Hush Full Node software. We were censored from Github, this is where all development happens now. https://hush.is
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Duke Leto d4883bce7c More timedate changes from KMD 0.6 4 years ago
..
data Add json test vectors for Sapling key components. 6 years ago
Checkpoints_tests.cpp chainparams: move CCheckpointData into chainparams.h 7 years ago
DoS_tests.cpp Part of #2966, extending Sprout tests to other epochs. 6 years ago
Makefile build: add stub makefiles for easier subdir builds 10 years ago
README.md Update some unit test stuff 5 years ago
accounting_tests.cpp Refactor: replace calls to GetTxid() with GetHash() 8 years ago
addrman_tests.cpp More timedate changes from KMD 0.6 4 years ago
alert_tests.cpp Changes for most chain power rule 6 years ago
allocator_tests.cpp allocators: split allocators and pagelocker 9 years ago
arith_uint256_tests.cpp tests: add a BasicTestingSetup and apply to all tests 9 years ago
base32_tests.cpp Simplify Base32 and Base64 conversions 6 years ago
base58_tests.cpp Split key_io (address/key encodings) off from base58 6 years ago
base64_tests.cpp Simplify Base32 and Base64 conversions 6 years ago
bctest.py cleanup: Ensure code is pyflakes-clean for CI 6 years ago
bech32_tests.cpp Raise the 90-character limit on Bech32 encodings 6 years ago
bignum.h Assert that new OpenSSL allocators succeed 8 years ago
bip32_tests.cpp Split key_io (address/key encodings) off from base58 6 years ago
bitcoin-util-test.py Use portable #! in python scripts (/usr/bin/env) 6 years ago
bloom_tests.cpp Split key_io (address/key encodings) off from base58 6 years ago
buildenv.py.in Use portable #! in python scripts (/usr/bin/env) 6 years ago
checkblock_tests.cpp Skip JoinSplit verification before the last checkpoint 8 years ago
coins_tests.cpp desprout 4 years ago
compress_tests.cpp coin supply, rewards 8 years ago
convertbits_tests.cpp Generalize ConvertBits 6 years ago
crypto_tests.cpp tests: add a BasicTestingSetup and apply to all tests 9 years ago
dbwrapper_tests.cpp Get rid of nType and nVersion 6 years ago
equihash_tests.cpp Add compile flag to disable compilation of mining code 8 years ago
getarg_tests.cpp tests: add a BasicTestingSetup and apply to all tests 9 years ago
hash_tests.cpp tests: add a BasicTestingSetup and apply to all tests 9 years ago
key_tests.cpp desprout 4 years ago
main_tests.cpp Update tests to account for decreased block interval 8 years ago
mempool_tests.cpp Closes #3134 - Least Authority Issue E 6 years ago
miner_tests.cpp Pass in _pk to CreateBlock 6 years ago
mruset_tests.cpp Better mruset unit test 9 years ago
multisig_tests.cpp Part of #2966, extending Sprout tests to other epochs. 6 years ago
netbase_tests.cpp add unit test for CNetAddr::GetGroup. 9 years ago
pmt_tests.cpp [test] Remove unused code 6 years ago
policyestimator_tests.cpp Merge remote-tracking branch 'zcash/master' into rebase2 6 years ago
pow_tests.cpp Changes for most chain power rule 6 years ago
prevector_tests.cpp Prevector type 6 years ago
raii_event_tests.cpp Skip RAII event tests if libevent is built without event_set_mem_functions 7 years ago
reverselock_tests.cpp c++11: don't throw from the reverselock destructor 7 years ago
rpc_tests.cpp Fix rpc c++ tests 5 years ago
rpc_wallet_tests.cpp desprout 4 years ago
sanity_tests.cpp tests: add a BasicTestingSetup and apply to all tests 9 years ago
scheduler_tests.cpp Update to address @daira comments wrt fixing configure.ac 7 years ago
script_P2PKH_tests.cpp Bitcore port 6 years ago
script_P2SH_tests.cpp Prevector type 6 years ago
script_tests.cpp Prevector type 6 years ago
scriptnum_tests.cpp Make CScriptNum() take nMaxNumSize as an argument 9 years ago
serialize_tests.cpp Replace boost::array with std::array 6 years ago
sha256compress_tests.cpp Remove unused code in libzerocash util.cpp 8 years ago
sighash_tests.cpp Improve/Fix variable names 6 years ago
sigopcount_tests.cpp Prevector type 6 years ago
skiplist_tests.cpp Changes for most chain power rule 6 years ago
test_bitcoin.cpp Avoid downloading the 700MB sprout-groth16 file we do not need 5 years ago
test_bitcoin.h Remove mempool transactions which commit to an unmineable branch ID 6 years ago
timedata_tests.cpp tests: add a BasicTestingSetup and apply to all tests 9 years ago
torcontrol_tests.cpp Check that >3-digit octals are truncated. 7 years ago
transaction_tests.cpp delete 4 years ago
uint256_tests.cpp Get rid of nType and nVersion 6 years ago
univalue_tests.cpp UniValue: don't escape solidus, keep espacing of reverse solidus 7 years ago
util_tests.cpp [test] Remove unused code 6 years ago
wallet-utility.py Bitcore port 6 years ago

README.md

Hush Unit tests

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.

Add the source files to /src/Makefile.test.include to add them to the build.

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