aboutsummaryrefslogtreecommitdiffstats
path: root/src/tests
diff options
context:
space:
mode:
authorSimon Warta <[email protected]>2015-07-15 00:16:50 +0200
committerSimon Warta <[email protected]>2015-07-15 00:16:50 +0200
commitcadcfbf1bdcbf1377d117eb81402ae1b9f3c3f04 (patch)
treeb543806c0a62f33a1bb13dc25db4c60d93c752fd /src/tests
parent15a53cd1cf09078e456a4fd03484e71fd00f055e (diff)
Improve test reporting
Diffstat (limited to 'src/tests')
-rw-r--r--src/tests/tests.cpp14
-rw-r--r--src/tests/tests.h2
2 files changed, 9 insertions, 7 deletions
diff --git a/src/tests/tests.cpp b/src/tests/tests.cpp
index b7cfd2ecc..ebb34227d 100644
--- a/src/tests/tests.cpp
+++ b/src/tests/tests.cpp
@@ -33,24 +33,26 @@ size_t run_tests_in_dir(const std::string& dir, std::function<size_t (const std:
return fails;
}
-size_t run_tests(const std::vector<test_fn>& tests)
+size_t run_tests(const std::vector<std::pair<std::string, test_fn>>& tests)
{
size_t fails = 0;
- for(auto& test : tests)
+ for(const auto& row : tests)
{
+ auto name = row.first;
+ auto test = row.second;
try
{
fails += test();
}
catch(std::exception& e)
{
- std::cout << "Exception escaped test: " << e.what() << std::endl;
+ std::cout << name << ": Exception escaped test: " << e.what() << std::endl;
++fails;
}
catch(...)
{
- std::cout << "Exception escaped test" << std::endl;
+ std::cout << name << ": Exception escaped test" << std::endl;
++fails;
}
}
@@ -226,10 +228,10 @@ int main(int argc, char* argv[])
if(target == "-h" || target == "--help" || target == "help")
return help(argv[0]);
- std::vector<test_fn> tests;
+ std::vector<std::pair<std::string, test_fn>> tests;
#define DEF_TEST(test) do { if(target == "all" || target == #test) \
- tests.push_back(test_ ## test); \
+ tests.push_back(std::make_pair(#test, test_ ## test)); \
} while(0)
DEF_TEST(block);
diff --git a/src/tests/tests.h b/src/tests/tests.h
index 15ce4b4ab..d2fe0e69b 100644
--- a/src/tests/tests.h
+++ b/src/tests/tests.h
@@ -42,7 +42,7 @@ size_t run_tests_in_dir(const std::string& dir, std::function<size_t (const std:
// Run a list of tests
typedef std::function<size_t ()> test_fn;
-size_t run_tests(const std::vector<test_fn>& tests);
+size_t run_tests(const std::vector<std::pair<std::string, test_fn>>& tests);
void test_report(const std::string& name, size_t ran, size_t failed);
#define TEST(expr, msg) do { if(!(expr)) { ++fails; std::cout << msg; } while(0)