bitcoin/src/test
Wladimir J. van der Laan 961901f77e
Merge #11117: Prepare for non-Base58 addresses
864cd2787 Move CBitcoinAddress to base58.cpp (Pieter Wuille)
5c8ff0d44 Introduce wrappers around CBitcoinAddress (Pieter Wuille)

Pull request description:

  This patch removes the need for the intermediary Base58 type `CBitcoinAddress`, by providing {`Encode`,`Decode`,`IsValid`}`Destination` functions that directly operate on the conversion between `std::string`s and `CTxDestination`.

  As a side, it also fixes a number of indentation issues, and removes probably several unnecessary implicit `CTxDestination`<->`CBitcoinAddress` conversions.

  This change is far from complete. In follow-ups I'd like to:
  * Split off the specific address and key encoding logic from base58.h, and move it to a address.h or so.
  * Replace `CTxDestination` with a non-`boost::variant` version (which can be more efficient as `boost::variant` allocates everything on the heap, and remove the need for `boost::get<...>` and `IsValidDestination` calls everywhere).
  * Do the same for `CBitcoinSecret`, `CBitcoinExtKey`, and `CBitcoinExtPubKey`.

  However, I've tried to keep this patch to be minimally invasive, but still enough to support non-Base58 addresses. Perhaps a smaller patch is possible to hack Bech32 support into `CBitcoinAddress`, but I would consider that a move in the wrong direction.

