kevacoin/qa/rpc-tests
2014-12-09 10:57:51 +01:00
..
python-bitcoinrpc
.gitignore
conflictedbalance.sh
forknotify.py
getblocktemplate_longpoll.py
getblocktemplate_proposals.py
getchaintips.py
httpbasics.py [RPC] add rpc-test for http keep-alive (persistent connections) 2014-12-06 23:15:22 +01:00
keypool.py
listtransactions.py
mempool_resurrect_test.py Fix missing python2 in rpc-tests 2014-12-05 16:04:05 -08:00
mempool_spendcoinbase.py Fix missing python2 in rpc-tests 2014-12-05 16:04:05 -08:00
netutil.py
README.md
receivedby.py
rest.py Fix missing python2 in rpc-tests 2014-12-05 16:04:05 -08:00
rpcbind_test.py
send.sh
smartfees.py
test_framework.py
txn_doublespend.py
util.py
util.sh
wallet.py
walletbackup.py Port of walletbackup.sh to Python. 2014-12-09 10:57:51 +01:00
zapwallettxes.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.

test_framework.py

Base class for 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