diff options
author | Andrew Chow <achow101-github@achow101.com> | 2017-09-29 00:21:28 -0400 |
---|---|---|
committer | Andrew Chow <achow101-github@achow101.com> | 2018-01-11 14:13:24 -0500 |
commit | 1df206f854d222230dcffd58e1b496567e570978 (patch) | |
tree | ae69bf08457642e4bd354461bbc391747605a1aa /test/functional/deprecated_rpc.py | |
parent | 0910cbe4ef31eb95fd76c7c2f820419fe64a3150 (diff) | |
download | bitcoin-1df206f854d222230dcffd58e1b496567e570978.tar.xz |
Disallow using addresses in createmultisig
Make createmultisig only accept public keys with the old functionality
marked as deprecated.
Splits _createmultisig_redeemscript into two functions, one for
getting public keys from UniValue and one for getting addresses
from UniValue and then their respective public keys. The one for
retrieving address's public keys is located in rpcwallet.cpp
Changes addwitnessaddress's output to be a JSON object with
two fields, address and redeemscript.
Adds a test to deprecated_rpc.py for testing the deprecation.
Update the tests to use addwitnessaddress or give only public keys
to createmultisig. Anything that used addwitnessaddress was also
updated to reflect the new API.
Diffstat (limited to 'test/functional/deprecated_rpc.py')
-rwxr-xr-x | test/functional/deprecated_rpc.py | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/test/functional/deprecated_rpc.py b/test/functional/deprecated_rpc.py index 19fd24edb9..d6f25158ef 100755 --- a/test/functional/deprecated_rpc.py +++ b/test/functional/deprecated_rpc.py @@ -10,7 +10,7 @@ class DeprecatedRpcTest(BitcoinTestFramework): def set_test_params(self): self.num_nodes = 2 self.setup_clean_chain = True - self.extra_args = [[], ["-deprecatedrpc=estimatefee"]] + self.extra_args = [[], ["-deprecatedrpc=estimatefee", "-deprecatedrpc=createmultisig"]] def run_test(self): self.log.info("estimatefee: Shows deprecated message") @@ -19,5 +19,9 @@ class DeprecatedRpcTest(BitcoinTestFramework): self.log.info("Using -deprecatedrpc=estimatefee bypasses the error") self.nodes[1].estimatefee(1) + self.log.info("Make sure that -deprecatedrpc=createmultisig allows it to take addresses") + assert_raises_rpc_error(-5, "Invalid public key", self.nodes[0].createmultisig, 1, [self.nodes[0].getnewaddress()]) + self.nodes[1].createmultisig(1, [self.nodes[1].getnewaddress()]) + if __name__ == '__main__': DeprecatedRpcTest().main() |