Tree-SHA512: c2c77ffb57caeadf2429b1c2562ce60e8c7be8aa9f8e51b591f354b6b441162625b2efe14c023a1ae485cf2ed417263afa35c892891dfaa7844e7fbabccab85e
2017-09-06 22:31:02 +02:00
..
data Merge #10679: Document the non-DER-conformance of one test in tx_valid.json. 2017-08-23 12:15:10 +02:00
addrman_tests.cpp Add recommendation: By default, declare single-argument constructors explicit 2017-08-22 22:55:19 +02:00
allocator_tests.cpp Use the override specifier (C++11) where we expect to be overriding the virtual function of a base class 2017-06-28 02:12:06 +02:00
amount_tests.cpp Consensus: Policy: MOVEONLY: Move CFeeRate out of the consensus module 2017-05-03 18:00:13 +02:00
arith_uint256_tests.cpp Fixed multiple typos 2017-06-22 19:18:10 +03:00
base32_tests.cpp Bump copyright headers to 2015 2015-12-13 18:08:39 +01:00
base58_tests.cpp Introduce wrappers around CBitcoinAddress 2017-09-06 13:07:45 -07:00
base64_tests.cpp Bump copyright headers to 2015 2015-12-13 18:08:39 +01:00
bip32_tests.cpp Declare single-argument (non-converting) constructors "explicit" 2017-08-16 16:33:25 +02:00
blockencodings_tests.cpp Declare single-argument (non-converting) constructors "explicit" 2017-08-16 16:33:25 +02:00
bloom_tests.cpp Remove unused Boost includes 2017-06-09 10:25:26 +02:00
bswap_tests.cpp Uses built-in byte swap if available (Apple) and if bswap_XX is undefined. 2016-12-17 12:27:00 +09:00
checkqueue_tests.cpp Merge #10521: Limit variable scope 2017-06-09 13:09:24 -07:00
coins_tests.cpp Declare single-argument (non-converting) constructors "explicit" 2017-08-16 16:33:25 +02:00
compress_tests.cpp Bump copyright headers to 2015 2015-12-13 18:08:39 +01:00
crypto_tests.cpp Merge #10545: Use list initialization (C++11) for maps/vectors instead of boost::assign::map_list_of/list_of 2017-06-08 20:26:40 +02:00
cuckoocache_tests.cpp Remove unused Boost includes 2017-06-09 10:25:26 +02:00
dbwrapper_tests.cpp Declare single-argument (non-converting) constructors "explicit" 2017-08-16 16:33:25 +02:00
DoS_tests.cpp scripted-diff: stop using the gArgs wrappers 2017-08-14 17:02:10 +02:00
getarg_tests.cpp scripted-diff: stop using the gArgs wrappers 2017-08-14 17:02:10 +02:00
hash_tests.cpp scripted-diff: Use new naming style for insecure_rand* functions 2017-06-07 12:08:39 -07:00
key_tests.cpp Introduce wrappers around CBitcoinAddress 2017-09-06 13:07:45 -07:00
limitedmap_tests.cpp [Trivial] Grammar and typo correction 2017-01-22 13:18:51 +01:00
main_tests.cpp Chainparams: Get rid of CChainParams& Params(std::string) 2017-05-03 18:15:54 +02:00
Makefile build: add stub makefiles for easier subdir builds 2014-06-05 16:05:43 -04:00
mempool_tests.cpp Merge #9548: Remove min reasonable fee 2017-03-07 19:49:00 +01:00
merkle_tests.cpp scripted-diff: Use new naming style for insecure_rand* functions 2017-06-07 12:08:39 -07:00
miner_tests.cpp scripted-diff: Use the C++11 keyword nullptr to denote the pointer literal instead of the macro NULL 2017-08-07 07:36:37 +02:00
multisig_tests.cpp scripted-diff: Use the C++11 keyword nullptr to denote the pointer literal instead of the macro NULL 2017-08-07 07:36:37 +02:00
net_tests.cpp scripted-diff: stop using the gArgs wrappers 2017-08-14 17:02:10 +02:00
netbase_tests.cpp [refactor] move SplitHostPort() into utilstrencodings 2017-07-12 17:06:15 -04:00
pmt_tests.cpp Merge #10545: Use list initialization (C++11) for maps/vectors instead of boost::assign::map_list_of/list_of 2017-06-08 20:26:40 +02:00
policyestimator_tests.cpp Remove checking of mempool min fee from estimateSmartFee. 2017-07-14 23:41:40 -04:00
pow_tests.cpp scripted-diff: Use the C++11 keyword nullptr to denote the pointer literal instead of the macro NULL 2017-08-07 07:36:37 +02:00
prevector_tests.cpp Add const to methods that do not modify the object for which it is called 2017-07-25 13:46:52 +02:00
raii_event_tests.cpp scripted-diff: Use the C++11 keyword nullptr to denote the pointer literal instead of the macro NULL 2017-08-07 07:36:37 +02:00
random_tests.cpp Add FastRandomContext::rand256() and ::randbytes() 2017-06-05 12:44:44 -07:00
README.md Move src/test/bitcoin-util-test.py to test/util/bitcoin-util-test.py 2017-03-20 10:40:31 -04:00
reverselock_tests.cpp Increment MIT Licence copyright header year on files modified in 2016 2016-12-31 11:01:21 -07:00
rpc_tests.cpp rpc: Move ValueFromAmount to core_write 2017-08-07 17:01:21 +02:00
sanity_tests.cpp Bump copyright headers to 2015 2015-12-13 18:08:39 +01:00
scheduler_tests.cpp [tests] Use FastRandomContext instead of boost::random::{mt19937,uniform_int_distribution} 2017-06-07 20:38:03 +02:00
script_P2SH_tests.cpp scripted-diff: Use the C++11 keyword nullptr to denote the pointer literal instead of the macro NULL 2017-08-07 07:36:37 +02:00
script_tests.cpp Merge #9964: Add const to methods that do not modify the object for which it is called 2017-08-16 02:09:49 +02:00
scriptnum10.h Bump copyright headers to 2015 2015-12-13 18:08:39 +01:00
scriptnum_tests.cpp [tests] Avoid redundant assignments. Remove unused variables. 2017-07-09 13:05:01 +02:00
serialize_tests.cpp [trivial] Fix typos in comments 2017-01-27 21:22:35 +01:00
sighash_tests.cpp [tests] Avoid redundant assignments. Remove unused variables. 2017-07-09 13:05:01 +02:00
sigopcount_tests.cpp Remove confusing MAX_BLOCK_BASE_SIZE. 2017-07-14 19:24:17 +00:00
skiplist_tests.cpp scripted-diff: Use the C++11 keyword nullptr to denote the pointer literal instead of the macro NULL 2017-08-07 07:36:37 +02:00
streams_tests.cpp Remove unused Boost includes 2017-06-09 10:25:26 +02:00
test_bitcoin.cpp Remove redundant testutil files 2017-09-05 15:02:17 +12:00
test_bitcoin.h Declare single-argument (non-converting) constructors "explicit" 2017-08-16 16:33:25 +02:00
test_bitcoin_fuzzy.cpp Switch CCoinsView and chainstate db from per-txid to per-txout 2017-06-01 12:59:38 -07:00
test_bitcoin_main.cpp Add attribute [[noreturn]] (C++11) to functions that will not return 2017-07-17 18:46:18 +02:00
timedata_tests.cpp Refactoring: Removed using namespace <xxx> from bench/ and test/ source files. 2017-01-02 20:35:23 +09:00
torcontrol_tests.cpp torcontrol: Handle escapes in Tor QuotedStrings 2017-05-16 18:22:25 +12:00
transaction_tests.cpp Remove factor of 3 from definition of dust. 2017-07-17 07:10:03 -04:00
txvalidationcache_tests.cpp scripted-diff: Use the C++11 keyword nullptr to denote the pointer literal instead of the macro NULL 2017-08-07 07:36:37 +02:00
uint256_tests.cpp Increment MIT Licence copyright header year on files modified in 2016 2016-12-31 11:01:21 -07:00
univalue_tests.cpp Merge #9281: Refactor: Remove using namespace <xxx> from bench/ & test/ sources 2017-01-05 11:32:05 +01:00
util_tests.cpp Allow setting nMinimumChainWork on command line 2017-09-05 15:05:28 -04:00
versionbits_tests.cpp Improve versionbits_computeblockversion test code consistency 2017-08-28 00:03:18 +03:00

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 bitcoind tests manually, launch src/test/test_bitcoin.

To add more bitcoind 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 bitcoin-qt tests manually, launch src/qt/test/test_bitcoin-qt

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

Running individual tests

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

test_bitcoin --log_level=all --run_test=getarg_tests

... or to run just the doubledash test:

test_bitcoin --run_test=getarg_tests/doubledash

Run test_bitcoin --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 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. 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.

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/.