2019-06-06 03:53:16 -04:00
|
|
|
// Copyright (c) 2017-2019 The Bitcoin Core developers
|
|
|
|
// Distributed under the MIT software license, see the accompanying
|
|
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
|
|
|
|
#include <key.h>
|
2019-09-17 19:28:03 -03:00
|
|
|
#include <node/context.h>
|
2019-06-06 03:53:16 -04:00
|
|
|
#include <script/script.h>
|
|
|
|
#include <script/standard.h>
|
2019-11-05 17:18:59 -03:00
|
|
|
#include <test/util/setup_common.h>
|
2019-06-06 03:53:16 -04:00
|
|
|
#include <wallet/ismine.h>
|
2019-06-06 04:00:00 -04:00
|
|
|
#include <wallet/wallet.h>
|
2019-06-06 03:53:16 -04:00
|
|
|
|
|
|
|
#include <boost/test/unit_test.hpp>
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_FIXTURE_TEST_SUITE(ismine_tests, BasicTestingSetup)
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(ismine_standard)
|
|
|
|
{
|
|
|
|
CKey keys[2];
|
|
|
|
CPubKey pubkeys[2];
|
|
|
|
for (int i = 0; i < 2; i++) {
|
|
|
|
keys[i].MakeNewKey(true);
|
|
|
|
pubkeys[i] = keys[i].GetPubKey();
|
|
|
|
}
|
|
|
|
|
|
|
|
CKey uncompressedKey;
|
|
|
|
uncompressedKey.MakeNewKey(false);
|
|
|
|
CPubKey uncompressedPubkey = uncompressedKey.GetPubKey();
|
2019-09-17 19:28:03 -03:00
|
|
|
NodeContext node;
|
|
|
|
std::unique_ptr<interfaces::Chain> chain = interfaces::MakeChain(node);
|
2019-06-06 03:53:16 -04:00
|
|
|
|
|
|
|
CScript scriptPubKey;
|
|
|
|
isminetype result;
|
|
|
|
|
|
|
|
// P2PK compressed
|
|
|
|
{
|
2020-06-17 12:30:37 -04:00
|
|
|
CWallet keystore(chain.get(), WalletLocation(), CreateDummyWalletDatabase());
|
2019-10-07 15:11:34 -03:00
|
|
|
keystore.SetupLegacyScriptPubKeyMan();
|
2019-10-07 15:11:34 -03:00
|
|
|
LOCK(keystore.GetLegacyScriptPubKeyMan()->cs_KeyStore);
|
2019-06-06 03:53:16 -04:00
|
|
|
scriptPubKey = GetScriptForRawPubKey(pubkeys[0]);
|
|
|
|
|
|
|
|
// Keystore does not have key
|
2019-10-07 15:11:34 -03:00
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
|
|
|
|
// Keystore has key
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(keys[0]));
|
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_SPENDABLE);
|
|
|
|
}
|
|
|
|
|
|
|
|
// P2PK uncompressed
|
|
|
|
{
|
2020-06-17 12:30:37 -04:00
|
|
|
CWallet keystore(chain.get(), WalletLocation(), CreateDummyWalletDatabase());
|
2019-10-07 15:11:34 -03:00
|
|
|
keystore.SetupLegacyScriptPubKeyMan();
|
2019-10-07 15:11:34 -03:00
|
|
|
LOCK(keystore.GetLegacyScriptPubKeyMan()->cs_KeyStore);
|
2019-06-06 03:53:16 -04:00
|
|
|
scriptPubKey = GetScriptForRawPubKey(uncompressedPubkey);
|
|
|
|
|
|
|
|
// Keystore does not have key
|
2019-10-07 15:11:34 -03:00
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
|
|
|
|
// Keystore has key
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(uncompressedKey));
|
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_SPENDABLE);
|
|
|
|
}
|
|
|
|
|
|
|
|
// P2PKH compressed
|
|
|
|
{
|
2020-06-17 12:30:37 -04:00
|
|
|
CWallet keystore(chain.get(), WalletLocation(), CreateDummyWalletDatabase());
|
2019-10-07 15:11:34 -03:00
|
|
|
keystore.SetupLegacyScriptPubKeyMan();
|
2019-10-07 15:11:34 -03:00
|
|
|
LOCK(keystore.GetLegacyScriptPubKeyMan()->cs_KeyStore);
|
2019-06-06 03:53:16 -04:00
|
|
|
scriptPubKey = GetScriptForDestination(PKHash(pubkeys[0]));
|
|
|
|
|
|
|
|
// Keystore does not have key
|
2019-10-07 15:11:34 -03:00
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
|
|
|
|
// Keystore has key
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(keys[0]));
|
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_SPENDABLE);
|
|
|
|
}
|
|
|
|
|
|
|
|
// P2PKH uncompressed
|
|
|
|
{
|
2020-06-17 12:30:37 -04:00
|
|
|
CWallet keystore(chain.get(), WalletLocation(), CreateDummyWalletDatabase());
|
2019-10-07 15:11:34 -03:00
|
|
|
keystore.SetupLegacyScriptPubKeyMan();
|
2019-10-07 15:11:34 -03:00
|
|
|
LOCK(keystore.GetLegacyScriptPubKeyMan()->cs_KeyStore);
|
2019-06-06 03:53:16 -04:00
|
|
|
scriptPubKey = GetScriptForDestination(PKHash(uncompressedPubkey));
|
|
|
|
|
|
|
|
// Keystore does not have key
|
2019-10-07 15:11:34 -03:00
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
|
|
|
|
// Keystore has key
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(uncompressedKey));
|
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_SPENDABLE);
|
|
|
|
}
|
|
|
|
|
|
|
|
// P2SH
|
|
|
|
{
|
2020-06-17 12:30:37 -04:00
|
|
|
CWallet keystore(chain.get(), WalletLocation(), CreateDummyWalletDatabase());
|
2019-10-07 15:11:34 -03:00
|
|
|
keystore.SetupLegacyScriptPubKeyMan();
|
2019-10-07 15:11:34 -03:00
|
|
|
LOCK(keystore.GetLegacyScriptPubKeyMan()->cs_KeyStore);
|
2019-06-06 03:53:16 -04:00
|
|
|
|
|
|
|
CScript redeemScript = GetScriptForDestination(PKHash(pubkeys[0]));
|
|
|
|
scriptPubKey = GetScriptForDestination(ScriptHash(redeemScript));
|
|
|
|
|
|
|
|
// Keystore does not have redeemScript or key
|
2019-10-07 15:11:34 -03:00
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
|
|
|
|
// Keystore has redeemScript but no key
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(redeemScript));
|
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
|
|
|
|
// Keystore has redeemScript and key
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(keys[0]));
|
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_SPENDABLE);
|
|
|
|
}
|
|
|
|
|
|
|
|
// (P2PKH inside) P2SH inside P2SH (invalid)
|
|
|
|
{
|
2020-06-17 12:30:37 -04:00
|
|
|
CWallet keystore(chain.get(), WalletLocation(), CreateDummyWalletDatabase());
|
2019-10-07 15:11:34 -03:00
|
|
|
keystore.SetupLegacyScriptPubKeyMan();
|
2019-10-07 15:11:34 -03:00
|
|
|
LOCK(keystore.GetLegacyScriptPubKeyMan()->cs_KeyStore);
|
2019-06-06 03:53:16 -04:00
|
|
|
|
|
|
|
CScript redeemscript_inner = GetScriptForDestination(PKHash(pubkeys[0]));
|
|
|
|
CScript redeemscript = GetScriptForDestination(ScriptHash(redeemscript_inner));
|
|
|
|
scriptPubKey = GetScriptForDestination(ScriptHash(redeemscript));
|
|
|
|
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(redeemscript));
|
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(redeemscript_inner));
|
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(scriptPubKey));
|
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(keys[0]));
|
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
}
|
|
|
|
|
|
|
|
// (P2PKH inside) P2SH inside P2WSH (invalid)
|
|
|
|
{
|
2020-06-17 12:30:37 -04:00
|
|
|
CWallet keystore(chain.get(), WalletLocation(), CreateDummyWalletDatabase());
|
2019-10-07 15:11:34 -03:00
|
|
|
keystore.SetupLegacyScriptPubKeyMan();
|
2019-10-07 15:11:34 -03:00
|
|
|
LOCK(keystore.GetLegacyScriptPubKeyMan()->cs_KeyStore);
|
2019-06-06 03:53:16 -04:00
|
|
|
|
|
|
|
CScript redeemscript = GetScriptForDestination(PKHash(pubkeys[0]));
|
|
|
|
CScript witnessscript = GetScriptForDestination(ScriptHash(redeemscript));
|
|
|
|
scriptPubKey = GetScriptForDestination(WitnessV0ScriptHash(witnessscript));
|
|
|
|
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(witnessscript));
|
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(redeemscript));
|
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(scriptPubKey));
|
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(keys[0]));
|
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
}
|
|
|
|
|
|
|
|
// P2WPKH inside P2WSH (invalid)
|
|
|
|
{
|
2020-06-17 12:30:37 -04:00
|
|
|
CWallet keystore(chain.get(), WalletLocation(), CreateDummyWalletDatabase());
|
2019-10-07 15:11:34 -03:00
|
|
|
keystore.SetupLegacyScriptPubKeyMan();
|
2019-10-07 15:11:34 -03:00
|
|
|
LOCK(keystore.GetLegacyScriptPubKeyMan()->cs_KeyStore);
|
2019-06-06 03:53:16 -04:00
|
|
|
|
2020-01-15 04:46:14 -03:00
|
|
|
CScript witnessscript = GetScriptForDestination(WitnessV0KeyHash(pubkeys[0]));
|
2019-06-06 03:53:16 -04:00
|
|
|
scriptPubKey = GetScriptForDestination(WitnessV0ScriptHash(witnessscript));
|
|
|
|
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(witnessscript));
|
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(scriptPubKey));
|
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(keys[0]));
|
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
}
|
|
|
|
|
|
|
|
// (P2PKH inside) P2WSH inside P2WSH (invalid)
|
|
|
|
{
|
2020-06-17 12:30:37 -04:00
|
|
|
CWallet keystore(chain.get(), WalletLocation(), CreateDummyWalletDatabase());
|
2019-10-07 15:11:34 -03:00
|
|
|
keystore.SetupLegacyScriptPubKeyMan();
|
2019-10-07 15:11:34 -03:00
|
|
|
LOCK(keystore.GetLegacyScriptPubKeyMan()->cs_KeyStore);
|
2019-06-06 03:53:16 -04:00
|
|
|
|
|
|
|
CScript witnessscript_inner = GetScriptForDestination(PKHash(pubkeys[0]));
|
|
|
|
CScript witnessscript = GetScriptForDestination(WitnessV0ScriptHash(witnessscript_inner));
|
|
|
|
scriptPubKey = GetScriptForDestination(WitnessV0ScriptHash(witnessscript));
|
|
|
|
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(witnessscript_inner));
|
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(witnessscript));
|
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(scriptPubKey));
|
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(keys[0]));
|
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
}
|
|
|
|
|
|
|
|
// P2WPKH compressed
|
|
|
|
{
|
2020-06-17 12:30:37 -04:00
|
|
|
CWallet keystore(chain.get(), WalletLocation(), CreateDummyWalletDatabase());
|
2019-10-07 15:11:34 -03:00
|
|
|
keystore.SetupLegacyScriptPubKeyMan();
|
2019-10-07 15:11:34 -03:00
|
|
|
LOCK(keystore.GetLegacyScriptPubKeyMan()->cs_KeyStore);
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(keys[0]));
|
2019-06-06 03:53:16 -04:00
|
|
|
|
2020-01-15 04:46:14 -03:00
|
|
|
scriptPubKey = GetScriptForDestination(WitnessV0KeyHash(pubkeys[0]));
|
2019-06-06 03:53:16 -04:00
|
|
|
|
|
|
|
// Keystore implicitly has key and P2SH redeemScript
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(scriptPubKey));
|
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_SPENDABLE);
|
|
|
|
}
|
|
|
|
|
|
|
|
// P2WPKH uncompressed
|
|
|
|
{
|
2020-06-17 12:30:37 -04:00
|
|
|
CWallet keystore(chain.get(), WalletLocation(), CreateDummyWalletDatabase());
|
2019-10-07 15:11:34 -03:00
|
|
|
keystore.SetupLegacyScriptPubKeyMan();
|
2019-10-07 15:11:34 -03:00
|
|
|
LOCK(keystore.GetLegacyScriptPubKeyMan()->cs_KeyStore);
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(uncompressedKey));
|
2019-06-06 03:53:16 -04:00
|
|
|
|
2020-01-15 04:46:14 -03:00
|
|
|
scriptPubKey = GetScriptForDestination(WitnessV0KeyHash(uncompressedPubkey));
|
2019-06-06 03:53:16 -04:00
|
|
|
|
|
|
|
// Keystore has key, but no P2SH redeemScript
|
2019-10-07 15:11:34 -03:00
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
|
|
|
|
// Keystore has key and P2SH redeemScript
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(scriptPubKey));
|
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
}
|
|
|
|
|
|
|
|
// scriptPubKey multisig
|
|
|
|
{
|
2020-06-17 12:30:37 -04:00
|
|
|
CWallet keystore(chain.get(), WalletLocation(), CreateDummyWalletDatabase());
|
2019-10-07 15:11:34 -03:00
|
|
|
keystore.SetupLegacyScriptPubKeyMan();
|
2019-10-07 15:11:34 -03:00
|
|
|
LOCK(keystore.GetLegacyScriptPubKeyMan()->cs_KeyStore);
|
2019-06-06 03:53:16 -04:00
|
|
|
|
|
|
|
scriptPubKey = GetScriptForMultisig(2, {uncompressedPubkey, pubkeys[1]});
|
|
|
|
|
|
|
|
// Keystore does not have any keys
|
2019-10-07 15:11:34 -03:00
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
|
|
|
|
// Keystore has 1/2 keys
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(uncompressedKey));
|
2019-06-06 03:53:16 -04:00
|
|
|
|
2019-10-07 15:11:34 -03:00
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
|
|
|
|
// Keystore has 2/2 keys
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(keys[1]));
|
2019-06-06 03:53:16 -04:00
|
|
|
|
2019-10-07 15:11:34 -03:00
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
|
|
|
|
// Keystore has 2/2 keys and the script
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(scriptPubKey));
|
2019-06-06 03:53:16 -04:00
|
|
|
|
2019-10-07 15:11:34 -03:00
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
}
|
|
|
|
|
|
|
|
// P2SH multisig
|
|
|
|
{
|
2020-06-17 12:30:37 -04:00
|
|
|
CWallet keystore(chain.get(), WalletLocation(), CreateDummyWalletDatabase());
|
2019-10-07 15:11:34 -03:00
|
|
|
keystore.SetupLegacyScriptPubKeyMan();
|
2019-10-07 15:11:34 -03:00
|
|
|
LOCK(keystore.GetLegacyScriptPubKeyMan()->cs_KeyStore);
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(uncompressedKey));
|
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(keys[1]));
|
2019-06-06 03:53:16 -04:00
|
|
|
|
|
|
|
CScript redeemScript = GetScriptForMultisig(2, {uncompressedPubkey, pubkeys[1]});
|
|
|
|
scriptPubKey = GetScriptForDestination(ScriptHash(redeemScript));
|
|
|
|
|
|
|
|
// Keystore has no redeemScript
|
2019-10-07 15:11:34 -03:00
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
|
|
|
|
// Keystore has redeemScript
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(redeemScript));
|
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_SPENDABLE);
|
|
|
|
}
|
|
|
|
|
|
|
|
// P2WSH multisig with compressed keys
|
|
|
|
{
|
2020-06-17 12:30:37 -04:00
|
|
|
CWallet keystore(chain.get(), WalletLocation(), CreateDummyWalletDatabase());
|
2019-10-07 15:11:34 -03:00
|
|
|
keystore.SetupLegacyScriptPubKeyMan();
|
2019-10-07 15:11:34 -03:00
|
|
|
LOCK(keystore.GetLegacyScriptPubKeyMan()->cs_KeyStore);
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(keys[0]));
|
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(keys[1]));
|
2019-06-06 03:53:16 -04:00
|
|
|
|
|
|
|
CScript witnessScript = GetScriptForMultisig(2, {pubkeys[0], pubkeys[1]});
|
|
|
|
scriptPubKey = GetScriptForDestination(WitnessV0ScriptHash(witnessScript));
|
|
|
|
|
|
|
|
// Keystore has keys, but no witnessScript or P2SH redeemScript
|
2019-10-07 15:11:34 -03:00
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
|
|
|
|
// Keystore has keys and witnessScript, but no P2SH redeemScript
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(witnessScript));
|
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
|
|
|
|
// Keystore has keys, witnessScript, P2SH redeemScript
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(scriptPubKey));
|
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_SPENDABLE);
|
|
|
|
}
|
|
|
|
|
|
|
|
// P2WSH multisig with uncompressed key
|
|
|
|
{
|
2020-06-17 12:30:37 -04:00
|
|
|
CWallet keystore(chain.get(), WalletLocation(), CreateDummyWalletDatabase());
|
2019-10-07 15:11:34 -03:00
|
|
|
keystore.SetupLegacyScriptPubKeyMan();
|
2019-10-07 15:11:34 -03:00
|
|
|
LOCK(keystore.GetLegacyScriptPubKeyMan()->cs_KeyStore);
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(uncompressedKey));
|
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(keys[1]));
|
2019-06-06 03:53:16 -04:00
|
|
|
|
|
|
|
CScript witnessScript = GetScriptForMultisig(2, {uncompressedPubkey, pubkeys[1]});
|
|
|
|
scriptPubKey = GetScriptForDestination(WitnessV0ScriptHash(witnessScript));
|
|
|
|
|
|
|
|
// Keystore has keys, but no witnessScript or P2SH redeemScript
|
2019-10-07 15:11:34 -03:00
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
|
|
|
|
// Keystore has keys and witnessScript, but no P2SH redeemScript
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(witnessScript));
|
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
|
|
|
|
// Keystore has keys, witnessScript, P2SH redeemScript
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(scriptPubKey));
|
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
}
|
|
|
|
|
|
|
|
// P2WSH multisig wrapped in P2SH
|
|
|
|
{
|
2020-06-17 12:30:37 -04:00
|
|
|
CWallet keystore(chain.get(), WalletLocation(), CreateDummyWalletDatabase());
|
2019-10-07 15:11:34 -03:00
|
|
|
keystore.SetupLegacyScriptPubKeyMan();
|
2019-10-07 15:11:34 -03:00
|
|
|
LOCK(keystore.GetLegacyScriptPubKeyMan()->cs_KeyStore);
|
2019-06-06 03:53:16 -04:00
|
|
|
|
|
|
|
CScript witnessScript = GetScriptForMultisig(2, {pubkeys[0], pubkeys[1]});
|
|
|
|
CScript redeemScript = GetScriptForDestination(WitnessV0ScriptHash(witnessScript));
|
|
|
|
scriptPubKey = GetScriptForDestination(ScriptHash(redeemScript));
|
|
|
|
|
|
|
|
// Keystore has no witnessScript, P2SH redeemScript, or keys
|
2019-10-07 15:11:34 -03:00
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
|
|
|
|
// Keystore has witnessScript and P2SH redeemScript, but no keys
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(redeemScript));
|
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddCScript(witnessScript));
|
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
|
|
|
|
// Keystore has keys, witnessScript, P2SH redeemScript
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(keys[0]));
|
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(keys[1]));
|
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_SPENDABLE);
|
|
|
|
}
|
|
|
|
|
|
|
|
// OP_RETURN
|
|
|
|
{
|
2020-06-17 12:30:37 -04:00
|
|
|
CWallet keystore(chain.get(), WalletLocation(), CreateDummyWalletDatabase());
|
2019-10-07 15:11:34 -03:00
|
|
|
keystore.SetupLegacyScriptPubKeyMan();
|
2019-10-07 15:11:34 -03:00
|
|
|
LOCK(keystore.GetLegacyScriptPubKeyMan()->cs_KeyStore);
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(keys[0]));
|
2019-06-06 03:53:16 -04:00
|
|
|
|
|
|
|
scriptPubKey.clear();
|
|
|
|
scriptPubKey << OP_RETURN << ToByteVector(pubkeys[0]);
|
|
|
|
|
2019-10-07 15:11:34 -03:00
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
}
|
|
|
|
|
|
|
|
// witness unspendable
|
|
|
|
{
|
2020-06-17 12:30:37 -04:00
|
|
|
CWallet keystore(chain.get(), WalletLocation(), CreateDummyWalletDatabase());
|
2019-10-07 15:11:34 -03:00
|
|
|
keystore.SetupLegacyScriptPubKeyMan();
|
2019-10-07 15:11:34 -03:00
|
|
|
LOCK(keystore.GetLegacyScriptPubKeyMan()->cs_KeyStore);
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(keys[0]));
|
2019-06-06 03:53:16 -04:00
|
|
|
|
|
|
|
scriptPubKey.clear();
|
|
|
|
scriptPubKey << OP_0 << ToByteVector(ParseHex("aabb"));
|
|
|
|
|
2019-10-07 15:11:34 -03:00
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
}
|
|
|
|
|
|
|
|
// witness unknown
|
|
|
|
{
|
2020-06-17 12:30:37 -04:00
|
|
|
CWallet keystore(chain.get(), WalletLocation(), CreateDummyWalletDatabase());
|
2019-10-07 15:11:34 -03:00
|
|
|
keystore.SetupLegacyScriptPubKeyMan();
|
2019-10-07 15:11:34 -03:00
|
|
|
LOCK(keystore.GetLegacyScriptPubKeyMan()->cs_KeyStore);
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(keys[0]));
|
2019-06-06 03:53:16 -04:00
|
|
|
|
|
|
|
scriptPubKey.clear();
|
|
|
|
scriptPubKey << OP_16 << ToByteVector(ParseHex("aabb"));
|
|
|
|
|
2019-10-07 15:11:34 -03:00
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Nonstandard
|
|
|
|
{
|
2020-06-17 12:30:37 -04:00
|
|
|
CWallet keystore(chain.get(), WalletLocation(), CreateDummyWalletDatabase());
|
2019-10-07 15:11:34 -03:00
|
|
|
keystore.SetupLegacyScriptPubKeyMan();
|
2019-10-07 15:11:34 -03:00
|
|
|
LOCK(keystore.GetLegacyScriptPubKeyMan()->cs_KeyStore);
|
2019-10-07 15:11:34 -03:00
|
|
|
BOOST_CHECK(keystore.GetLegacyScriptPubKeyMan()->AddKey(keys[0]));
|
2019-06-06 03:53:16 -04:00
|
|
|
|
|
|
|
scriptPubKey.clear();
|
|
|
|
scriptPubKey << OP_9 << OP_ADD << OP_11 << OP_EQUAL;
|
|
|
|
|
2019-10-07 15:11:34 -03:00
|
|
|
result = keystore.GetLegacyScriptPubKeyMan()->IsMine(scriptPubKey);
|
2019-06-06 03:53:16 -04:00
|
|
|
BOOST_CHECK_EQUAL(result, ISMINE_NO);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_SUITE_END()
|