aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPieter Wuille <pieter.wuille@gmail.com>2018-06-17 17:39:42 -0700
committerPieter Wuille <pieter.wuille@gmail.com>2018-06-17 17:39:42 -0700
commiteaba1c111e9671cdd6faf4b96c39341bbdd41632 (patch)
tree712348e41ec927ac421f872d33052373f3b7f56d
parente6b9730c49da6a0219453dec8f4df351292e6e07 (diff)
Add additional unit tests for invalid IsMine combinations
-rw-r--r--src/test/script_standard_tests.cpp82
1 files changed, 82 insertions, 0 deletions
diff --git a/src/test/script_standard_tests.cpp b/src/test/script_standard_tests.cpp
index ec4eb34b8a..f319ea831a 100644
--- a/src/test/script_standard_tests.cpp
+++ b/src/test/script_standard_tests.cpp
@@ -488,6 +488,88 @@ BOOST_AUTO_TEST_CASE(script_standard_IsMine)
BOOST_CHECK_EQUAL(result, ISMINE_SPENDABLE);
}
+ // (P2PKH inside) P2SH inside P2SH (invalid)
+ {
+ CBasicKeyStore keystore;
+
+ CScript redeemscript, redeemscript_inner;
+ redeemscript_inner << OP_DUP << OP_HASH160 << ToByteVector(pubkeys[0].GetID()) << OP_EQUALVERIFY << OP_CHECKSIG;
+ redeemscript << OP_HASH160 << ToByteVector(CScriptID(redeemscript_inner)) << OP_EQUAL;
+
+ scriptPubKey.clear();
+ scriptPubKey << OP_HASH160 << ToByteVector(CScriptID(redeemscript)) << OP_EQUAL;
+
+ keystore.AddCScript(redeemscript);
+ keystore.AddCScript(redeemscript_inner);
+ keystore.AddCScript(scriptPubKey);
+ keystore.AddKey(keys[0]);
+ result = IsMine(keystore, scriptPubKey);
+ BOOST_CHECK_EQUAL(result, ISMINE_NO);
+ }
+
+ // (P2PKH inside) P2SH inside P2WSH (invalid)
+ {
+ CBasicKeyStore keystore;
+
+ CScript witnessscript, redeemscript;
+ redeemscript << OP_DUP << OP_HASH160 << ToByteVector(pubkeys[0].GetID()) << OP_EQUALVERIFY << OP_CHECKSIG;
+ witnessscript << OP_HASH160 << ToByteVector(CScriptID(redeemscript)) << OP_EQUAL;
+
+ uint256 scripthash;
+ CSHA256().Write(witnessscript.data(), witnessscript.size()).Finalize(scripthash.begin());
+ scriptPubKey.clear();
+ scriptPubKey << OP_0 << ToByteVector(scripthash);
+
+ keystore.AddCScript(witnessscript);
+ keystore.AddCScript(redeemscript);
+ keystore.AddCScript(scriptPubKey);
+ keystore.AddKey(keys[0]);
+ result = IsMine(keystore, scriptPubKey);
+ BOOST_CHECK_EQUAL(result, ISMINE_NO);
+ }
+
+ // P2WPKH inside P2WSH (invalid)
+ {
+ CBasicKeyStore keystore;
+
+ CScript witnessscript;
+ witnessscript << OP_0 << ToByteVector(pubkeys[0].GetID());
+
+ scriptPubKey.clear();
+ uint256 scripthash;
+ CSHA256().Write(witnessscript.data(), witnessscript.size()).Finalize(scripthash.begin());
+ scriptPubKey << OP_0 << ToByteVector(scripthash);
+
+ keystore.AddCScript(witnessscript);
+ keystore.AddCScript(scriptPubKey);
+ keystore.AddKey(keys[0]);
+ result = IsMine(keystore, scriptPubKey);
+ BOOST_CHECK_EQUAL(result, ISMINE_NO);
+ }
+
+ // (P2PKH inside) P2WSH inside P2WSH (invalid)
+ {
+ CBasicKeyStore keystore;
+
+ CScript witnessscript_inner;
+ witnessscript_inner << OP_DUP << OP_HASH160 << ToByteVector(pubkeys[0].GetID()) << OP_EQUALVERIFY << OP_CHECKSIG;
+ uint256 scripthash;
+ CSHA256().Write(witnessscript_inner.data(), witnessscript_inner.size()).Finalize(scripthash.begin());
+ CScript witnessscript;
+ witnessscript << OP_0 << ToByteVector(scripthash);
+
+ scriptPubKey.clear();
+ CSHA256().Write(witnessscript.data(), witnessscript.size()).Finalize(scripthash.begin());
+ scriptPubKey << OP_0 << ToByteVector(scripthash);
+
+ keystore.AddCScript(witnessscript_inner);
+ keystore.AddCScript(witnessscript);
+ keystore.AddCScript(scriptPubKey);
+ keystore.AddKey(keys[0]);
+ result = IsMine(keystore, scriptPubKey);
+ BOOST_CHECK_EQUAL(result, ISMINE_NO);
+ }
+
// P2WPKH compressed
{
CBasicKeyStore keystore;