How to write this unit-test with more standard testing librariesDo I need to create more functions? And also, is this code difficult to unit test?How to unit test this method?Test Driven Development, Mocking & Unit-testingIs this good practice with unit-testing?Unit testing - test class inheritance vs single test classHow to write unit test cases for any real time Java app?Unit testing with a singly linked listMethod injection into TestClass local namespace for automatic generation of Python unittest “test_xxx” methodsUnit test with check testing frameworkPrepare a cross-platform QT C-wrapper class for unit testing and mocking
Do I need to be arrogant to get ahead?
Why does a Star of David appear at a rally with Francisco Franco?
What exactly is this small puffer fish doing and how did it manage to accomplish such a feat?
Non-trivial topology where only open sets are closed
Different outputs for `w`, `who`, `whoami` and `id`
Why did it take so long to abandon sail after steamships were demonstrated?
About the actual radiative impact of greenhouse gas emission over time
Does .bashrc contain syntax errors?
I got the following comment from a reputed math journal. What does it mean?
Four married couples attend a party. Each person shakes hands with every other person, except their own spouse, exactly once. How many handshakes?
Why is there is so much iron?
How difficult is it to simply disable/disengage the MCAS on Boeing 737 Max 8 & 9 Aircraft?
Is there a symmetric-key algorithm which we can use for creating a signature?
How can we have a quark condensate without a quark potential?
How do you talk to someone whose loved one is dying?
Recruiter wants very extensive technical details about all of my previous work
Should Stotras and Mantras be recited aloud?
What is the meaning of まっちろけ?
A single argument pattern definition applies to multiple-argument patterns?
Does multi-classing into Fighter give you heavy armor proficiency?
"of which" is correct here?
Are all passive ability checks floors for active ability checks?
How are passwords stolen from companies if they only store hashes?
How could a scammer know the apps on my phone / iTunes account?
How to write this unit-test with more standard testing libraries
Do I need to create more functions? And also, is this code difficult to unit test?How to unit test this method?Test Driven Development, Mocking & Unit-testingIs this good practice with unit-testing?Unit testing - test class inheritance vs single test classHow to write unit test cases for any real time Java app?Unit testing with a singly linked listMethod injection into TestClass local namespace for automatic generation of Python unittest “test_xxx” methodsUnit test with check testing frameworkPrepare a cross-platform QT C-wrapper class for unit testing and mocking
$begingroup$
Here is a simple unit-test I wrote for a binary-search-tree class (I removed a lot of tests to focus on the main question):
#include <iostream>
using std::cout, std::endl;
#include "Tree.hpp"
#include "badkan.hpp"
int main()
Tree tree;
badkan::TestCase tc("Binary tree");
tc
.CHECK_EQUAL (tree.size(), 0)
.CHECK_EQUAL (tree.contains(5), false)
.CHECK_OK (tree.insert(5))
.CHECK_EQUAL (tree.size(), 1)
.CHECK_EQUAL (tree.contains(5), true)
.CHECK_OK (tree.remove(5))
.CHECK_EQUAL (tree.contains(5), false)
.CHECK_THROWS(tree.remove(5))
.CHECK_EQUAL (tree.size() ,0)
;
cout << "You have " << tc.right() << " right answers "
<< " and " << tc.wrong() << " wrong answers "
<< " so your grade is " << tc.grade() << ". Great!" << endl;
The "badkan.hpp" is a simple library that I wrote for unit-testing: https://github.com/erelsgl/ariel-cpp-5779/blob/master/02-classes-constructors-destructors/homework/badkan.hpp
The program defines a TestCase variable tc, then runs one of the methods:
- CHECK_EQUAL to check that the outcome of a function equals a certain value;
- CHECK_OK to check that the given function runs without exceptions;
- CHECK_THROWS to check that the given function throws an exception.
Finally, it prints the number of right and wrong answers and calculates the grade (right/(right+wrong)).
There are many things to improve here, but the main thing I am interested in is: how to write this code using a more standard library for unitesting, such as: GoogleTest, catch2, doctest, etc.?
From what I know, these libraries can print nice-looking reports, however, they do not give me the ability to actually read the number of right and wrong answers in the code (like tc.right() and tc.wrong()) and do calculations with them (like tc.grade()).
c++ unit-testing
$endgroup$
add a comment |
$begingroup$
Here is a simple unit-test I wrote for a binary-search-tree class (I removed a lot of tests to focus on the main question):
#include <iostream>
using std::cout, std::endl;
#include "Tree.hpp"
#include "badkan.hpp"
int main()
Tree tree;
badkan::TestCase tc("Binary tree");
tc
.CHECK_EQUAL (tree.size(), 0)
.CHECK_EQUAL (tree.contains(5), false)
.CHECK_OK (tree.insert(5))
.CHECK_EQUAL (tree.size(), 1)
.CHECK_EQUAL (tree.contains(5), true)
.CHECK_OK (tree.remove(5))
.CHECK_EQUAL (tree.contains(5), false)
.CHECK_THROWS(tree.remove(5))
.CHECK_EQUAL (tree.size() ,0)
;
cout << "You have " << tc.right() << " right answers "
<< " and " << tc.wrong() << " wrong answers "
<< " so your grade is " << tc.grade() << ". Great!" << endl;
The "badkan.hpp" is a simple library that I wrote for unit-testing: https://github.com/erelsgl/ariel-cpp-5779/blob/master/02-classes-constructors-destructors/homework/badkan.hpp
The program defines a TestCase variable tc, then runs one of the methods:
- CHECK_EQUAL to check that the outcome of a function equals a certain value;
- CHECK_OK to check that the given function runs without exceptions;
- CHECK_THROWS to check that the given function throws an exception.
Finally, it prints the number of right and wrong answers and calculates the grade (right/(right+wrong)).
There are many things to improve here, but the main thing I am interested in is: how to write this code using a more standard library for unitesting, such as: GoogleTest, catch2, doctest, etc.?
From what I know, these libraries can print nice-looking reports, however, they do not give me the ability to actually read the number of right and wrong answers in the code (like tc.right() and tc.wrong()) and do calculations with them (like tc.grade()).
c++ unit-testing
$endgroup$
add a comment |
$begingroup$
Here is a simple unit-test I wrote for a binary-search-tree class (I removed a lot of tests to focus on the main question):
#include <iostream>
using std::cout, std::endl;
#include "Tree.hpp"
#include "badkan.hpp"
int main()
Tree tree;
badkan::TestCase tc("Binary tree");
tc
.CHECK_EQUAL (tree.size(), 0)
.CHECK_EQUAL (tree.contains(5), false)
.CHECK_OK (tree.insert(5))
.CHECK_EQUAL (tree.size(), 1)
.CHECK_EQUAL (tree.contains(5), true)
.CHECK_OK (tree.remove(5))
.CHECK_EQUAL (tree.contains(5), false)
.CHECK_THROWS(tree.remove(5))
.CHECK_EQUAL (tree.size() ,0)
;
cout << "You have " << tc.right() << " right answers "
<< " and " << tc.wrong() << " wrong answers "
<< " so your grade is " << tc.grade() << ". Great!" << endl;
The "badkan.hpp" is a simple library that I wrote for unit-testing: https://github.com/erelsgl/ariel-cpp-5779/blob/master/02-classes-constructors-destructors/homework/badkan.hpp
The program defines a TestCase variable tc, then runs one of the methods:
- CHECK_EQUAL to check that the outcome of a function equals a certain value;
- CHECK_OK to check that the given function runs without exceptions;
- CHECK_THROWS to check that the given function throws an exception.
Finally, it prints the number of right and wrong answers and calculates the grade (right/(right+wrong)).
There are many things to improve here, but the main thing I am interested in is: how to write this code using a more standard library for unitesting, such as: GoogleTest, catch2, doctest, etc.?
From what I know, these libraries can print nice-looking reports, however, they do not give me the ability to actually read the number of right and wrong answers in the code (like tc.right() and tc.wrong()) and do calculations with them (like tc.grade()).
c++ unit-testing
$endgroup$
Here is a simple unit-test I wrote for a binary-search-tree class (I removed a lot of tests to focus on the main question):
#include <iostream>
using std::cout, std::endl;
#include "Tree.hpp"
#include "badkan.hpp"
int main()
Tree tree;
badkan::TestCase tc("Binary tree");
tc
.CHECK_EQUAL (tree.size(), 0)
.CHECK_EQUAL (tree.contains(5), false)
.CHECK_OK (tree.insert(5))
.CHECK_EQUAL (tree.size(), 1)
.CHECK_EQUAL (tree.contains(5), true)
.CHECK_OK (tree.remove(5))
.CHECK_EQUAL (tree.contains(5), false)
.CHECK_THROWS(tree.remove(5))
.CHECK_EQUAL (tree.size() ,0)
;
cout << "You have " << tc.right() << " right answers "
<< " and " << tc.wrong() << " wrong answers "
<< " so your grade is " << tc.grade() << ". Great!" << endl;
The "badkan.hpp" is a simple library that I wrote for unit-testing: https://github.com/erelsgl/ariel-cpp-5779/blob/master/02-classes-constructors-destructors/homework/badkan.hpp
The program defines a TestCase variable tc, then runs one of the methods:
- CHECK_EQUAL to check that the outcome of a function equals a certain value;
- CHECK_OK to check that the given function runs without exceptions;
- CHECK_THROWS to check that the given function throws an exception.
Finally, it prints the number of right and wrong answers and calculates the grade (right/(right+wrong)).
There are many things to improve here, but the main thing I am interested in is: how to write this code using a more standard library for unitesting, such as: GoogleTest, catch2, doctest, etc.?
From what I know, these libraries can print nice-looking reports, however, they do not give me the ability to actually read the number of right and wrong answers in the code (like tc.right() and tc.wrong()) and do calculations with them (like tc.grade()).
c++ unit-testing
c++ unit-testing
asked 14 mins ago
Erel Segal-HaleviErel Segal-Halevi
2771212
2771212
add a comment |
add a comment |
0
active
oldest
votes
Your Answer
StackExchange.ifUsing("editor", function ()
return StackExchange.using("mathjaxEditing", function ()
StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix)
StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["\$", "\$"]]);
);
);
, "mathjax-editing");
StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");
StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "196"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);
else
createEditor();
);
function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
var $window = $(window),
onScroll = function(e)
var $elem = $('.new-login-left'),
docViewTop = $window.scrollTop(),
docViewBottom = docViewTop + $window.height(),
elemTop = $elem.offset().top,
elemBottom = elemTop + $elem.height();
if ((docViewTop elemBottom))
StackExchange.using('gps', function() StackExchange.gps.track('embedded_signup_form.view', location: 'question_page' ); );
$window.unbind('scroll', onScroll);
;
$window.on('scroll', onScroll);
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f215597%2fhow-to-write-this-unit-test-with-more-standard-testing-libraries%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
0
active
oldest
votes
0
active
oldest
votes
active
oldest
votes
active
oldest
votes
Thanks for contributing an answer to Code Review Stack Exchange!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
Use MathJax to format equations. MathJax reference.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
var $window = $(window),
onScroll = function(e)
var $elem = $('.new-login-left'),
docViewTop = $window.scrollTop(),
docViewBottom = docViewTop + $window.height(),
elemTop = $elem.offset().top,
elemBottom = elemTop + $elem.height();
if ((docViewTop elemBottom))
StackExchange.using('gps', function() StackExchange.gps.track('embedded_signup_form.view', location: 'question_page' ); );
$window.unbind('scroll', onScroll);
;
$window.on('scroll', onScroll);
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f215597%2fhow-to-write-this-unit-test-with-more-standard-testing-libraries%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
var $window = $(window),
onScroll = function(e)
var $elem = $('.new-login-left'),
docViewTop = $window.scrollTop(),
docViewBottom = docViewTop + $window.height(),
elemTop = $elem.offset().top,
elemBottom = elemTop + $elem.height();
if ((docViewTop elemBottom))
StackExchange.using('gps', function() StackExchange.gps.track('embedded_signup_form.view', location: 'question_page' ); );
$window.unbind('scroll', onScroll);
;
$window.on('scroll', onScroll);
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
var $window = $(window),
onScroll = function(e)
var $elem = $('.new-login-left'),
docViewTop = $window.scrollTop(),
docViewBottom = docViewTop + $window.height(),
elemTop = $elem.offset().top,
elemBottom = elemTop + $elem.height();
if ((docViewTop elemBottom))
StackExchange.using('gps', function() StackExchange.gps.track('embedded_signup_form.view', location: 'question_page' ); );
$window.unbind('scroll', onScroll);
;
$window.on('scroll', onScroll);
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
var $window = $(window),
onScroll = function(e)
var $elem = $('.new-login-left'),
docViewTop = $window.scrollTop(),
docViewBottom = docViewTop + $window.height(),
elemTop = $elem.offset().top,
elemBottom = elemTop + $elem.height();
if ((docViewTop elemBottom))
StackExchange.using('gps', function() StackExchange.gps.track('embedded_signup_form.view', location: 'question_page' ); );
$window.unbind('scroll', onScroll);
;
$window.on('scroll', onScroll);
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown