|
19 | 19 | #include <script/sign.h>
|
20 | 20 | #include <script/standard.h>
|
21 | 21 | #include <serialize.h>
|
| 22 | +#include <streams.h> |
22 | 23 | #include <test/fuzz/FuzzedDataProvider.h>
|
23 | 24 | #include <test/fuzz/fuzz.h>
|
24 | 25 | #include <uint256.h>
|
25 | 26 | #include <util/strencodings.h>
|
26 | 27 | #include <util/system.h>
|
27 | 28 | #include <util/time.h>
|
| 29 | +#include <version.h> |
28 | 30 |
|
29 | 31 | #include <cassert>
|
30 | 32 | #include <limits>
|
@@ -54,6 +56,7 @@ void test_one_input(const std::vector<uint8_t>& buffer)
|
54 | 56 | // We cannot assume a specific value of std::is_signed<char>::value:
|
55 | 57 | // ConsumeIntegral<char>() instead of casting from {u,}int8_t.
|
56 | 58 | const char ch = fuzzed_data_provider.ConsumeIntegral<char>();
|
| 59 | + const bool b = fuzzed_data_provider.ConsumeBool(); |
57 | 60 |
|
58 | 61 | const Consensus::Params& consensus_params = Params().GetConsensus();
|
59 | 62 | (void)CheckProofOfWork(u256, u32, consensus_params);
|
@@ -119,4 +122,68 @@ void test_one_input(const std::vector<uint8_t>& buffer)
|
119 | 122 | (void)GetScriptForDestination(destination);
|
120 | 123 | (void)IsValidDestination(destination);
|
121 | 124 | }
|
| 125 | + |
| 126 | + { |
| 127 | + CDataStream stream(SER_NETWORK, INIT_PROTO_VERSION); |
| 128 | + |
| 129 | + uint256 deserialized_u256; |
| 130 | + stream << u256; |
| 131 | + stream >> deserialized_u256; |
| 132 | + assert(u256 == deserialized_u256 && stream.empty()); |
| 133 | + |
| 134 | + uint160 deserialized_u160; |
| 135 | + stream << u160; |
| 136 | + stream >> deserialized_u160; |
| 137 | + assert(u160 == deserialized_u160 && stream.empty()); |
| 138 | + |
| 139 | + uint64_t deserialized_u64; |
| 140 | + stream << u64; |
| 141 | + stream >> deserialized_u64; |
| 142 | + assert(u64 == deserialized_u64 && stream.empty()); |
| 143 | + |
| 144 | + int64_t deserialized_i64; |
| 145 | + stream << i64; |
| 146 | + stream >> deserialized_i64; |
| 147 | + assert(i64 == deserialized_i64 && stream.empty()); |
| 148 | + |
| 149 | + uint32_t deserialized_u32; |
| 150 | + stream << u32; |
| 151 | + stream >> deserialized_u32; |
| 152 | + assert(u32 == deserialized_u32 && stream.empty()); |
| 153 | + |
| 154 | + int32_t deserialized_i32; |
| 155 | + stream << i32; |
| 156 | + stream >> deserialized_i32; |
| 157 | + assert(i32 == deserialized_i32 && stream.empty()); |
| 158 | + |
| 159 | + uint16_t deserialized_u16; |
| 160 | + stream << u16; |
| 161 | + stream >> deserialized_u16; |
| 162 | + assert(u16 == deserialized_u16 && stream.empty()); |
| 163 | + |
| 164 | + int16_t deserialized_i16; |
| 165 | + stream << i16; |
| 166 | + stream >> deserialized_i16; |
| 167 | + assert(i16 == deserialized_i16 && stream.empty()); |
| 168 | + |
| 169 | + uint8_t deserialized_u8; |
| 170 | + stream << u8; |
| 171 | + stream >> deserialized_u8; |
| 172 | + assert(u8 == deserialized_u8 && stream.empty()); |
| 173 | + |
| 174 | + int8_t deserialized_i8; |
| 175 | + stream << i8; |
| 176 | + stream >> deserialized_i8; |
| 177 | + assert(i8 == deserialized_i8 && stream.empty()); |
| 178 | + |
| 179 | + char deserialized_ch; |
| 180 | + stream << ch; |
| 181 | + stream >> deserialized_ch; |
| 182 | + assert(ch == deserialized_ch && stream.empty()); |
| 183 | + |
| 184 | + bool deserialized_b; |
| 185 | + stream << b; |
| 186 | + stream >> deserialized_b; |
| 187 | + assert(b == deserialized_b && stream.empty()); |
| 188 | + } |
122 | 189 | }
|
0 commit comments