Bitcoin ABC  0.28.12
P2P Digital Currency
proof_tests.cpp
Go to the documentation of this file.
1 // Copyright (c) 2020 The Bitcoin developers
2 // Distributed under the MIT software license, see the accompanying
3 // file COPYING or http://www.opensource.org/licenses/mit-license.php.
4 
5 #include <avalanche/proof.h>
6 
8 #include <avalanche/test/util.h>
9 #include <avalanche/validation.h>
10 #include <coins.h>
11 #include <script/standard.h>
12 #include <util/strencodings.h>
13 #include <util/translation.h>
14 #include <validation.h>
15 
16 #include <test/util/setup_common.h>
17 
18 #include <boost/test/unit_test.hpp>
19 
20 using namespace avalanche;
21 
22 BOOST_FIXTURE_TEST_SUITE(proof_tests, TestChain100Setup)
23 
24 BOOST_AUTO_TEST_CASE(proof_random) {
25  Chainstate &active_chainstate = Assert(m_node.chainman)->ActiveChainstate();
26 
27  for (int i = 0; i < 1000; i++) {
28  const uint32_t score = InsecureRand32();
29  auto p = buildRandomProof(active_chainstate, score);
30  BOOST_CHECK_EQUAL(p->getScore(), score);
31 
32  ProofValidationResult expected_state =
35 
37  const bool ret = p->verify(PROOF_DUST_THRESHOLD, state);
40  BOOST_CHECK(state.GetResult() == expected_state);
41  }
42 }
43 
44 BOOST_AUTO_TEST_CASE(proofbuilder) {
45  // Master key.
46  auto key = CKey::MakeCompressedKey();
47  const CPubKey master = key.GetPubKey();
48 
49  const uint64_t sequence = InsecureRandBits(64);
50  const int64_t expiration = InsecureRandBits(64);
51 
52  ProofBuilder pb(sequence, expiration, key, UNSPENDABLE_ECREG_PAYOUT_SCRIPT);
53 
54  for (int i = 0; i < 3; i++) {
55  key.MakeNewKey(true);
56  BOOST_CHECK(pb.addUTXO(COutPoint(TxId(GetRandHash()), InsecureRand32()),
57  int64_t(InsecureRand32()) * COIN / 100,
58  InsecureRand32(), InsecureRandBool(), key));
59  }
60 
61  ProofRef p = pb.build();
62 
65 
66  BOOST_CHECK_EQUAL(p->getSequence(), sequence);
67  BOOST_CHECK_EQUAL(p->getExpirationTime(), expiration);
68  BOOST_CHECK(p->getMaster() == master);
69 
71 }
72 
73 struct TestVector {
74  std::string name;
75  std::string hex;
77  uint32_t score;
79 };
80 
81 BOOST_AUTO_TEST_CASE(deserialization) {
82  // Proof master key:
83  // privkey L4J6gEE4wL9ji2EQbzS5dPMTTsw8LRvcMst1Utij4e3X5ccUSdqW
84  const std::vector<TestVector> testCases{
85  // Using P2PK payout to
86  // 023beefdde700a6bc02036335b4df141c8bc67bb05a971f5ac2745fd683797dde3
87  {"No utxo staked",
88  "96527eae083f1f24625f049d9e54bb9a21023beefdde700a6bc02036335b4df141c8b"
89  "c67bb05a971f5ac2745fd683797dde3002321023beefdde700a6bc02036335b4df141"
90  "c8bc67bb05a971f5ac2745fd683797dde3ac135da984db510334abe41134e3d4ef09a"
91  "d006b1152be8bc413182bf6f947eac1f8580fe265a382195aa2d73935cabf86d90a8f"
92  "666d0a62385ae24732eca51575",
93  ProofId::fromHex("979dbc3b1351ee12f91f537e04e61fdf93a73d5ebfc317bccd12"
94  "643b8be87b02"),
96  {"1 utxo staked",
97  "a6d66db9fe9378fdd37a0ad2c01c2acd21023beefdde700a6bc02036335b4df141c8b"
98  "c67bb05a971f5ac2745fd683797dde30145a4d07798547464daa53acefb7c97c0c415"
99  "ed8e81e549ff56a0ef6f847fcc9ca855b36200fe38dce5060000e707d7274104fb662"
100  "6e21dbd1cc9feeecdefc9213fdce2b51ac4bb44e1f8dc6f14c2052f5dd7bfaeb2267a"
101  "97ca2bec6e0dd4acf50a66204bde1ebb5d6c551684cff2f939920f7fbb2efd860d6d5"
102  "926bf425eb47b78bf6979cdcd67eb705e2c9a4d45a0930ba25463178a3fb99cb28c8b"
103  "77d8fcf68c54ebfadf08b9a446c251a0088301c50d532321023beefdde700a6bc0203"
104  "6335b4df141c8bc67bb05a971f5ac2745fd683797dde3ac845148594a3067f06bc2cf"
105  "495a1191c00e012dd3d0e4b0c393b3e46c2adcebc3df50f1a203f02e445a0101f4675"
106  "26becb0aa4c64400a10bbde83b3f0290bdeaa",
107  ProofId::fromHex("e01bac293ed39e8d5e06214e7fe0bceb9646ef253ce501dcd7a4"
108  "75f802ab07f1"),
110  {"2 utxo staked",
111  "872379ab64f55b4166ca0e79639999ec21023beefdde700a6bc02036335b4df141c8b"
112  "c67bb05a971f5ac2745fd683797dde302fabf3ad5b875840e7813a66d5ea8a1288a49"
113  "b6222b59fcbe6249f94e5927f9f4b884b0b040a534b3ba040000d045d5d021036830e"
114  "697b0ee89866da798a8945bd85b352545ec1bcace7e04909ea54c134f16d5fe4e972b"
115  "7acd29ebfc2b7b11c26974b84e5f21a45bbe8372472f59e5dfdea7e9e5857c6aebe5d"
116  "bc5e646dfbf4e7cee380afaddb15d06153bf1755b9ef00a616d4c8c3c3a662b5eddc1"
117  "926564a488e3e68e334291078001480f7fa5144ef3a606a41e85c0218dd377090000e"
118  "41099912102ebfcea8e1864c1273c41e0d7c1e9097be5c491bbbf5fe31161d8e5589b"
119  "9d6b5b12f3b963c7fc7614d56d83af907e5cb18ac2f4c3e70a8c4253995f6bc002ec5"
120  "e350491c965cba4dbc11c210979217f1ac3ece7a748f5b2fcf5cced40a5d4c40e2321"
121  "023beefdde700a6bc02036335b4df141c8bc67bb05a971f5ac2745fd683797dde3ace"
122  "a8c988e488eaeef3dc441eb8ede93d2e249ecac3a4277d0347bb1abfdb79b7ebc507e"
123  "5447309db034983b38bd663242834b89026424472e192220863274b266",
124  ProofId::fromHex("ebf52f8d3c845761e55ef145a37537162e5fbbcc87c58a5b0040"
125  "d0a9c89003c4"),
127  {"3 utxo staked",
128  "525e2aa04af0e2457c66ac9e7f66257f21023beefdde700a6bc02036335b4df141c8b"
129  "c67bb05a971f5ac2745fd683797dde3039ce8d3b77938e49ce3bc9824e90b72c65542"
130  "2fb502f137e03a4499e5223d10096fe541eb80316ce3c80800000285f59341044fd7e"
131  "95de7c7bb30e7f60434a3e1a414a9e5d9c383c7b27396b1b84355a32e2996ecb98dc2"
132  "0143089932fa1b905a60fc3cfefeea193c91d1405f7c03de494fa4de065c067d64606"
133  "0e9270281c316d5c4c01d7e43d009151a72bf647794ce1727cbefaeb19719f916cd4d"
134  "d176c376a4da72431b61736d4a3e01c25ba057eac0af8f2988b78d1b75e02281fac56"
135  "2357a06353bf7f214c883e65add05b3a616300cb99cc963c0f4ded8c00e0000b03aab"
136  "f82103172b4f1890594508ab1e0cc5e9728b8a249660da4df724762a8fd888e8ece1b"
137  "d6fe923ed17ad0fd77a90d31e3877de1a8cdb4e95bcf2cdd6fb9768f86789f253b432"
138  "f3b5058b2d1892e90882529055fdedf8ae5d3280b2404a65321cf7f7229202db300ff"
139  "2897e33259a81dfc4bf296c3a156dc8dbfa074c602dd2250cc531b346fc28bb80ddf2"
140  "9ddc020000a713a5bb21035615635d449988a4eea03fd317e44481bde2e34a2489f3f"
141  "b24f0b0ea1cbfc4030bec095a8d3e9c2a233778535dc1fcc07755149b23ea8c17931a"
142  "37e9377eaa2f45bafb8d0bb9ba1700aab88fd6a53ea3e83d95ad2d84e7abe828f5570"
143  "91b185e2321023beefdde700a6bc02036335b4df141c8bc67bb05a971f5ac2745fd68"
144  "3797dde3acf3c32376092a751c432eb727544e6e5caab7e9be1c947ece79995ddc883"
145  "e6e1d48c6865554267cd8f388af277e4fa7a4ad6801f17db36074985ac477e250702"
146  "b",
147  ProofId::fromHex("8542635d83f8020bc781d9e8a3de53c23f5e3f77c21588719b58"
148  "b6618ee1782b"),
150  {"4 utxo staked",
151  "eef33172651f752ac255c85a4e13749921023beefdde700a6bc02036335b4df141c8b"
152  "c67bb05a971f5ac2745fd683797dde304295de5ebf9fbbbb65fc1d9a71587c5284cff"
153  "b2e834addefe090b8200435668c8f02c0b0100689a117e0e000007d801582102a682d"
154  "9d12d53b0eb37a3af2838510f079041905a75f82b6a3fb5558728d781fbf868d1d968"
155  "27b273f5a79f84ebe23add967a98f472fb80323439d0a65d546fc3745806f6d7f3381"
156  "24a7a2573864e97a26246644a7d7b05d97943dfcdb4b694df631e6dc5f87e28c1fe3e"
157  "5ba021f38c471638769041db81ffcf8c9887d078419f97fe2a2c408fee822c0600001"
158  "689b9cd2102e38d0adddcd7c88e3c87b8babcae10647e2862fb719839fc8890e42aeb"
159  "929b85e1a3f14e2cdc65e2b1396f2dae41b047958cdc7e4d2f6fa051065829e26797c"
160  "5b882e45bb9fea32c0b0e0ad90f8ac1e5d8d0b16a9b74d77614b7fd99e56b6091aca3"
161  "67f8f7a68d1b654e51dd00733bd191dc9bea2ba750e063b05d962aaf9c4d2088ce4f0"
162  "03e73e253040000a5eebe222103a20dd85b66b44b22fdd17a93762194c9bedb442c7f"
163  "fd7f08a9f82c42a8c1d9a0443f700cb8a40c8cf7f840b5137b6d019efed961771d095"
164  "88b0eb3c5e1672bb95b06ca7e2068e564001aa75b8c37bb6601117c286b6b0c9728d1"
165  "e928ab02e3b67e9422b484ef2624ce5de974b5bd616874ec39d03d32ed0bf114759b7"
166  "0bf5dcef51534b100515301140f0000950121754104d66dba1569164a134111961133"
167  "4bad5e2d398823f1454ceecb9c4266fd3ba4b969ac4d4f6c4b3975d19c2f7dcbbca09"
168  "6af5395780a2d3c42505146c095bc861fab15238fb8aa1fb82c7ad28b0ee5d1335348"
169  "76dc7887490c7c6e61103b2cd221f1991826a73fecf08e0b5a0a7d357a5431eee032d"
170  "14a348c80ca1833d68b3d7b2321023beefdde700a6bc02036335b4df141c8bc67bb05"
171  "a971f5ac2745fd683797dde3ac157f7621dd2ce427c07dc0da1fc46412edd5c78b10c"
172  "e70e7e6010c65d22de2f434e4f08c158af3c9f5a2411677bd69adbaec068cbb04e79f"
173  "90dbdcb6be2b437f",
174  ProofId::fromHex("6ba2a3ff986d5bc4457da693096bab408cfd8cf4e988e5ac013f"
175  "e48a4e2961c9"),
177  {"Properly signed 1 UTXO proof",
178  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
179  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
180  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102449fb"
181  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce68099f1e258ab"
182  "54f960102c8b480e1dd5795422791bb8a7a19e5542fe8b6a76df7fa09a3fd4be62db7"
183  "50131f1fbea6f7bb978288f7fe941c39ef625aa80576e19fc43410469ab5a892ffa4b"
184  "b104a3d5760dd893a5502512eea4ba32a6d6672767be4959c0f70489b803a47a3abf8"
185  "3f30e8d9da978de4027c70ce7e0d3b0ad62eb08edd8f9ac05a9ea3a5333926249331f"
186  "34a41a3519bab179ce9228dc940019ee80f754da0499379229f9b49f1bccc6566a734"
187  "7227299f775939444505952f920ccea8b9f18",
188  ProofId::fromHex("cdcdd71605139f49d4884b0c3d9a6be309f07b008a760bb3b25f"
189  "cfcb7a3ffc46"),
190  444638638, ProofValidationResult::NONE},
191  {"Duplicated UTXO",
192  "c964aa6fde575e4ce8404581c7be874e21023beefdde700a6bc02036335b4df141c8b"
193  "c67bb05a971f5ac2745fd683797dde302d1e26c2287948bc6ab2b55945c591b8ba3ff"
194  "a237f5d9164d30a4f10145a61f788e639b1480731e2aead30500bf8462872102449fb"
195  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce6806b8111af77"
196  "e1076caba7cb76de29abae963b7f6a1879318e8e37ff488d5843b783215fe9561431a"
197  "c55ecef78ce214869aac0c271d35bee7fdb0858a7ddffe3b0d1e26c2287948bc6ab2b"
198  "55945c591b8ba3ffa237f5d9164d30a4f10145a61f788e639b1480731e2aead30500b"
199  "f8462872102449fb5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8"
200  "bce6802f5c4b2a2ab7fb315d3b9e0318e4e90faa997f28ea6fb31c3487332718079c1"
201  "0131da1acd028a093be651330679bb02bd471053e18a590e373a08c2e60ca15f92321"
202  "038439233261789dd340bdc1450172d9c671b72ee8c0b2736ed2a3a250760897fdac3"
203  "dfb66133d94674a3a6565d8f84e1a31e2f79a4bb399c04adc802abcf8b395f62315d3"
204  "ad8450ba57e11dfb61b1f5a7325094d5ffda1f5830e0990dcc2ebb9be8",
205  ProofId::fromHex("5d4919b43a1afb6acdeddaf1678397eaa10562125db6b911ec4e"
206  "35fd8598ad73"),
208  {"Properly signed 3 UTXO proof",
209  "c964aa6fde575e4ce8404581c7be874e21023beefdde700a6bc02036335b4df141c8b"
210  "c67bb05a971f5ac2745fd683797dde3030b1e5f35704cb63360aa3d5f444ee35eea4c"
211  "154c1af6d4e7595b409ada4b42377764698aaa9da7a9070000000f28db322102449fb"
212  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce680bff436d745"
213  "ad2517f048748d49425db654ad2db24a89cbf91221f3d2e8833cbc63395b0b6f25e54"
214  "3bc4c081e57dd7c29e271d0245230077eddfa991e418a9cceac098c86414715db364a"
215  "4e32216084c561acdd79e0860b1fdf7497b159cb132304512002dcdf1b4c090000009"
216  "f2bc7392102449fb5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8"
217  "bce680cbfabd2e54169fa88efc205505dca2bd65baf893eb38dfa2bc5a691569ed660"
218  "6873d8abc9b68951f8a76db379fb1244d0a1e005d310774f3dbd7863c5f6b060ce4ed"
219  "76e1f19b2c2a0fcc069b4ace4a078cb5cc31e9e19b266d0af41ea8bb0c30c8b47c959"
220  "0627dac060000007dfdd89a2102449fb5237efe8f647d32e8b64f06c22d1d40368eac"
221  "a2a71ffc6a13ecc8bce6800d930fdf810c20955b67deb1b7db92a1e4f835da7b48495"
222  "4ab1c0b982b3821d627a99fc244c9f9556a3b2b2db0098b5c4ef4578de2df3df6b744"
223  "249d456987881976a914f8172c51efbf34413a308a030fd4b164c5bfcd8f88ac87b98"
224  "97ce7b037539f910559fc8ddf69edd509484119f39a344cad40b4b7655438dabf7142"
225  "7a37b92e0e6e29226b6474022ea16be6108ab0f9075f0cd391e746",
226  ProofId::fromHex("526e0e5aef9d857d8c4c15208cc30b5a00818627eebe06098055"
227  "a88d57d461b0"),
229  {"Changing sequence affect ProofId but not the stake signature",
230  "d87587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
231  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
232  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102449fb"
233  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce68099f1e258ab"
234  "54f960102c8b480e1dd5795422791bb8a7a19e5542fe8b6a76df7fa09a3fd4be62db7"
235  "50131f1fbea6f7bb978288f7fe941c39ef625aa80576e19fc43410469ab5a892ffa4b"
236  "b104a3d5760dd893a5502512eea4ba32a6d6672767be4959c0f70489b803a47a3abf8"
237  "3f30e8d9da978de4027c70ce7e0d3b0ad62eb08edd8f9ac80bdeb2ada22b35856fa25"
238  "d2fe7a145b4ce09c6332b72925dbf2b09140d6163863437a8076f7836fcbb7154b831"
239  "65a65910d1b2a8c3655d111f008a57315f5a0",
240  ProofId::fromHex("8b0640e7bf81f487d90d6b5c3ead4bc41eae418da4e6874618b2"
241  "89124e52ba1e"),
242  444638638, ProofValidationResult::NONE},
243  {"Changing expiration affect ProofId",
244  "d97587e6c882615797011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
245  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
246  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102449fb"
247  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce68099f1e258ab"
248  "54f960102c8b480e1dd5795422791bb8a7a19e5542fe8b6a76df7fa09a3fd4be62db7"
249  "50131f1fbea6f7bb978288f7fe941c39ef625aa80576e19fc43410469ab5a892ffa4b"
250  "b104a3d5760dd893a5502512eea4ba32a6d6672767be4959c0f70489b803a47a3abf8"
251  "3f30e8d9da978de4027c70ce7e0d3b0ad62eb08edd8f9ac5995555107107e656abd8e"
252  "2852f311ff0f5c4f606695b63ec44e04303e3378a2e21e16bf05727240ebee1334d2f"
253  "858c6c2e3bdd8d289400b99d7f70b35f9d2fa",
254  ProofId::fromHex("26ce40e7b5dfc8d3d48d743ed23fa6ff32ca269a59c4fb101b3b"
255  "48e5d8450465"),
257  {"Changing the TxId affect the ProofId",
258  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
259  "c67bb05a971f5ac2745fd683797dde30179a79ff23e1d58c64afad42ad81cffe53967"
260  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102449fb"
261  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce68099f1e258ab"
262  "54f960102c8b480e1dd5795422791bb8a7a19e5542fe8b6a76df7fa09a3fd4be62db7"
263  "50131f1fbea6f7bb978288f7fe941c39ef625aa80576e19fc43410469ab5a892ffa4b"
264  "b104a3d5760dd893a5502512eea4ba32a6d6672767be4959c0f70489b803a47a3abf8"
265  "3f30e8d9da978de4027c70ce7e0d3b0ad62eb08edd8f9acaefee33b8b7a0ce4d5d1ab"
266  "92ea8d08dd2538102a4dde790f6317558ceb68e5d2267aac97a0f313dccec827d0401"
267  "a3095b4e862068077ce942380b474c30b64e0",
268  ProofId::fromHex("4b57e163adc5174820ce21eb0e0e9d6565bc00d51bf9f86c58c5"
269  "6947428c2d84"),
271  {"Changing the outpoint index change the ProofId",
272  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
273  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
274  "e16beb692fc5776bb442c79c5d91df00cf21804712806594010038e168a32102449fb"
275  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce68099f1e258ab"
276  "54f960102c8b480e1dd5795422791bb8a7a19e5542fe8b6a76df7fa09a3fd4be62db7"
277  "50131f1fbea6f7bb978288f7fe941c39ef625aa80576e19fc43410469ab5a892ffa4b"
278  "b104a3d5760dd893a5502512eea4ba32a6d6672767be4959c0f70489b803a47a3abf8"
279  "3f30e8d9da978de4027c70ce7e0d3b0ad62eb08edd8f9acecc6e78166848efad9772b"
280  "a11ed0a8b1e9e844cbc2727c69c5e1898430548c9062a52ca9dc1dbe614213d9f7d54"
281  "65dc297d0dc1880adb7daf088f6927a4d6a51",
282  ProofId::fromHex("b569969b77b683904a89c3364c667ac434602936548c80352a85"
283  "ffed4c934cbc"),
285  {"Changing the amount changes the ProofId",
286  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
287  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
288  "e16beb692fc5776bb442c79c5d91de00cf21814712806594010038e168a32102449fb"
289  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce68099f1e258ab"
290  "54f960102c8b480e1dd5795422791bb8a7a19e5542fe8b6a76df7fa09a3fd4be62db7"
291  "50131f1fbea6f7bb978288f7fe941c39ef625aa80576e19fc43410469ab5a892ffa4b"
292  "b104a3d5760dd893a5502512eea4ba32a6d6672767be4959c0f70489b803a47a3abf8"
293  "3f30e8d9da978de4027c70ce7e0d3b0ad62eb08edd8f9acefbdde03c4cc7065075d06"
294  "6c693086c0df0b6b349ec9300ff1333cca65d076364560fb2cbb1365240cdd6c9c323"
295  "d73fc17576da71a5c336a170f76a1b52ffc89",
296  ProofId::fromHex("6989ce300064196c177eae6fd73cf3f89719ddedf068e757eb39"
297  "eb2030baa846"),
299  {"Changing the height changes the ProofId",
300  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
301  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
302  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010028e168a32102449fb"
303  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce68099f1e258ab"
304  "54f960102c8b480e1dd5795422791bb8a7a19e5542fe8b6a76df7fa09a3fd4be62db7"
305  "50131f1fbea6f7bb978288f7fe941c39ef625aa80576e19fc43410469ab5a892ffa4b"
306  "b104a3d5760dd893a5502512eea4ba32a6d6672767be4959c0f70489b803a47a3abf8"
307  "3f30e8d9da978de4027c70ce7e0d3b0ad62eb08edd8f9ac4fc8c51b5a993c0a8f3a53"
308  "c88fb49f228305da66d20b8c73e7e9de55300ac1de52c898fa73e8c5f54a727edc4a6"
309  "76a66dc8bb89bd6c54d41053edceaead6d7b1",
310  ProofId::fromHex("81d217bbfa019439ab6dfbe02b8b703b93eb26e6047a7ee3cc4a"
311  "ba1366286d8d"),
313  {"Changing the pubkey changes the ProofId",
314  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
315  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
316  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102459fb"
317  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce68099f1e258ab"
318  "54f960102c8b480e1dd5795422791bb8a7a19e5542fe8b6a76df7fa09a3fd4be62db7"
319  "50131f1fbea6f7bb978288f7fe941c39ef625aa80576e19fc43410469ab5a892ffa4b"
320  "b104a3d5760dd893a5502512eea4ba32a6d6672767be4959c0f70489b803a47a3abf8"
321  "3f30e8d9da978de4027c70ce7e0d3b0ad62eb08edd8f9ac893ad17cf6a17016f35337"
322  "f6a10f85357689be2760734137c51225cbe0eca4fa00b671f50deacfb86afd61d9cdf"
323  "ae24aa1e9ced62954c4f8eb8114bb4fb852fe",
324  ProofId::fromHex("e33e02f3d608b4a6447c3b3ee283763718716fff02f3a79e3251"
325  "417bd03b9834"),
327  {"Changing the signature does NOT change the ProofId",
328  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
329  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
330  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102449fb"
331  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce68099f1e258ab"
332  "54f960102c8b480e1dd5795422791bb8a7a19e5542fe8b6a76df7fa09a3fd4be62db7"
333  "50131f1fbea6f7bb978288f7fe941c39ef625aa80576e19fd43410469ab5a892ffa4b"
334  "b104a3d5760dd893a5502512eea4ba32a6d6672767be4959c0f70489b803a47a3abf8"
335  "3f30e8d9da978de4027c70ce7e0d3b0ad62eb08edd8f9ac3359ba425e0084157ca510"
336  "e30865693578e3f5eb426d97597ccbd7766db411abaf653aea59c34861cbafeaee076"
337  "8ae58fa2b68a7bfdcdbdc041c50ea59cf1b22",
338  ProofId::fromHex("cdcdd71605139f49d4884b0c3d9a6be309f07b008a760bb3b25f"
339  "cfcb7a3ffc46"),
341  {"1 utxo staked but zero coins",
342  "a6d6852ffa70b172d37a0ad2c01c2acd21023beefdde700a6bc02036335b4df141c8b"
343  "c67bb05a971f5ac2745fd683797dde30145a4d07798547464daa53acefb7c97c0c415"
344  "ed8e81e549ff56a0ef6f847fcc9ca855b3620000000000000000e707d7272102449fb"
345  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce680061c669954"
346  "f964a68b43b1b354b65b651f349a3ff310a1dcb862aa285f26fc7f6fd0b9cb766f1e1"
347  "f90fc63ce03c956b3dac9a4ac2fff963f643ae1326b08d33c2321023beefdde700a6b"
348  "c02036335b4df141c8bc67bb05a971f5ac2745fd683797dde3ac6ad76de70caa0fb07"
349  "12a44e24f791244f733017920ef42c876220a9c50f0239d97414829fe9103741aba28"
350  "7579d8ea26ca28162e3091d53cc51fd58be9b18d22",
351  ProofId::fromHex("c95e3c6417a799dd3085af689ea12fb3d2e1130870fef9f0bdc6"
352  "d10a27df746a"),
354  {"Properly signed 1 UTXO proof, P2PK payout script",
355  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
356  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
357  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102449fb"
358  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce6804534ca1f5e"
359  "22670be3df5cbd5957d8dd83d05c8f17eae391f0e7ffdce4fb3defadb7c079473ebec"
360  "cf88c1f8ce87c61e451447b89c445967335ffd1aadef429982321023beefdde700a6b"
361  "c02036335b4df141c8bc67bb05a971f5ac2745fd683797dde3ac7b0b7865200f63052"
362  "ff980b93f965f398dda04917d411dd46e3c009a5fef35661fac28779b6a22760c0000"
363  "4f5ddf7d9865c7fead7e4a840b947939590261640f",
364  ProofId::fromHex("455f34eb8a00b0799630071c0728481bdb1653035b1484ac33e9"
365  "74aa4ae7db6d"),
366  444638638, ProofValidationResult::NONE},
367  {"Properly signed 1 UTXO proof, P2PKH payout script",
368  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
369  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
370  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102449fb"
371  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce6804848a02e2b"
372  "1c8aa1d21c31b056ab6a63f08e07bb0b56258d1c58b87f3ff472b7b5b9a5907142a04"
373  "041e95e6874ae0874d0f7bbe266f7c4606af315711d0f49341976a914f8172c51efbf"
374  "34413a308a030fd4b164c5bfcd8f88ac2d805b078f5efe022304f8c6ccd0ef5255d80"
375  "6a473fc85a5ad1caf1aa94a4e49ef7625b9dc85d263b2829d5822af62226bc50a4a83"
376  "76a3a6e1cd0a37ea2fbbf9",
377  ProofId::fromHex("8a2fcc5700a89f37a3726cdf3202353bf61f280815a9df744e3c"
378  "9de6215a745a"),
379  444638638, ProofValidationResult::NONE},
380  {"Properly signed 1 UTXO proof, P2SH payout script",
381  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
382  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
383  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102449fb"
384  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce680575db01b67"
385  "5b042bf1ab89aa6ad3842804bb57bf87ebf2bfbcb169debdbf9c51e5d2638eb981bfd"
386  "0e7465a5f3edd152d52b2f6d0108fcd277168be362e849e1f17a914da1745e9b549bd"
387  "0bfa1a569971c77eba30cd5a4b87fea0a245528a4aadfc1dd5731c0cfe738e276c938"
388  "15c69789fe97b15a5fb5b4f75b598ed94096205561e8d16203b8ef21763891d8e79a5"
389  "9862bccbbd5bdf3a58",
390  ProofId::fromHex("c61ee0416eb9549ea0e09dfd2c6062a11aa5d3ab0adcdf59abcc"
391  "02dd0de401fc"),
392  444638638, ProofValidationResult::NONE},
393  {"Properly signed 1 UTXO proof, 1-of-1 multisig payout script",
394  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
395  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
396  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102449fb"
397  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce680ea4c55850f"
398  "587c7839fe254880547049a8be7c27cf511e440fa46237db32dced28e0c10edcf5ddb"
399  "31e2f61e5c749e7324e7edf9aa09547810d64a12fb960a206255121023beefdde700a"
400  "6bc02036335b4df141c8bc67bb05a971f5ac2745fd683797dde351ae29eaecb058c9b"
401  "b74eef68dbeaa5da8b96aacc00bc89c911095ad016cfbdc53b1eeb10a9f29d6c48a5f"
402  "b3a1e6e30d332a05bdc67062f94acffbe6d6c909bb5643",
403  ProofId::fromHex("29deedc94713bbc4d4f88fe96fae6801b91c5ae50601f158fa76"
404  "a036e18ea468"),
405  444638638, ProofValidationResult::NONE},
406  {"Properly signed 1 UTXO proof, 2-of-3 multisig payout script",
407  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
408  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
409  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102449fb"
410  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce680edf24d6c6e"
411  "1ed44a0e0d651d5d2611f80e5c921778c3cbc2923fade878d7d9c69e5f4f7ff0c8dd9"
412  "985ff427011c5cf0cac854c607e1d788d140f8b6d6010aad8695221023beefdde700a"
413  "6bc02036335b4df141c8bc67bb05a971f5ac2745fd683797dde321023beefdde700a6"
414  "bc02036335b4df141c8bc67bb05a971f5ac2745fd683797dde321023beefdde700a6b"
415  "c02036335b4df141c8bc67bb05a971f5ac2745fd683797dde353ae34814734c1bd2c4"
416  "76fdae6fb1145530c3244878f3c2e0c2e5c05da14f17456aedee6beb80f68f42248fd"
417  "89042346be54beaef7da8e549d7d5ff07f9a2cc63c83",
418  ProofId::fromHex("c24dc13d98d0e0a80c19346b9590368557a66f0f65c0088c179d"
419  "89eca25107c8"),
420  444638638, ProofValidationResult::NONE},
421  {"Properly signed 1 UTXO proof, OP_RETURN payout script",
422  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
423  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
424  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102449fb"
425  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce680b746fe5c9d"
426  "10002880169f03c69456f57d60589cd451c2fa078fc0241a022f2c6f1736b4bb49ea0"
427  "d7b878e581de9625f301c68defeda9d506f9b128dbccb08481b6a19492077616e7420"
428  "746f206275726e206d792072657761726473f42ae2e5fa253a700e5dcb3970a894db4"
429  "48b61960b45c84723bf769d4dab0370994d0163e235b688da2fabc8e5b57e24805dce"
430  "3baa62e064c32266a723c6adb6",
431  ProofId::fromHex("bfc250ca1986177acc779f26eaff80aa8916d23cb3e7e0ce6d35"
432  "89c4f5ea364c"),
433  444638638, ProofValidationResult::NONE},
434  {"Invalid payout script (OP_FALSE)",
435  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
436  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
437  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102449fb"
438  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce68082a5aec394"
439  "b2a25fedc70a81f93bb08b46a51bd1259f3f10fa421a4989039d74d30cf449de3b8b4"
440  "6551b8ec927a83d16caaf8fc32636110407cfc9effbaf8c210100b71f0e77b4ad5d73"
441  "d5a872ab43699309b5c194f72be5ee0812236c1a46a5b2c22ddd71d909cf52143f487"
442  "54a61dfe0c6566342fa50b7d62c40fb44d1ff5abed3",
443  ProofId::fromHex("046e75fa2d7f0868dcfa683bbdf657fc6a49b8f8b0d5c2dfdf90"
444  "736ded26b076"),
446  {"Invalid payout script (1-of-5 multisig)",
447  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
448  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
449  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102449fb"
450  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce6804d972714d8"
451  "bcdeb680cd736ee6252c92453d7de362b97007c77abe1d76c80c41b502aa331a94d50"
452  "fb2d709b66a679e2b4b2385dd2f4fad13c85015fc4c6ae7e4ad5121023beefdde700a"
453  "6bc02036335b4df141c8bc67bb05a971f5ac2745fd683797dde321023beefdde700a6"
454  "bc02036335b4df141c8bc67bb05a971f5ac2745fd683797dde321023beefdde700a6b"
455  "c02036335b4df141c8bc67bb05a971f5ac2745fd683797dde321023beefdde700a6bc"
456  "02036335b4df141c8bc67bb05a971f5ac2745fd683797dde321023beefdde700a6bc0"
457  "2036335b4df141c8bc67bb05a971f5ac2745fd683797dde355ae005dfe80b01bc99f9"
458  "3ae1d1c2d7176f7ea54a7f7c76b6eabb1aec5d31de170b0690282f624d01070fb2700"
459  "18694aea6a73ac5b7a96e30ed69df9b7684298b986",
460  ProofId::fromHex("e66b0ab11de5e2f358d2e1f65b1ebe608e4a1f10a9f5d42f1173"
461  "b262e1a218a6"),
463  {"Changing the payout address changes the proof signature (P2PK) but "
464  "not the stake signature",
465  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
466  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
467  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102449fb"
468  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce6804534ca1f5e"
469  "22670be3df5cbd5957d8dd83d05c8f17eae391f0e7ffdce4fb3defadb7c079473ebec"
470  "cf88c1f8ce87c61e451447b89c445967335ffd1aadef429982321023beefdde700a6b"
471  "c02036335b4df141c8bc67bb05a971f5ac2745fd683797dde4ac7b0b7865200f63052"
472  "ff980b93f965f398dda04917d411dd46e3c009a5fef35661fac28779b6a22760c0000"
473  "4f5ddf7d9865c7fead7e4a840b947939590261640f",
474  ProofId::fromHex("ce2812a1decdef0267e0266c68ab53c5ecad292f7b7d0fbd3db9"
475  "285a08ccd2a1"),
477  // The following tests are based on the valid 1 UTXO proof (P2PK script)
478  {"Changing the sequence changes the proof signature",
479  "da7587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
480  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
481  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102449fb"
482  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce6808ef3a5bb64"
483  "dc73a757aba041f348e7bc93c9c96f53a3d48a9a9df6f505f37283834788bad9370e9"
484  "e6e702f8ba5323d38cb3b720adfefee6af4187ee6d9bed2482321023beefdde700a6b"
485  "c02036335b4df141c8bc67bb05a971f5ac2745fd683797dde3ac7b0b7865200f63052"
486  "ff980b93f965f398dda04917d411dd46e3c009a5fef35661fac28779b6a22760c0000"
487  "4f5ddf7d9865c7fead7e4a840b947939590261640f",
488  ProofId::fromHex("37a08e004f35d6410b24a5724b8351b41d4e3ac04f285cd76d73"
489  "a023b2ae5519"),
491  {"Changing the expiration time changes the proof signature",
492  "d97587e6c882615797011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
493  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
494  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102449fb"
495  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce680e475b4323a"
496  "a8775b6b0ab82985f515bd95fb1cc18389d40c7a59a49df1ffa788ae68cfcc21e60c0"
497  "e39806e935ce19b71f1182f4ca83f51d654a95b2e9b021ea12321023beefdde700a6b"
498  "c02036335b4df141c8bc67bb05a971f5ac2745fd683797dde3ac7b0b7865200f63052"
499  "ff980b93f965f398dda04917d411dd46e3c009a5fef35661fac28779b6a22760c0000"
500  "4f5ddf7d9865c7fead7e4a840b947939590261640f",
501  ProofId::fromHex("1312eff53594f63e61f044c36b2cf2d3e7e44c706f17bfabcf49"
502  "954741380bbc"),
504  {"Changing the master pubkey does NOT change the proof signature (but "
505  "signature verification obviously fails)",
506  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
507  "c67bb05a971f5ac2745fd683797dde40169a79ff23e1d58c64afad42ad81cffe53967"
508  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102449fb"
509  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce680306b113bd2"
510  "fc0e5c4f0cc46aed8a6c8efb0b5bcdc214ad78a29e00b1174c67d1c4576f4d815ba74"
511  "ef6bdd0d8243402f6c4c8dcf71a4eb24d97f6d6b1d4a65b912321023beefdde700a6b"
512  "c02036335b4df141c8bc67bb05a971f5ac2745fd683797dde3ac7b0b7865200f63052"
513  "ff980b93f965f398dda04917d411dd46e3c009a5fef35661fac28779b6a22760c0000"
514  "4f5ddf7d9865c7fead7e4a840b947939590261640f",
515  ProofId::fromHex("de837b44ae2df5408f89dc42039ae53a61ea508a15e214e69a50"
516  "d940b72e7713"),
518  {"Changing the TxId changes the proof signature",
519  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
520  "c67bb05a971f5ac2745fd683797dde3016aa79ff23e1d58c64afad42ad81cffe53967"
521  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102449fb"
522  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce680e0d7f1933e"
523  "b1e4f9011b9cf363f198f764ff5d65f471f4e4568beeed834d15f6917378fc9f84a3a"
524  "5c3e445329dbfed556d82ba43e74619e32baad4b3437e2f482321023beefdde700a6b"
525  "c02036335b4df141c8bc67bb05a971f5ac2745fd683797dde3ac7b0b7865200f63052"
526  "ff980b93f965f398dda04917d411dd46e3c009a5fef35661fac28779b6a22760c0000"
527  "4f5ddf7d9865c7fead7e4a840b947939590261640f",
528  ProofId::fromHex("2c90b8359740d675952b570cca76ffb7c1a225984b8c7f47bc27"
529  "607c58a613b5"),
531  {"Changing the outpoint index changes the proof signature",
532  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
533  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
534  "e16beb692fc5776bb442c79c5d91df00cf21804712806594010038e168a32102449fb"
535  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce6803671ac4cd4"
536  "928d9db4be75e0213709e903855369c90f2bd8459ad24ad936a09c550b87d2ab7c7c0"
537  "f1e7b18c484c65aa175e3fc10088b198334d9b2846d7c19272321023beefdde700a6b"
538  "c02036335b4df141c8bc67bb05a971f5ac2745fd683797dde3ac7b0b7865200f63052"
539  "ff980b93f965f398dda04917d411dd46e3c009a5fef35661fac28779b6a22760c0000"
540  "4f5ddf7d9865c7fead7e4a840b947939590261640f",
541  ProofId::fromHex("289c082f835c2edd24b95e1aee7dbb353dff30cdcaab02d5dc2a"
542  "c44c57181468"),
544  {"Changing the amount changes the proof signature",
545  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
546  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
547  "e16beb692fc5776bb442c79c5d91de00cf21814712806594010038e168a32102449fb"
548  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce680c4a8d2cbb3"
549  "ef086b41da91cbf99404c4970fee9cd8dff8c82d4169751e1049fb2506a194e14ef96"
550  "4f308f1afdbb3853df59f58fa88cedcf71722f8130f89e6ef2321023beefdde700a6b"
551  "c02036335b4df141c8bc67bb05a971f5ac2745fd683797dde3ac7b0b7865200f63052"
552  "ff980b93f965f398dda04917d411dd46e3c009a5fef35661fac28779b6a22760c0000"
553  "4f5ddf7d9865c7fead7e4a840b947939590261640f",
554  ProofId::fromHex("8d97d3ed1884462122976da4706778593fc4b5eaafb859bec0b4"
555  "5f590219f5ba"),
557  {"Changing the height changes the proof signature",
558  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
559  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
560  "e16beb692fc5776bb442c79c5d91de00cf2180471280659401003ae168a32102449fb"
561  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce6804fb8adfb4e"
562  "08ad2e6284042968f65dfe365b975492fdac597c75ae91edcb3b0d7ad9352d0cff1b2"
563  "7577eb5fc4646f0106d57d214f71ce21272eb31af09482f2b2321023beefdde700a6b"
564  "c02036335b4df141c8bc67bb05a971f5ac2745fd683797dde3ac7b0b7865200f63052"
565  "ff980b93f965f398dda04917d411dd46e3c009a5fef35661fac28779b6a22760c0000"
566  "4f5ddf7d9865c7fead7e4a840b947939590261640f",
567  ProofId::fromHex("690cb3d74b5add1cfb7d4cf186426d41117586c57d59da330cc9"
568  "50e2d18d613c"),
570  {"Changing the coinbase flag changes the proof signature",
571  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
572  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
573  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010039e168a32102449fb"
574  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce6807b0eeab05c"
575  "31d69c288fab140311274530dea518a7b62846c33e6a087b489210fed85b8a18017d4"
576  "30751e81e276aecdb565a3cd5c58b5a0f81cbf5af33196dfd2321023beefdde700a6b"
577  "c02036335b4df141c8bc67bb05a971f5ac2745fd683797dde3ac7b0b7865200f63052"
578  "ff980b93f965f398dda04917d411dd46e3c009a5fef35661fac28779b6a22760c0000"
579  "4f5ddf7d9865c7fead7e4a840b947939590261640f",
580  ProofId::fromHex("f713dec5d2f798360748914face171d5a45706b9c5f0bc4d561f"
581  "6e80e098beef"),
583  {"Changing the stake pubkey changes the proof signature",
584  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
585  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
586  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102449fb"
587  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce6814534ca1f5e"
588  "22670be3df5cbd5957d8dd83d05c8f17eae391f0e7ffdce4fb3defadb7c079473ebec"
589  "cf88c1f8ce87c61e451447b89c445967335ffd1aadef429982321023beefdde700a6b"
590  "c02036335b4df141c8bc67bb05a971f5ac2745fd683797dde3ac7b0b7865200f63052"
591  "ff980b93f965f398dda04917d411dd46e3c009a5fef35661fac28779b6a22760c0000"
592  "4f5ddf7d9865c7fead7e4a840b947939590261640f",
593  ProofId::fromHex("df84548b3a085e29d58ba5e83ad2fd1c9ecbe8595d4240f3f588"
594  "e52af84cc65b"),
596  {"Changing the stake signature does NOT change the proof signature",
597  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
598  "c67bb05a971f5ac2745fd683797dde30169a79ff23e1d58c64afad42ad81cffe53967"
599  "e16beb692fc5776bb442c79c5d91de00cf21804712806594010038e168a32102449fb"
600  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce6804534ca1f5e"
601  "22670be3df5cbd5957d8dd83d05c8f17eae391f0e7ffdce4fb3defadb7c079473ebec"
602  "cf88c1f8ce87c61e451447b89c445967335ffd1aadef429992321023beefdde700a6b"
603  "c02036335b4df141c8bc67bb05a971f5ac2745fd683797dde3ac7b0b7865200f63052"
604  "ff980b93f965f398dda04917d411dd46e3c009a5fef35661fac28779b6a22760c0000"
605  "4f5ddf7d9865c7fead7e4a840b947939590261640f",
606  ProofId::fromHex("455f34eb8a00b0799630071c0728481bdb1653035b1484ac33e9"
607  "74aa4ae7db6d"),
609  {"Adding a stake changes the proof signature but does not involve "
610  "changing the previous stake signature",
611  "d97587e6c882615796011ec8f9a7b1c621023beefdde700a6bc02036335b4df141c8b"
612  "c67bb05a971f5ac2745fd683797dde3026aa79ff23e1d58c64afad42ad81cffe53967"
613  "e16beb692fc5776bb442c79c5d91df00cf2180471280659401003be168a32102449fb"
614  "5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8bce680f2adfb4bcb"
615  "14bf1f6aa38a44994419bd34e9da07d972d3f092cd3ef037fe7bcd92e3d7073faa7e6"
616  "e0697b9fab8670417959ab0b0958fdc576a11dffe599e851269a79ff23e1d58c64afa"
617  "d42ad81cffe53967e16beb692fc5776bb442c79c5d91de00cf2180471280659401003"
618  "8e168a32102449fb5237efe8f647d32e8b64f06c22d1d40368eaca2a71ffc6a13ecc8"
619  "bce6804534ca1f5e22670be3df5cbd5957d8dd83d05c8f17eae391f0e7ffdce4fb3de"
620  "fadb7c079473ebeccf88c1f8ce87c61e451447b89c445967335ffd1aadef429982321"
621  "023beefdde700a6bc02036335b4df141c8bc67bb05a971f5ac2745fd683797dde3ac9"
622  "32ce54c4d405de52399cf48b4b10038d1bbbd65206f0934b2bdfc7b6a4a2e1cff1803"
623  "a69bd03dd3897d4cfde46c2ee2cf17895880770c8b49089a26b6b5ff1e",
624  ProofId::fromHex("96bd9fee759d81f9bc30e26015d979df3f6046c7a8764582d1a2"
625  "c5c3d61c2f44"),
626  2 * 444638638, ProofValidationResult::NONE},
627  };
628 
629  for (const auto &c : testCases) {
630  Proof p;
632  BOOST_CHECK(Proof::FromHex(p, c.hex, error));
633  BOOST_CHECK_EQUAL(p.getId(), c.proofid);
634  BOOST_CHECK_EQUAL(p.getScore(), c.score);
635 
636  ProofValidationState state;
638  c.result == ProofValidationResult::NONE);
639  BOOST_CHECK(state.GetResult() == c.result);
640  BOOST_TEST_MESSAGE(c.proofid);
641  }
642 }
643 
645  gArgs.ForceSetArg("-avaproofstakeutxoconfirmations", "1");
646 
647  auto key = CKey::MakeCompressedKey();
648  const CPubKey pubkey = key.GetPubKey();
649 
650  const Amount value = 2 * PROOF_DUST_THRESHOLD;
651  const uint32_t height = 10;
652 
653  ChainstateManager &chainman = *Assert(m_node.chainman);
654  LOCK(cs_main);
655  CCoinsViewCache &coins = chainman.ActiveChainstate().CoinsTip();
656 
657  COutPoint pkh_outpoint(TxId(InsecureRand256()), InsecureRand32());
658  CTxOut pkh_output(value, GetScriptForRawPubKey(pubkey));
659  coins.AddCoin(pkh_outpoint, Coin(pkh_output, height, false), false);
660 
661  COutPoint nonstd_outpoint(TxId(InsecureRand256()), InsecureRand32());
662  CTxOut nonstd_output(value, CScript() << OP_TRUE);
663  coins.AddCoin(nonstd_outpoint, Coin(nonstd_output, height, false), false);
664 
665  COutPoint p2sh_outpoint(TxId(InsecureRand256()), InsecureRand32());
666  CTxOut p2sh_output(value,
667  GetScriptForDestination(ScriptHash(InsecureRand160())));
668  coins.AddCoin(p2sh_outpoint, Coin(p2sh_output, height, false), false);
669 
670  const auto runCheck = [&](const ProofValidationResult result,
671  const COutPoint &o, const Amount v,
672  const uint32_t h, const bool is_coinbase,
673  const CKey &k, int64_t expirationTime = 0) {
674  // Generate a proof that match the UTXO.
675  ProofBuilder pb(0, expirationTime, key,
677  BOOST_CHECK(pb.addUTXO(o, v, h, is_coinbase, k));
678  ProofRef p = pb.build();
679 
680  ProofValidationState state;
682  LOCK(cs_main);
683  BOOST_CHECK(p->verify(PROOF_DUST_THRESHOLD, chainman, state) ==
684  (result == ProofValidationResult::NONE));
685  BOOST_CHECK(state.GetResult() == result);
686  };
687 
688  const int64_t currentTipMTP = chainman.ActiveTip()->GetMedianTimePast();
689 
690  // Valid proof
691  runCheck(ProofValidationResult::NONE, pkh_outpoint, value, height, false,
692  key);
693 
694  // Expiration checks
695 
696  // Negative or zero expiration times means no expiration
697  runCheck(ProofValidationResult::NONE, pkh_outpoint, value, height, false,
698  key, -1);
699  runCheck(ProofValidationResult::NONE, pkh_outpoint, value, height, false,
700  key, 0);
701  runCheck(ProofValidationResult::NONE, pkh_outpoint, value, height, false,
702  key, std::numeric_limits<int64_t>::min());
703 
704  // The future
705  runCheck(ProofValidationResult::NONE, pkh_outpoint, value, height, false,
706  key, std::numeric_limits<int64_t>::max());
707  runCheck(ProofValidationResult::NONE, pkh_outpoint, value, height, false,
708  key, currentTipMTP + 1);
709 
710  // Expired proofs
711  runCheck(ProofValidationResult::EXPIRED, pkh_outpoint, value, height, false,
712  key, 1);
713  runCheck(ProofValidationResult::EXPIRED, pkh_outpoint, value, height, false,
714  key, currentTipMTP - 1);
715  runCheck(ProofValidationResult::EXPIRED, pkh_outpoint, value, height, false,
716  key, currentTipMTP);
717 
718  // Coinbase mismatch
719  runCheck(ProofValidationResult::COINBASE_MISMATCH, pkh_outpoint, value,
720  height, true, key);
721 
722  // Height mismatch
723  runCheck(ProofValidationResult::HEIGHT_MISMATCH, pkh_outpoint, value,
724  height + 1, false, key);
725 
726  // Amount mismatch
727  runCheck(ProofValidationResult::AMOUNT_MISMATCH, pkh_outpoint,
728  value + 1 * SATOSHI, height, false, key);
729 
730  // Invalid outpoints
732  COutPoint(pkh_outpoint.GetTxId(), pkh_outpoint.GetN() + 1), value,
733  height, false, key);
735  COutPoint(TxId(InsecureRand256()), pkh_outpoint.GetN()), value,
736  height, false, key);
737 
738  // Non standard script
739  runCheck(ProofValidationResult::NON_STANDARD_DESTINATION, nonstd_outpoint,
740  value, height, false, key);
741 
742  // Non PKHhash destination
743  runCheck(ProofValidationResult::DESTINATION_NOT_SUPPORTED, p2sh_outpoint,
744  value, height, false, key);
745 
746  // Mismatching key
747  {
748  runCheck(ProofValidationResult::DESTINATION_MISMATCH, pkh_outpoint,
749  value, height, false, CKey::MakeCompressedKey());
750  }
751 
752  // No stake
753  {
754  ProofRef p =
756 
757  ProofValidationState state;
758  BOOST_CHECK(!p->verify(PROOF_DUST_THRESHOLD, chainman, state));
760  }
761 
762  // Dust thresold
763  {
764  // tuple<utxo value, dust threshold, result>
765  const std::vector<std::tuple<Amount, Amount, ProofValidationResult>>
766  testCases = {
767  // Defaults
773  // Modified threshold
775  {value - 1 * SATOSHI, value,
777  {value, value, ProofValidationResult::NONE},
778  };
779 
780  for (const auto &[utxoValue, dustThreshold, expectedResult] :
781  testCases) {
783  BOOST_CHECK(
784  pb.addUTXO(pkh_outpoint, utxoValue, height, false, key));
785  ProofRef p = pb.build();
786 
787  ProofValidationState state;
788  BOOST_CHECK(p->verify(dustThreshold, chainman, state) ==
789  (expectedResult == ProofValidationResult::NONE));
790  BOOST_CHECK(state.GetResult() == expectedResult);
791  }
792  }
793 
794  // Duplicated input
795  {
797  BOOST_CHECK(pb.addUTXO(pkh_outpoint, value, height, false, key));
799 
800  ProofValidationState state;
801  BOOST_CHECK(!p->verify(PROOF_DUST_THRESHOLD, chainman, state));
802  BOOST_CHECK(state.GetResult() ==
804  }
805 
806  // Wrong stake ordering
807  {
808  COutPoint other_pkh_outpoint(TxId(InsecureRand256()), InsecureRand32());
809  CTxOut other_pkh_output(value, GetScriptForRawPubKey(pubkey));
810  coins.AddCoin(other_pkh_outpoint, Coin(other_pkh_output, height, false),
811  false);
812 
814  BOOST_CHECK(pb.addUTXO(pkh_outpoint, value, height, false, key));
815  BOOST_CHECK(pb.addUTXO(other_pkh_outpoint, value, height, false, key));
817 
818  ProofValidationState state;
819  BOOST_CHECK(!p->verify(PROOF_DUST_THRESHOLD, chainman, state));
820  BOOST_CHECK(state.GetResult() ==
822  }
823 
824  // Immature stake
825  {
826  uint32_t chaintipHeight = chainman.ActiveHeight();
827 
828  // A proof where the UTXO is both missing and immature gives
829  // MISSING_UTXO
830  {
831  gArgs.ForceSetArg("-avaproofstakeutxoconfirmations", "11");
832  for (auto h = chaintipHeight; h > chaintipHeight - 10; h--) {
833  COutPoint outpoint(TxId(InsecureRand256()), InsecureRand32());
834  CTxOut output(value, GetScriptForRawPubKey(pubkey));
835  runCheck(ProofValidationResult::MISSING_UTXO, outpoint, value,
836  h, false, key);
837 
838  // Add the coin to the UTXO set to verify it's immature
839  coins.AddCoin(outpoint, Coin(output, h, false), false);
840  runCheck(ProofValidationResult::IMMATURE_UTXO, outpoint, value,
841  h, false, key);
842  }
843  }
844 
845  // tuple<stake utxo confs, avaproofstakeutxoconfirmations, result>
846  const std::vector<
847  std::tuple<uint32_t, std::string, ProofValidationResult>>
848  testCases = {
849  // Require less or equal the number of confirmations the stake
850  // has
851  {chaintipHeight, "1", ProofValidationResult::NONE},
852  {50, "1", ProofValidationResult::NONE},
853  {50, "50", ProofValidationResult::NONE},
854  {50, "51", ProofValidationResult::NONE},
855  // Require more than the number of confirmations the stake has
856  {chaintipHeight, "2", ProofValidationResult::IMMATURE_UTXO},
859  };
860 
861  for (const auto &[stakeConfs, configuredStakeConfs, expectedResult] :
862  testCases) {
863  COutPoint outpoint(TxId(InsecureRand256()), InsecureRand32());
864  CTxOut output(value, GetScriptForRawPubKey(pubkey));
865  coins.AddCoin(outpoint, Coin(output, stakeConfs, false), false);
866 
867  gArgs.ForceSetArg("-avaproofstakeutxoconfirmations",
868  configuredStakeConfs);
869  runCheck(expectedResult, outpoint, value, stakeConfs, false, key);
870  }
871  gArgs.ClearForcedArg("-avaproofstakeutxoconfirmations");
872  }
873 }
874 
875 BOOST_AUTO_TEST_CASE(deterministic_proofid) {
876  auto key = CKey::MakeCompressedKey();
877 
878  const Amount value = 12345 * COIN;
879  const uint32_t height = 10;
880 
881  std::vector<COutPoint> outpoints(10);
882  for (size_t i = 0; i < 10; i++) {
883  outpoints[i] = COutPoint(TxId(InsecureRand256()), InsecureRand32());
884  }
885 
886  auto computeProofId = [&]() {
888  for (const COutPoint &outpoint : outpoints) {
889  BOOST_CHECK(pb.addUTXO(outpoint, value, height, false, key));
890  }
891  ProofRef p = pb.build();
892 
893  return p->getId();
894  };
895 
896  const ProofId proofid = computeProofId();
897  Shuffle(outpoints.begin(), outpoints.end(), FastRandomContext());
898  BOOST_CHECK_EQUAL(proofid, computeProofId());
899 }
900 
901 BOOST_AUTO_TEST_CASE(get_staked_amount) {
902  auto key = CKey::MakeCompressedKey();
904 
905  {
906  ProofRef p = pb.build();
908  }
909 
910  for (int i = 1; i <= 10; i++) {
911  BOOST_CHECK(pb.addUTXO(COutPoint(TxId(GetRandHash()), 0), i * COIN, 42,
912  false, key));
913  }
914 
915  {
916  ProofRef p = pb.build();
918  }
919 }
920 
static constexpr Amount SATOSHI
Definition: amount.h:143
static constexpr Amount COIN
Definition: amount.h:144
#define Assert(val)
Identity function.
Definition: check.h:84
void ForceSetArg(const std::string &strArg, const std::string &strValue)
Definition: system.cpp:706
void ClearForcedArg(const std::string &strArg)
Remove a forced arg setting, used only in testing.
Definition: system.cpp:757
int64_t GetMedianTimePast() const
Definition: blockindex.h:190
CCoinsView that adds a memory cache for transactions to another CCoinsView.
Definition: coins.h:203
void AddCoin(const COutPoint &outpoint, Coin coin, bool possible_overwrite)
Add a coin.
Definition: coins.cpp:100
An encapsulated secp256k1 private key.
Definition: key.h:28
static CKey MakeCompressedKey()
Produce a valid compressed key.
Definition: key.cpp:466
An outpoint - a combination of a transaction hash and an index n into its vout.
Definition: transaction.h:20
uint32_t GetN() const
Definition: transaction.h:36
const TxId & GetTxId() const
Definition: transaction.h:35
An encapsulated public key.
Definition: pubkey.h:31
Serialized script, used inside transaction inputs and outputs.
Definition: script.h:431
An output of a transaction.
Definition: transaction.h:128
Chainstate stores and provides an API to update our local knowledge of the current best chain.
Definition: validation.h:648
Provides an interface for creating and interacting with one or two chainstates: an IBD chainstate gen...
Definition: validation.h:1157
int ActiveHeight() const EXCLUSIVE_LOCKS_REQUIRED(GetMutex())
Definition: validation.h:1359
CBlockIndex * ActiveTip() const EXCLUSIVE_LOCKS_REQUIRED(GetMutex())
Definition: validation.h:1362
A UTXO entry.
Definition: coins.h:27
Fast randomness source.
Definition: random.h:156
Result GetResult() const
Definition: validation.h:115
bool addUTXO(COutPoint utxo, Amount amount, uint32_t height, bool is_coinbase, CKey key)
int64_t getExpirationTime() const
Definition: proof.h:163
static bool FromHex(Proof &proof, const std::string &hexProof, bilingual_str &errorOut)
Definition: proof.cpp:51
const ProofId & getId() const
Definition: proof.h:169
bool verify(const Amount &stakeUtxoDustThreshold, ProofValidationState &state) const
Definition: proof.cpp:119
Amount getStakedAmount() const
Definition: proof.cpp:104
uint64_t getSequence() const
Definition: proof.h:162
const CPubKey & getMaster() const
Definition: proof.h:164
uint32_t getScore() const
Definition: proof.h:174
RecursiveMutex cs_main
Mutex to guard access to validation specific variables, such as reading or changing the chainstate.
Definition: cs_main.cpp:7
static constexpr Amount PROOF_DUST_THRESHOLD
Minimum amount per utxo.
Definition: proof.h:40
ProofValidationResult
Definition: validation.h:12
const CScript UNSPENDABLE_ECREG_PAYOUT_SCRIPT
Definition: util.h:19
ProofRef buildRandomProof(Chainstate &active_chainstate, uint32_t score, int height, const CKey &masterKey)
Definition: util.cpp:20
bool hasDustStake(const ProofRef &proof)
Definition: util.cpp:42
NodeContext & m_node
Definition: interfaces.cpp:778
#define BOOST_AUTO_TEST_SUITE_END()
Definition: object.cpp:16
#define BOOST_CHECK_EQUAL(v1, v2)
Definition: object.cpp:18
#define BOOST_CHECK(expr)
Definition: object.cpp:17
BOOST_AUTO_TEST_CASE(proof_random)
Definition: proof_tests.cpp:24
uint256 GetRandHash() noexcept
Definition: random.cpp:659
void Shuffle(I first, I last, R &&rng)
More efficient than using std::shuffle on a FastRandomContext.
Definition: random.h:291
const char * name
Definition: rest.cpp:48
@ OP_TRUE
Definition: script.h:57
BOOST_FIXTURE_TEST_SUITE(stakingrewards_tests, StakingRewardsActivationTestingSetup) BOOST_AUTO_TEST_CASE(isstakingrewardsactivated)
CScript GetScriptForRawPubKey(const CPubKey &pubKey)
Generate a P2PK script for the given pubkey.
Definition: standard.cpp:244
CScript GetScriptForDestination(const CTxDestination &dest)
Generate a Bitcoin scriptPubKey for the given CTxDestination.
Definition: standard.cpp:240
Definition: amount.h:19
static constexpr Amount zero() noexcept
Definition: amount.h:32
ProofId proofid
Definition: proof_tests.cpp:76
ProofValidationResult result
Definition: proof_tests.cpp:78
uint32_t score
Definition: proof_tests.cpp:77
A TxId is the identifier of a transaction.
Definition: txid.h:14
static ProofId fromHex(const std::string &str)
Definition: proofid.h:21
static ProofRef buildWithReversedOrderStakes(ProofBuilder &pb)
Definition: util.cpp:66
static ProofRef buildDuplicatedStakes(ProofBuilder &pb)
Definition: util.cpp:107
Bilingual messages:
Definition: translation.h:17
#define LOCK(cs)
Definition: sync.h:306
ArgsManager gArgs
Definition: system.cpp:80
bool error(const char *fmt, const Args &...args)
Definition: system.h:45