Branch data Line data Source code
1 : : // Copyright (c) 2012-2021 The Bitcoin Core 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 <compressor.h>
6 : : #include <script/script.h>
7 : : #include <test/util/setup_common.h>
8 : :
9 : : #include <stdint.h>
10 : :
11 : : #include <boost/test/unit_test.hpp>
12 : :
13 : : // amounts 0.00000001 .. 0.00100000
14 : : #define NUM_MULTIPLES_UNIT 100000
15 : :
16 : : // amounts 0.01 .. 100.00
17 : : #define NUM_MULTIPLES_CENT 10000
18 : :
19 : : // amounts 1 .. 10000
20 : : #define NUM_MULTIPLES_1BTC 10000
21 : :
22 : : // amounts 50 .. 21000000
23 : : #define NUM_MULTIPLES_50BTC 420000
24 : :
25 : 0 : BOOST_FIXTURE_TEST_SUITE(compress_tests, BasicTestingSetup)
26 : :
27 : 0 : bool static TestEncode(uint64_t in) {
28 : 0 : return in == DecompressAmount(CompressAmount(in));
29 : : }
30 : :
31 : 0 : bool static TestDecode(uint64_t in) {
32 : 0 : return in == CompressAmount(DecompressAmount(in));
33 : : }
34 : :
35 : 0 : bool static TestPair(uint64_t dec, uint64_t enc) {
36 : 0 : return CompressAmount(dec) == enc &&
37 : 0 : DecompressAmount(enc) == dec;
38 : : }
39 : :
40 : 0 : BOOST_AUTO_TEST_CASE(compress_amounts)
41 : : {
42 : 0 : BOOST_CHECK(TestPair( 0, 0x0));
43 : 0 : BOOST_CHECK(TestPair( 1, 0x1));
44 : 0 : BOOST_CHECK(TestPair( CENT, 0x7));
45 : 0 : BOOST_CHECK(TestPair( COIN, 0x9));
46 : 0 : BOOST_CHECK(TestPair( 50*COIN, 0x32));
47 : 0 : BOOST_CHECK(TestPair(21000000*COIN, 0x1406f40));
48 : :
49 : 0 : for (uint64_t i = 1; i <= NUM_MULTIPLES_UNIT; i++)
50 : 0 : BOOST_CHECK(TestEncode(i));
51 : :
52 : 0 : for (uint64_t i = 1; i <= NUM_MULTIPLES_CENT; i++)
53 : 0 : BOOST_CHECK(TestEncode(i * CENT));
54 : :
55 : 0 : for (uint64_t i = 1; i <= NUM_MULTIPLES_1BTC; i++)
56 : 0 : BOOST_CHECK(TestEncode(i * COIN));
57 : :
58 : 0 : for (uint64_t i = 1; i <= NUM_MULTIPLES_50BTC; i++)
59 : 0 : BOOST_CHECK(TestEncode(i * 50 * COIN));
60 : :
61 : 0 : for (uint64_t i = 0; i < 100000; i++)
62 : 0 : BOOST_CHECK(TestDecode(i));
63 : 0 : }
64 : :
65 : 0 : BOOST_AUTO_TEST_CASE(compress_script_to_ckey_id)
66 : : {
67 : : // case CKeyID
68 : 0 : CKey key;
69 : 0 : key.MakeNewKey(true);
70 : 0 : CPubKey pubkey = key.GetPubKey();
71 : :
72 : 0 : CScript script = CScript() << OP_DUP << OP_HASH160 << ToByteVector(pubkey.GetID()) << OP_EQUALVERIFY << OP_CHECKSIG;
73 : 0 : BOOST_CHECK_EQUAL(script.size(), 25U);
74 : 0 :
75 : 0 : CompressedScript out;
76 : 0 : bool done = CompressScript(script, out);
77 : 0 : BOOST_CHECK_EQUAL(done, true);
78 : :
79 : : // Check compressed script
80 : 0 : BOOST_CHECK_EQUAL(out.size(), 21U);
81 : 0 : BOOST_CHECK_EQUAL(out[0], 0x00);
82 : 0 : BOOST_CHECK_EQUAL(memcmp(out.data() + 1, script.data() + 3, 20), 0); // compare the 20 relevant chars of the CKeyId in the script
83 : 0 : }
84 : :
85 : 0 : BOOST_AUTO_TEST_CASE(compress_script_to_cscript_id)
86 : : {
87 : : // case CScriptID
88 : 0 : CScript script, redeemScript;
89 : 0 : script << OP_HASH160 << ToByteVector(CScriptID(redeemScript)) << OP_EQUAL;
90 : 0 : BOOST_CHECK_EQUAL(script.size(), 23U);
91 : :
92 : 0 : CompressedScript out;
93 : 0 : bool done = CompressScript(script, out);
94 : 0 : BOOST_CHECK_EQUAL(done, true);
95 : :
96 : : // Check compressed script
97 : 0 : BOOST_CHECK_EQUAL(out.size(), 21U);
98 : 0 : BOOST_CHECK_EQUAL(out[0], 0x01);
99 : 0 : BOOST_CHECK_EQUAL(memcmp(out.data() + 1, script.data() + 2, 20), 0); // compare the 20 relevant chars of the CScriptId in the script
100 : 0 : }
101 : :
102 : 0 : BOOST_AUTO_TEST_CASE(compress_script_to_compressed_pubkey_id)
103 : : {
104 : 0 : CKey key;
105 : 0 : key.MakeNewKey(true); // case compressed PubKeyID
106 : :
107 : 0 : CScript script = CScript() << ToByteVector(key.GetPubKey()) << OP_CHECKSIG; // COMPRESSED_PUBLIC_KEY_SIZE (33)
108 : 0 : BOOST_CHECK_EQUAL(script.size(), 35U);
109 : :
110 : 0 : CompressedScript out;
111 : 0 : bool done = CompressScript(script, out);
112 : 0 : BOOST_CHECK_EQUAL(done, true);
113 : :
114 : : // Check compressed script
115 : 0 : BOOST_CHECK_EQUAL(out.size(), 33U);
116 : 0 : BOOST_CHECK_EQUAL(memcmp(out.data(), script.data() + 1, 1), 0);
117 : 0 : BOOST_CHECK_EQUAL(memcmp(out.data() + 1, script.data() + 2, 32), 0); // compare the 32 chars of the compressed CPubKey
118 : 0 : }
119 : :
120 : 0 : BOOST_AUTO_TEST_CASE(compress_script_to_uncompressed_pubkey_id)
121 : : {
122 : 0 : CKey key;
123 : 0 : key.MakeNewKey(false); // case uncompressed PubKeyID
124 : 0 : CScript script = CScript() << ToByteVector(key.GetPubKey()) << OP_CHECKSIG; // PUBLIC_KEY_SIZE (65)
125 : 0 : BOOST_CHECK_EQUAL(script.size(), 67U); // 1 char code + 65 char pubkey + OP_CHECKSIG
126 : :
127 : 0 : CompressedScript out;
128 : 0 : bool done = CompressScript(script, out);
129 : 0 : BOOST_CHECK_EQUAL(done, true);
130 : :
131 : : // Check compressed script
132 : 0 : BOOST_CHECK_EQUAL(out.size(), 33U);
133 : 0 : BOOST_CHECK_EQUAL(memcmp(out.data() + 1, script.data() + 2, 32), 0); // first 32 chars of CPubKey are copied into out[1:]
134 : 0 : BOOST_CHECK_EQUAL(out[0], 0x04 | (script[65] & 0x01)); // least significant bit (lsb) of last char of pubkey is mapped into out[0]
135 : 0 : }
136 : :
137 : 0 : BOOST_AUTO_TEST_SUITE_END()
|