Fix importmulti bug when importing an already imported key
This commit is contained in:
parent
364da2c529
commit
a44a215177
2 changed files with 13 additions and 1 deletions
|
@ -961,7 +961,7 @@ UniValue ProcessImport(CWallet * const pwallet, const UniValue& data, const int6
|
||||||
pwallet->SetAddressBook(vchAddress, label, "receive");
|
pwallet->SetAddressBook(vchAddress, label, "receive");
|
||||||
|
|
||||||
if (pwallet->HaveKey(vchAddress)) {
|
if (pwallet->HaveKey(vchAddress)) {
|
||||||
return false;
|
throw JSONRPCError(RPC_WALLET_ERROR, "The wallet already contains the private key for this address or script");
|
||||||
}
|
}
|
||||||
|
|
||||||
pwallet->mapKeyMetadata[vchAddress].nCreateTime = timestamp;
|
pwallet->mapKeyMetadata[vchAddress].nCreateTime = timestamp;
|
||||||
|
|
|
@ -160,6 +160,18 @@ class ImportMultiTest (BitcoinTestFramework):
|
||||||
assert_equal(address_assert['ismine'], True)
|
assert_equal(address_assert['ismine'], True)
|
||||||
assert_equal(address_assert['timestamp'], timestamp)
|
assert_equal(address_assert['timestamp'], timestamp)
|
||||||
|
|
||||||
|
self.log.info("Should not import an address with private key if is already imported")
|
||||||
|
result = self.nodes[1].importmulti([{
|
||||||
|
"scriptPubKey": {
|
||||||
|
"address": address['address']
|
||||||
|
},
|
||||||
|
"timestamp": "now",
|
||||||
|
"keys": [ self.nodes[0].dumpprivkey(address['address']) ]
|
||||||
|
}])
|
||||||
|
assert_equal(result[0]['success'], False)
|
||||||
|
assert_equal(result[0]['error']['code'], -4)
|
||||||
|
assert_equal(result[0]['error']['message'], 'The wallet already contains the private key for this address or script')
|
||||||
|
|
||||||
# Address + Private key + watchonly
|
# Address + Private key + watchonly
|
||||||
self.log.info("Should not import an address with private key and with watchonly")
|
self.log.info("Should not import an address with private key and with watchonly")
|
||||||
address = self.nodes[0].validateaddress(self.nodes[0].getnewaddress())
|
address = self.nodes[0].validateaddress(self.nodes[0].getnewaddress())
|
||||||
|
|
Loading…
Add table
Reference in a new issue