mirror of
https://github.com/kvazar-network/kevacoin.git
synced 2025-01-14 00:58:09 +00:00
dcb98466b4
Add the capability to simulate network splits to the RPC test framework and use it to do more extensive testing of 'getchaintips'.
167 lines
7.2 KiB
Python
Executable File
167 lines
7.2 KiB
Python
Executable File
#!/usr/bin/env python
|
|
# Copyright (c) 2014 The Bitcoin Core developers
|
|
# Distributed under the MIT/X11 software license, see the accompanying
|
|
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
# Exercise the listreceivedbyaddress API
|
|
|
|
from test_framework import BitcoinTestFramework
|
|
from bitcoinrpc.authproxy import AuthServiceProxy, JSONRPCException
|
|
from util import *
|
|
|
|
|
|
def get_sub_array_from_array(object_array, to_match):
|
|
'''
|
|
Finds and returns a sub array from an array of arrays.
|
|
to_match should be a unique idetifier of a sub array
|
|
'''
|
|
num_matched = 0
|
|
for item in object_array:
|
|
all_match = True
|
|
for key,value in to_match.items():
|
|
if item[key] != value:
|
|
all_match = False
|
|
if not all_match:
|
|
continue
|
|
return item
|
|
return []
|
|
|
|
def check_array_result(object_array, to_match, expected, should_not_find = False):
|
|
"""
|
|
Pass in array of JSON objects, a dictionary with key/value pairs
|
|
to match against, and another dictionary with expected key/value
|
|
pairs.
|
|
If the should_not_find flag is true, to_match should not be found in object_array
|
|
"""
|
|
if should_not_find == True:
|
|
expected = { }
|
|
num_matched = 0
|
|
for item in object_array:
|
|
all_match = True
|
|
for key,value in to_match.items():
|
|
if item[key] != value:
|
|
all_match = False
|
|
if not all_match:
|
|
continue
|
|
for key,value in expected.items():
|
|
if item[key] != value:
|
|
raise AssertionError("%s : expected %s=%s"%(str(item), str(key), str(value)))
|
|
num_matched = num_matched+1
|
|
if num_matched == 0 and should_not_find != True:
|
|
raise AssertionError("No objects matched %s"%(str(to_match)))
|
|
if num_matched > 0 and should_not_find == True:
|
|
raise AssertionError("Objects was matched %s"%(str(to_match)))
|
|
|
|
class ReceivedByTest(BitcoinTestFramework):
|
|
|
|
def run_test(self):
|
|
'''
|
|
listreceivedbyaddress Test
|
|
'''
|
|
# Send from node 0 to 1
|
|
addr = self.nodes[1].getnewaddress()
|
|
txid = self.nodes[0].sendtoaddress(addr, 0.1)
|
|
self.sync_all()
|
|
|
|
#Check not listed in listreceivedbyaddress because has 0 confirmations
|
|
check_array_result(self.nodes[1].listreceivedbyaddress(),
|
|
{"address":addr},
|
|
{ },
|
|
True)
|
|
#Bury Tx under 10 block so it will be returned by listreceivedbyaddress
|
|
self.nodes[1].setgenerate(True, 10)
|
|
self.sync_all()
|
|
check_array_result(self.nodes[1].listreceivedbyaddress(),
|
|
{"address":addr},
|
|
{"address":addr, "account":"", "amount":Decimal("0.1"), "confirmations":10, "txids":[txid,]})
|
|
#With min confidence < 10
|
|
check_array_result(self.nodes[1].listreceivedbyaddress(5),
|
|
{"address":addr},
|
|
{"address":addr, "account":"", "amount":Decimal("0.1"), "confirmations":10, "txids":[txid,]})
|
|
#With min confidence > 10, should not find Tx
|
|
check_array_result(self.nodes[1].listreceivedbyaddress(11),{"address":addr},{ },True)
|
|
|
|
#Empty Tx
|
|
addr = self.nodes[1].getnewaddress()
|
|
check_array_result(self.nodes[1].listreceivedbyaddress(0,True),
|
|
{"address":addr},
|
|
{"address":addr, "account":"", "amount":0, "confirmations":0, "txids":[]})
|
|
|
|
'''
|
|
getreceivedbyaddress Test
|
|
'''
|
|
# Send from node 0 to 1
|
|
addr = self.nodes[1].getnewaddress()
|
|
txid = self.nodes[0].sendtoaddress(addr, 0.1)
|
|
self.sync_all()
|
|
|
|
#Check balance is 0 because of 0 confirmations
|
|
balance = self.nodes[1].getreceivedbyaddress(addr)
|
|
if balance != Decimal("0.0"):
|
|
raise AssertionError("Wrong balance returned by getreceivedbyaddress, %0.2f"%(balance))
|
|
|
|
#Check balance is 0.1
|
|
balance = self.nodes[1].getreceivedbyaddress(addr,0)
|
|
if balance != Decimal("0.1"):
|
|
raise AssertionError("Wrong balance returned by getreceivedbyaddress, %0.2f"%(balance))
|
|
|
|
#Bury Tx under 10 block so it will be returned by the default getreceivedbyaddress
|
|
self.nodes[1].setgenerate(True, 10)
|
|
self.sync_all()
|
|
balance = self.nodes[1].getreceivedbyaddress(addr)
|
|
if balance != Decimal("0.1"):
|
|
raise AssertionError("Wrong balance returned by getreceivedbyaddress, %0.2f"%(balance))
|
|
|
|
'''
|
|
listreceivedbyaccount + getreceivedbyaccount Test
|
|
'''
|
|
#set pre-state
|
|
addrArr = self.nodes[1].getnewaddress()
|
|
account = self.nodes[1].getaccount(addrArr)
|
|
received_by_account_json = get_sub_array_from_array(self.nodes[1].listreceivedbyaccount(),{"account":account})
|
|
if len(received_by_account_json) == 0:
|
|
raise AssertionError("No accounts found in node")
|
|
balance_by_account = rec_by_accountArr = self.nodes[1].getreceivedbyaccount(account)
|
|
|
|
txid = self.nodes[0].sendtoaddress(addr, 0.1)
|
|
|
|
# listreceivedbyaccount should return received_by_account_json because of 0 confirmations
|
|
check_array_result(self.nodes[1].listreceivedbyaccount(),
|
|
{"account":account},
|
|
received_by_account_json)
|
|
|
|
# getreceivedbyaddress should return same balance because of 0 confirmations
|
|
balance = self.nodes[1].getreceivedbyaccount(account)
|
|
if balance != balance_by_account:
|
|
raise AssertionError("Wrong balance returned by getreceivedbyaccount, %0.2f"%(balance))
|
|
|
|
self.nodes[1].setgenerate(True, 10)
|
|
self.sync_all()
|
|
# listreceivedbyaccount should return updated account balance
|
|
check_array_result(self.nodes[1].listreceivedbyaccount(),
|
|
{"account":account},
|
|
{"account":received_by_account_json["account"], "amount":(received_by_account_json["amount"] + Decimal("0.1"))})
|
|
|
|
# getreceivedbyaddress should return updates balance
|
|
balance = self.nodes[1].getreceivedbyaccount(account)
|
|
if balance != balance_by_account + Decimal("0.1"):
|
|
raise AssertionError("Wrong balance returned by getreceivedbyaccount, %0.2f"%(balance))
|
|
|
|
#Create a new account named "mynewaccount" that has a 0 balance
|
|
self.nodes[1].getaccountaddress("mynewaccount")
|
|
received_by_account_json = get_sub_array_from_array(self.nodes[1].listreceivedbyaccount(0,True),{"account":"mynewaccount"})
|
|
if len(received_by_account_json) == 0:
|
|
raise AssertionError("No accounts found in node")
|
|
|
|
# Test includeempty of listreceivedbyaccount
|
|
if received_by_account_json["amount"] != Decimal("0.0"):
|
|
raise AssertionError("Wrong balance returned by listreceivedbyaccount, %0.2f"%(received_by_account_json["amount"]))
|
|
|
|
# Test getreceivedbyaccount for 0 amount accounts
|
|
balance = self.nodes[1].getreceivedbyaccount("mynewaccount")
|
|
if balance != Decimal("0.0"):
|
|
raise AssertionError("Wrong balance returned by getreceivedbyaccount, %0.2f"%(balance))
|
|
|
|
if __name__ == '__main__':
|
|
ReceivedByTest().main()
|