summaryrefslogtreecommitdiffstats
path: root/Readme.testing
diff options
context:
space:
mode:
authorGravatar Miika Turkia <miika.turkia@gmail.com>2014-04-15 20:09:00 +0300
committerGravatar Dirk Hohndel <dirk@hohndel.org>2014-04-15 11:03:38 -0700
commit54af66bdb3f4738ca658d7bf7ffde56b26ec5032 (patch)
treef1b080189d1404bf3e89845035125ddc65e2c185 /Readme.testing
parent2e80d79396936d379aa71d65db597b7edc84e4da (diff)
downloadsubsurface-54af66bdb3f4738ca658d7bf7ffde56b26ec5032.tar.gz
Information on writing test cases
This information is mainly from Tomaz on IRC with references added to Qt documentation on the subject. Signed-off-by: Miika Turkia <miika.turkia@gmail.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'Readme.testing')
-rw-r--r--Readme.testing63
1 files changed, 63 insertions, 0 deletions
diff --git a/Readme.testing b/Readme.testing
index a7583e982..a229e3a16 100644
--- a/Readme.testing
+++ b/Readme.testing
@@ -14,3 +14,66 @@ but more verbosically - easyer to track them down.
to create a new test, just implement copy the one provided by
example in the tests folder and add the last three lines of the CMakeLists.txt file
adapted to your test.
+
+
+
+To create a new test you can do one of the following (information
+provided by Tomaz on IRC):
+
+1) Create a new private slot on an already created test class
+2) Implement the test there, and compare the expected result with the
+correct result with QCOMPARE:
+
+void testRedCeiling();
+testRedCeiling()
+{
+ load_dive("../dive/testDive.xml");
+ calculated_ceiling();
+ QCOMPARE( dive->ceiling->color(), QColor("red"));
+}
+
+3) Run the test case and see result
+
+$ make test
+
+If the color is not QColor("red"), when you run the test you will get a
+failure. Then you run a command to get a more verbose output and see in
+which part the test fails.
+
+$ ctest -V
+
+4) Fix the test case
+
+5) Look at the existing test cases if you run into trouble or need more
+ideas. E.g. running following command will show the first test cases
+written for unit conversions:
+
+$ git show 019edd065fd1eefd5f705c42bce23255bb5e20ac
+
+Also the Qt documentation is good source for more information:
+
+http://qt-project.org/doc/qt-4.8/qtest.html
+http://qt-project.org/doc/qt-5/qtest.html
+
+6) To create a new test class, copy the last three lines of the CMake,
+and duplicate it with the new class / file.
+
+Each "test" can have N test cases on it (each private slot counts as one
+test) and is executable. When one runs make, these test cases are
+compiled and when running "make test" they will be executed. Of course,
+the test cases can be run manually as well.
+
+There are three main test macros that we use, but of course many more
+are available (check the Qt documentation):
+
+QCOMPARE(value, expected)
+QVERIFY(boolean)
+QVERIFY2(boolean, "error message on fail")
+
+If expecting a test case to fail, use
+
+QEXPECT_FAIL("", "This test case fails, as it is not yet fully implemented", Continue);
+
+To link libraries, use the following macro:
+
+TARGET_LINK_LIBRARIES(TestCaseName ${QT_LIBRARIES} subsurface_corelib)