diff options
author | Andrew Chow <achow101@gmail.com> | 2016-04-27 12:18:20 -0700 |
---|---|---|
committer | Andrew <achow101@gmail.com> | 2016-04-28 14:58:14 -0400 |
commit | 7db0ecb90c80bd4995bedf8c2982e9a22345ca65 (patch) | |
tree | 3550a35888cdb3bb355df24327d52270941fb03d /qa/rpc-tests/signmessages.py | |
parent | f90efbfeef9cd733aa7590fdf581ff82b999c4b5 (diff) |
Test for signing messages
New rpc test for signing and verifying messages.
Diffstat (limited to 'qa/rpc-tests/signmessages.py')
-rwxr-xr-x | qa/rpc-tests/signmessages.py | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/qa/rpc-tests/signmessages.py b/qa/rpc-tests/signmessages.py new file mode 100755 index 0000000000..ff22f35300 --- /dev/null +++ b/qa/rpc-tests/signmessages.py @@ -0,0 +1,40 @@ +#!/usr/bin/env python2 +# Copyright (c) 2016 The Bitcoin Core developers +# Distributed under the MIT software license, see the accompanying +# file COPYING or http://www.opensource.org/licenses/mit-license.php. + +from test_framework.test_framework import BitcoinTestFramework +from test_framework.util import * + + +class SignMessagesTest(BitcoinTestFramework): + """Tests RPC commands for signing and verifying messages.""" + + def setup_chain(self): + print('Initializing test directory ' + self.options.tmpdir) + initialize_chain_clean(self.options.tmpdir, 1) + + def setup_network(self, split=False): + self.nodes = start_nodes(1, self.options.tmpdir) + self.is_network_split = False + + def run_test(self): + message = 'This is just a test message' + + # Test the signing with a privkey + privKey = 'cUeKHd5orzT3mz8P9pxyREHfsWtVfgsfDjiZZBcjUBAaGk1BTj7N' + address = 'mpLQjfK79b7CCV4VMJWEWAj5Mpx8Up5zxB' + signature = self.nodes[0].signmessagewithprivkey(privKey, message) + + # Verify the message + assert(self.nodes[0].verifymessage(address, signature, message)) + + # Test the signing with an address with wallet + address = self.nodes[0].getnewaddress() + signature = self.nodes[0].signmessage(address, message) + + # Verify the message + assert(self.nodes[0].verifymessage(address, signature, message)) + +if __name__ == '__main__': + SignMessagesTest().main() |