RPC tests for generatetoaddress
Adds two RPC tests for the generatetoaddress RPC, one in the wallet, and one when the wallet is disabled. The wallet RPC Test mines Bitcoin to another node's address and checks that that node has received the Bitcoin. The RPC test without the wallet mines Bitcoin to an arbitrary address and checks that it works. It then mines to an arbitrary invalid address and checks that that fails.
This commit is contained in:
parent
fe00ca758a
commit
d5c5c713e6
2 changed files with 26 additions and 0 deletions
|
@ -29,5 +29,19 @@ class DisableWalletTest (BitcoinTestFramework):
|
||||||
x = self.nodes[0].validateaddress('mneYUmWYsuk7kySiURxCi3AGxrAqZxLgPZ')
|
x = self.nodes[0].validateaddress('mneYUmWYsuk7kySiURxCi3AGxrAqZxLgPZ')
|
||||||
assert(x['isvalid'] == True)
|
assert(x['isvalid'] == True)
|
||||||
|
|
||||||
|
# Checking mining to an address without a wallet
|
||||||
|
try:
|
||||||
|
self.nodes[0].generatetoaddress(1, 'mneYUmWYsuk7kySiURxCi3AGxrAqZxLgPZ')
|
||||||
|
except JSONRPCException,e:
|
||||||
|
assert("Invalid address" not in e.error['message'])
|
||||||
|
assert("ProcessNewBlock, block not accepted" not in e.error['message'])
|
||||||
|
assert("Couldn't create new block" not in e.error['message'])
|
||||||
|
|
||||||
|
try:
|
||||||
|
self.nodes[0].generatetoaddress(1, '3J98t1WpEZ73CNmQviecrnyiWrnqRhWNLy')
|
||||||
|
raise AssertionError("Must not mine to invalid address!")
|
||||||
|
except JSONRPCException,e:
|
||||||
|
assert("Invalid address" in e.error['message'])
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
DisableWalletTest ().main ()
|
DisableWalletTest ().main ()
|
||||||
|
|
|
@ -262,6 +262,18 @@ class WalletTest (BitcoinTestFramework):
|
||||||
|
|
||||||
assert("not an integer" in errorString)
|
assert("not an integer" in errorString)
|
||||||
|
|
||||||
|
# Mine a block from node0 to an address from node1
|
||||||
|
cbAddr = self.nodes[1].getnewaddress()
|
||||||
|
blkHash = self.nodes[0].generatetoaddress(1, cbAddr)[0]
|
||||||
|
cbTxId = self.nodes[0].getblock(blkHash)['tx'][0]
|
||||||
|
self.sync_all()
|
||||||
|
|
||||||
|
# Check that the txid and balance is found by node1
|
||||||
|
try:
|
||||||
|
self.nodes[1].gettransaction(cbTxId)
|
||||||
|
except JSONRPCException,e:
|
||||||
|
assert("Invalid or non-wallet transaction id" not in e.error['message'])
|
||||||
|
|
||||||
#check if wallet or blochchain maintenance changes the balance
|
#check if wallet or blochchain maintenance changes the balance
|
||||||
self.sync_all()
|
self.sync_all()
|
||||||
blocks = self.nodes[0].generate(2)
|
blocks = self.nodes[0].generate(2)
|
||||||
|
|
Loading…
Add table
Reference in a new issue