dash/src/test
MarcoFalke e0e2a2e3fe
Merge #15352: tests: Reduce noise level in test_bitcoin output
0aef39d067 Silence "Test case [...] did not check any assertions" warnings when running "test_bitcoin --log_level=test_suite" (practicalswift)
5fd73c8694 Avoid repeated log messages in tests by connecting to signal handlers (ThreadSafeMessageBox, etc.) only once (practicalswift)
e502c3c515 tests: Reduce noise level in test_bitcoin output (practicalswift)

Pull request description:

  Reduce noise level in `test_bitcoin` output.

  Context: When working on the non-determinism issues in the unit tests (see #15296) I got a bit tired of the amount of noise in the `test_bitcoin` output :-)

  Before:

  ```
  $ src/test/test_bitcoin --log_level=test_suite 2>&1 | grep -vE '(Entering|Leaving)' | uniq -c
        1 Running 341 test cases...
        1 Test case blockencodings_tests/TransactionsRequestDeserializationOverflowTest did not check any assertions
        1 CheckSplitTorReplyLine(PROTOCOLINFO PIVERSION)
        1 CheckSplitTorReplyLine(AUTH METHODS=COOKIE,SAFECOOKIE COOKIEFILE="/home/x/.tor/control_auth_cookie")
        1 CheckSplitTorReplyLine(AUTH METHODS=NULL)
        1 CheckSplitTorReplyLine(AUTH METHODS=HASHEDPASSWORD)
        1 CheckSplitTorReplyLine(VERSION Tor="0.2.9.8 (git-a0df013ea241b026)")
        1 CheckSplitTorReplyLine(AUTHCHALLENGE SERVERHASH=aaaa SERVERNONCE=bbbb)
        1 CheckSplitTorReplyLine(COMMAND)
        1 CheckSplitTorReplyLine(COMMAND SOME  ARGS)
        1 CheckSplitTorReplyLine(COMMAND  ARGS)
        1 CheckSplitTorReplyLine(COMMAND   EVEN+more  ARGS)
        1 CheckParseTorReplyMapping(METHODS=COOKIE,SAFECOOKIE COOKIEFILE="/home/x/.tor/control_auth_cookie")
        1 CheckParseTorReplyMapping(METHODS=NULL)
        1 CheckParseTorReplyMapping(METHODS=HASHEDPASSWORD)
        1 CheckParseTorReplyMapping(Tor="0.2.9.8 (git-a0df013ea241b026)")
        1 CheckParseTorReplyMapping(SERVERHASH=aaaa SERVERNONCE=bbbb)
        1 CheckParseTorReplyMapping(ServiceID=exampleonion1234)
        1 CheckParseTorReplyMapping(PrivateKey=RSA1024:BLOB)
        1 CheckParseTorReplyMapping(ClientAuth=bob:BLOB)
        1 CheckParseTorReplyMapping(Foo=Bar=Baz Spam=Eggs)
        1 CheckParseTorReplyMapping(Foo="Bar=Baz")
        1 CheckParseTorReplyMapping(Foo="Bar Baz")
        1 CheckParseTorReplyMapping(Foo="Bar\ Baz")
        1 CheckParseTorReplyMapping(Foo="Bar\Baz")
        1 CheckParseTorReplyMapping(Foo="Bar\@Baz")
        1 CheckParseTorReplyMapping(Foo="Bar\"Baz" Spam="\"Eggs\"")
        1 CheckParseTorReplyMapping(Foo="Bar\\Baz")
        1 CheckParseTorReplyMapping(Foo="Bar\nBaz\t" Spam="\rEggs" Octals="\1a\11\17\18\81\377\378\400\2222" Final=Check)
        1 CheckParseTorReplyMapping(Valid=Mapping Escaped="Escape\\")
        1 CheckParseTorReplyMapping(Valid=Mapping Bare="Escape\")
        1 CheckParseTorReplyMapping(OneOctal="OneEnd\1" TwoOctal="TwoEnd\11")
        1 CheckParseTorReplyMapping(Null="\0")
        1 CheckParseTorReplyMapping(SOME=args,here MORE optional=arguments  here)
        1 CheckParseTorReplyMapping(ARGS)
        1 CheckParseTorReplyMapping(MORE ARGS)
        1 CheckParseTorReplyMapping(MORE  ARGS)
        1 CheckParseTorReplyMapping(EVEN more=ARGS)
        1 CheckParseTorReplyMapping(EVEN+more ARGS)
        1 Test case util_tests/util_criticalsection did not check any assertions
        1 Testing known outcomes
      326 Error: Specified -walletdir "/tmp/test_bitcoin/1553850209_943311758/tempdir/path_does_not_exist" does not exist
      327 Error: Specified -walletdir "/tmp/test_bitcoin/1553850209_643733972/tempdir/not_a_directory.dat" is not a directory
      328 Error: Specified -walletdir "wallets" is a relative path
        1
        1 *** No errors detected

  ```

  After:

  ```
  $ src/test/test_bitcoin --log_level=test_suite 2>&1 | grep -vE '(Entering|Leaving)' | uniq -c
        1 Running 341 test cases...
        1 Error: Specified -walletdir "/tmp/test_bitcoin/1553850026_943311758/tempdir/path_does_not_exist" does not exist
        1 Error: Specified -walletdir "/tmp/test_bitcoin/1553850026_643733972/tempdir/not_a_directory.dat" is not a directory
        1 Error: Specified -walletdir "wallets" is a relative path
        1
        1 *** No errors detected

  ```

ACKs for commit 0aef39:
  MarcoFalke:
    utACK 0aef39d0678ec2f26633028d44eea0ba0087e7c0

Tree-SHA512: 9cc22f64aa5c875861bae6533d18675ad978c623f053754deef6a8e271ea70bda3f72fb4ec5c8fd19b841757f21380639051d5f5b44301b9d2464b57655e9c05
2021-10-25 12:20:19 -04:00
..
data
fuzz Merge bitcoin/bitcoin#21773: fuzz: Ensure prevout is consensus-valid 2021-10-21 14:33:54 -04:00
addrman_tests.cpp Merge #14935: tests: Test for expected return values when calling functions returning a success code 2021-09-30 16:18:49 -07:00
allocator_tests.cpp Merge #14151: windows: Fix remaining compiler warnings (MSVC) 2021-10-06 20:05:01 -04:00
amount_tests.cpp
arith_uint256_tests.cpp
base32_tests.cpp Merge #17753: util: Don't allow Base32/64-decoding or ParseMoney(…) on strings with embedded NUL characters. Add tests. 2021-09-17 15:56:38 -04:00
base58_tests.cpp
base64_tests.cpp Merge #17753: util: Don't allow Base32/64-decoding or ParseMoney(…) on strings with embedded NUL characters. Add tests. 2021-09-17 15:56:38 -04:00
bech32_tests.cpp
bip32_tests.cpp
bip39_tests.cpp
blockchain_tests.cpp Merge #12151: rpc: Remove cs_main lock from blockToJSON and blockheaderToJSON 2021-08-24 19:16:52 -04:00
blockencodings_tests.cpp Merge #15352: tests: Reduce noise level in test_bitcoin output 2021-10-25 12:20:19 -04:00
blockfilter_index_tests.cpp merge bitcoin#15948: rename chainActive 2021-10-22 08:15:22 +05:30
blockfilter_tests.cpp Merge #15532: Remove sharp edge (uninit member) when using the compiler-generated ctor for BlockFilter 2021-10-13 23:44:38 -05:00
bloom_tests.cpp
bls_tests.cpp
bswap_tests.cpp Merge #18181: test: Remove incorrect assumptions in validation_flush_tests (#4536) 2021-10-24 13:52:19 +03:00
cachemap_tests.cpp
cachemultimap_tests.cpp
checkdatasig_tests.cpp
checkqueue_tests.cpp Merge #15352: tests: Reduce noise level in test_bitcoin output 2021-10-25 12:20:19 -04:00
coins_tests.cpp merge bitcoin#14908: Removed implicit CTransaction constructor calls from tests and benchmark 2021-10-12 08:58:08 +05:30
compress_tests.cpp
crypto_tests.cpp Merge pull request #4486 from Munkybooty/appveyor-backports-v0.18 2021-10-10 22:11:56 +03:00
cuckoocache_tests.cpp Merge #14969: tests: Fix cuckoocache_tests TSAN failure introduced in 14935. 2021-09-30 16:18:49 -07:00
dbwrapper_tests.cpp Merge #14935: tests: Test for expected return values when calling functions returning a success code 2021-09-30 16:18:49 -07:00
denialofservice_tests.cpp merge bitcoin#15948: rename chainActive 2021-10-22 08:15:22 +05:30
descriptor_tests.cpp
dip0020opcodes_tests.cpp refactor: replace instances of typedef with using in dash code (#4488) 2021-10-06 00:26:29 +03:00
evo_deterministicmns_tests.cpp refactor: Include adjustments (#4526) 2021-10-25 16:55:34 +03:00
evo_simplifiedmns_tests.cpp
flatfile_tests.cpp
fs_tests.cpp
getarg_tests.cpp Merge #14599: Use functions guaranteed to be locale independent (IsDigit, ToLower) in {Format,Parse}Money(...), uint256::SetHex(...), etc. Remove the use of locale dependent boost::is_space(...) 2021-09-09 11:23:24 -07:00
governance_validators_tests.cpp refactor: remove redundant filename prefixes for Dash-specific logic (#4475) 2021-10-01 22:19:08 +03:00
hash_tests.cpp
key_io_tests.cpp refactor: Include adjustments (#4526) 2021-10-25 16:55:34 +03:00
key_tests.cpp Merge #14935: tests: Test for expected return values when calling functions returning a success code 2021-09-30 16:18:49 -07:00
lcg.h
limitedmap_tests.cpp
logging_tests.cpp
main.cpp
Makefile
mempool_tests.cpp merge bitcoin#14908: Removed implicit CTransaction constructor calls from tests and benchmark 2021-10-12 08:58:08 +05:30
merkle_tests.cpp Merge #15139: util: Remove [U](BEGIN|END) macros 2021-08-24 19:14:49 -04:00
merkleblock_tests.cpp
miner_tests.cpp merge bitcoin#15855: Add missing LockAnnotation for cs_main (#4530) 2021-10-25 16:14:34 +03:00
multisig_tests.cpp merge bitcoin#14908: Removed implicit CTransaction constructor calls from tests and benchmark 2021-10-12 08:58:08 +05:30
net_tests.cpp Merge #17345: test: Do not instantiate CAddrDB for static call CAddrDB::Read() 2021-10-20 13:50:52 -04:00
netbase_tests.cpp Merge #20129: tests: don't export in6addr_loopback 2021-09-07 03:25:11 +03:00
pmt_tests.cpp
policyestimator_tests.cpp Merge #14963: mempool, validation: Explain cs_main locking semantics 2021-08-24 19:14:50 -04:00
pow_tests.cpp
prevector_tests.cpp
raii_event_tests.cpp
random_tests.cpp
ratecheck_tests.cpp
README.md
reverselock_tests.cpp partial Merge #18234: refactor: Replace boost::mutex,condition_var,chrono with std equivalents in scheduler 2021-09-28 19:42:22 -04:00
rpc_tests.cpp Merge #14437: Refactor: Start to separate wallet from node 2021-10-20 12:29:45 -04:00
sanity_tests.cpp
scheduler_tests.cpp Merge #18695: test: Replace boost::mutex with std::mutex 2021-10-20 13:54:31 -04:00
script_p2pk_tests.cpp
script_p2pkh_tests.cpp
script_p2sh_tests.cpp merge bitcoin#14908: Removed implicit CTransaction constructor calls from tests and benchmark 2021-10-12 08:58:08 +05:30
script_standard_tests.cpp Merge #14935: tests: Test for expected return values when calling functions returning a success code 2021-09-30 16:18:49 -07:00
script_tests.cpp Merge pull request #4504 from kittywhiskers/explicit_ref 2021-10-13 17:47:53 +03:00
scriptnum10.h
scriptnum_tests.cpp
serialize_tests.cpp
sighash_tests.cpp merge bitcoin#14908: Removed implicit CTransaction constructor calls from tests and benchmark 2021-10-12 08:58:08 +05:30
sigopcount_tests.cpp
skiplist_tests.cpp
streams_tests.cpp Merge #14357: streams: Fix broken streams_vector_reader test. Remove unused seek(size_t). 2021-09-07 12:26:47 -04:00
subsidy_tests.cpp
sync_tests.cpp merge bitcoin#19353: Fix mistakenly swapped "previous" and "current" lock orders 2021-10-13 12:42:48 -04:00
test_dash.cpp merge bitcoin#16443: have CCoins* data managed under CChainState 2021-10-22 08:15:38 +05:30
test_dash.h Merge #13076: Fix ScanForWalletTransactions to return an enum indicating scan result: success / failure / user_abort 2021-09-15 00:04:44 +05:30
timedata_tests.cpp
torcontrol_tests.cpp Merge #15352: tests: Reduce noise level in test_bitcoin output 2021-10-25 12:20:19 -04:00
transaction_tests.cpp Merge #18181: test: Remove incorrect assumptions in validation_flush_tests (#4536) 2021-10-24 13:52:19 +03:00
txindex_tests.cpp partial Merge #18234: refactor: Replace boost::mutex,condition_var,chrono with std equivalents in scheduler 2021-09-28 19:42:22 -04:00
txvalidation_tests.cpp
txvalidationcache_tests.cpp merge bitcoin#16443: have CCoins* data managed under CChainState 2021-10-22 08:15:38 +05:30
uint256_tests.cpp
util_tests.cpp Merge #15352: tests: Reduce noise level in test_bitcoin output 2021-10-25 12:20:19 -04:00
util_threadnames_tests.cpp
validation_block_tests.cpp merge bitcoin#15855: Add missing LockAnnotation for cs_main (#4530) 2021-10-25 16:14:34 +03:00
validation_flush_tests.cpp Merge #18181: test: Remove incorrect assumptions in validation_flush_tests (#4536) 2021-10-24 13:52:19 +03:00
validation_tests.cpp
versionbits_tests.cpp

Compiling/running unit tests

Unit tests will be automatically compiled if dependencies were met in ./configure and tests weren't explicitly disabled.

After configuring, they can be run with make check.

To run the dashd tests manually, launch src/test/test_dash. To recompile after a test file was modified, run make and then run the test again. If you modify a non-test file, use make -C src/test to recompile only what's needed to run the dashd tests.

To add more dashd tests, add BOOST_AUTO_TEST_CASE functions to the existing .cpp files in the test/ directory or add new .cpp files that implement new BOOST_AUTO_TEST_SUITE sections.

To run the dash-qt tests manually, launch src/qt/test/test_dash-qt

To add more dash-qt tests, add them to the src/qt/test/ directory and the src/qt/test/test_main.cpp file.

Running individual tests

test_dash has some built-in command-line arguments; for example, to run just the getarg_tests verbosely:

test_dash --log_level=all --run_test=getarg_tests

... or to run just the doubledash test:

test_dash --run_test=getarg_tests/doubledash

Run test_dash --help for the full list.

Note on adding test cases

The sources in this directory are unit test cases. Boost includes a unit testing framework, and since Dash Core 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_dash that runs all of the unit tests. The main source file is called test_dash.cpp. To add a new unit test file to our test suite you need to add the file to src/Makefile.test.include. 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 example of this pattern, examine uint256_tests.cpp.