aboutsummaryrefslogtreecommitdiff
path: root/src/test/README
diff options
context:
space:
mode:
authorGavin Andresen <gavinandresen@gmail.com>2011-06-27 14:05:02 -0400
committerGavin Andresen <gavinandresen@gmail.com>2011-06-27 14:12:48 -0400
commit8baf865c94653e21d4f6f43bbb5c712b16aba0e4 (patch)
tree406fea14ada1518e4d4122d4785deb7165f0e290 /src/test/README
parentc774b1697690c3f94ccd79c5de660b6050ac6409 (diff)
downloadbitcoin-8baf865c94653e21d4f6f43bbb5c712b16aba0e4.tar.xz
Boost unit-testing framework.
make -f makefile.{unix,osx,mingw} test_bitcoin to compile dumb, do-almost-nothing placeholder unit tests.
Diffstat (limited to 'src/test/README')
-rw-r--r--src/test/README21
1 files changed, 21 insertions, 0 deletions
diff --git a/src/test/README b/src/test/README
new file mode 100644
index 0000000000..77f7faa815
--- /dev/null
+++ b/src/test/README
@@ -0,0 +1,21 @@
+The sources in this directory are unit test cases. Boost includes a
+unit testing framework, and since bitcoin already uses boost, it makes
+sense to simply use this framework rather than require developers to
+configure some other framework (we want as few impediments to creating
+unit tests as possible).
+
+The build system is setup to compile an executable called "test_bitcoin"
+that runs all of the unit tests. The main source file is called
+test_bitcoin.cpp, which simply includes other files that contain the
+actual unit tests (outside of a couple required preprocessor
+directives). The pattern is to create one test file for each class or
+source file for which you want to create unit tests. The file naming
+convention is "<source_filename>_tests.cpp" and such files should wrap
+their tests in a test suite called "<source_filename>_tests". For an
+examples of this pattern, examine uint160_tests.cpp and
+uint256_tests.cpp.
+
+For further reading, I found the following website to be helpful in
+explaining how the boost unit test framework works:
+
+http://www.alittlemadness.com/2009/03/31/c-unit-testing-with-boosttest/