Skip to content

Commit 88af502

Browse files
committed
test: Add createrawtransaction functional tests
1 parent 27c6199 commit 88af502

File tree

1 file changed

+35
-0
lines changed

1 file changed

+35
-0
lines changed

test/functional/rawtransactions.py

+35
Original file line numberDiff line numberDiff line change
@@ -58,6 +58,41 @@ def run_test(self):
5858
self.nodes[0].generate(5)
5959
self.sync_all()
6060

61+
# Test `createrawtransaction` required parameters
62+
assert_raises_rpc_error(-1, "createrawtransaction", self.nodes[0].createrawtransaction)
63+
assert_raises_rpc_error(-1, "createrawtransaction", self.nodes[0].createrawtransaction, [])
64+
65+
# Test `createrawtransaction` invalid extra parameters
66+
assert_raises_rpc_error(-1, "createrawtransaction", self.nodes[0].createrawtransaction, [], {}, 0, False, 'foo')
67+
68+
# Test `createrawtransaction` invalid `inputs`
69+
txid = '1d1d4e24ed99057e84c3f80fd8fbec79ed9e1acee37da269356ecea000000000'
70+
assert_raises_rpc_error(-3, "Expected type array", self.nodes[0].createrawtransaction, 'foo', {})
71+
assert_raises_rpc_error(-1, "JSON value is not an object as expected", self.nodes[0].createrawtransaction, ['foo'], {})
72+
assert_raises_rpc_error(-8, "txid must be hexadecimal string", self.nodes[0].createrawtransaction, [{}], {})
73+
assert_raises_rpc_error(-8, "txid must be hexadecimal string", self.nodes[0].createrawtransaction, [{'txid': 'foo'}], {})
74+
assert_raises_rpc_error(-8, "Invalid parameter, missing vout key", self.nodes[0].createrawtransaction, [{'txid': txid}], {})
75+
assert_raises_rpc_error(-8, "Invalid parameter, missing vout key", self.nodes[0].createrawtransaction, [{'txid': txid, 'vout': 'foo'}], {})
76+
assert_raises_rpc_error(-8, "Invalid parameter, vout must be positive", self.nodes[0].createrawtransaction, [{'txid': txid, 'vout': -1}], {})
77+
assert_raises_rpc_error(-8, "Invalid parameter, sequence number is out of range", self.nodes[0].createrawtransaction, [{'txid': txid, 'vout': 0, 'sequence': -1}], {})
78+
79+
# Test `createrawtransaction` invalid `outputs`
80+
address = self.nodes[0].getnewaddress()
81+
assert_raises_rpc_error(-3, "Expected type object", self.nodes[0].createrawtransaction, [], 'foo')
82+
assert_raises_rpc_error(-8, "Data must be hexadecimal string", self.nodes[0].createrawtransaction, [], {'data': 'foo'})
83+
assert_raises_rpc_error(-5, "Invalid Bitcoin address", self.nodes[0].createrawtransaction, [], {'foo': 0})
84+
assert_raises_rpc_error(-3, "Invalid amount", self.nodes[0].createrawtransaction, [], {address: 'foo'})
85+
assert_raises_rpc_error(-3, "Amount out of range", self.nodes[0].createrawtransaction, [], {address: -1})
86+
assert_raises_rpc_error(-8, "Invalid parameter, duplicated address: %s" % address, self.nodes[0].createrawtransaction, [], multidict([(address, 1), (address, 1)]))
87+
88+
# Test `createrawtransaction` invalid `locktime`
89+
assert_raises_rpc_error(-3, "Expected type number", self.nodes[0].createrawtransaction, [], {}, 'foo')
90+
assert_raises_rpc_error(-8, "Invalid parameter, locktime out of range", self.nodes[0].createrawtransaction, [], {}, -1)
91+
assert_raises_rpc_error(-8, "Invalid parameter, locktime out of range", self.nodes[0].createrawtransaction, [], {}, 4294967296)
92+
93+
# Test `createrawtransaction` invalid `replaceable`
94+
assert_raises_rpc_error(-3, "Expected type bool", self.nodes[0].createrawtransaction, [], {}, 0, 'foo')
95+
6196
#########################################
6297
# sendrawtransaction with missing input #
6398
#########################################

0 commit comments

Comments
 (0)