cb4bdd18a7
This should show how to run a python-based regression test successfully in the pull-tester environment. |
||
---|---|---|
.. | ||
python-bitcoinrpc | ||
.gitignore | ||
conflictedbalance.sh | ||
listtransactions.py | ||
README.md | ||
send.sh | ||
skeleton.py | ||
txnmall.sh | ||
util.py | ||
util.sh | ||
wallet.sh | ||
walletbackup.sh |
Regression tests of RPC interface
python-bitcoinrpc: git subtree of https://github.com/jgarzik/python-bitcoinrpc Changes to python-bitcoinrpc should be made upstream, and then pulled here using git subtree
skeleton.py : Copy this to create new regression tests.
listtransactions.py : Tests for the listtransactions RPC call
util.py : generally useful functions
Bash-based tests, to be ported to Python:
wallet.sh : Exercise wallet send/receive code. walletbackup.sh : Exercise wallet backup / dump / import txnmall.sh : Test proper accounting of malleable transactions conflictedbalance.sh : More testing of malleable transaction handling
Notes
A 200-block -regtest blockchain and wallets for four nodes is created the first time a regression test is run and is stored in the cache/ directory. Each node has 25 mature blocks (25*50=1250 BTC) in their wallet.
After the first run, the cache/ blockchain and wallets are copied into a temporary directory and used as the initial test state.
If you get into a bad state, you should be able to recover with: rm -rf cache killall bitcoind