LCOV - code coverage report
Current view: top level - src/test/fuzz - integer.cpp (source / functions) Hit Total Coverage
Test: fuzz_coverage.info Lines: 2 165 1.2 %
Date: 2023-09-26 12:08:55 Functions: 3 5 60.0 %

          Line data    Source code
       1             : // Copyright (c) 2019-2022 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 <arith_uint256.h>
       6             : #include <common/args.h>
       7             : #include <common/system.h>
       8             : #include <compressor.h>
       9             : #include <consensus/amount.h>
      10             : #include <consensus/merkle.h>
      11             : #include <core_io.h>
      12             : #include <crypto/common.h>
      13             : #include <crypto/siphash.h>
      14             : #include <key_io.h>
      15             : #include <memusage.h>
      16             : #include <netbase.h>
      17             : #include <policy/policy.h>
      18             : #include <policy/settings.h>
      19             : #include <pow.h>
      20             : #include <protocol.h>
      21             : #include <pubkey.h>
      22             : #include <script/script.h>
      23             : #include <serialize.h>
      24             : #include <streams.h>
      25             : #include <test/fuzz/FuzzedDataProvider.h>
      26             : #include <test/fuzz/fuzz.h>
      27             : #include <test/fuzz/util.h>
      28             : #include <uint256.h>
      29             : #include <univalue.h>
      30             : #include <util/chaintype.h>
      31             : #include <util/check.h>
      32             : #include <util/moneystr.h>
      33             : #include <util/overflow.h>
      34             : #include <util/strencodings.h>
      35             : #include <util/string.h>
      36             : #include <version.h>
      37             : 
      38             : #include <cassert>
      39             : #include <chrono>
      40             : #include <limits>
      41             : #include <set>
      42             : #include <vector>
      43             : 
      44           0 : void initialize_integer()
      45             : {
      46           0 :     SelectParams(ChainType::REGTEST);
      47           0 : }
      48             : 
      49           4 : FUZZ_TARGET(integer, .init = initialize_integer)
      50             : {
      51           0 :     if (buffer.size() < sizeof(uint256) + sizeof(uint160)) {
      52           0 :         return;
      53             :     }
      54           0 :     FuzzedDataProvider fuzzed_data_provider(buffer.data(), buffer.size());
      55           0 :     const uint256 u256(fuzzed_data_provider.ConsumeBytes<unsigned char>(sizeof(uint256)));
      56           0 :     const uint160 u160(fuzzed_data_provider.ConsumeBytes<unsigned char>(sizeof(uint160)));
      57           0 :     const uint64_t u64 = fuzzed_data_provider.ConsumeIntegral<uint64_t>();
      58           0 :     const int64_t i64 = fuzzed_data_provider.ConsumeIntegral<int64_t>();
      59           0 :     const uint32_t u32 = fuzzed_data_provider.ConsumeIntegral<uint32_t>();
      60           0 :     const int32_t i32 = fuzzed_data_provider.ConsumeIntegral<int32_t>();
      61           0 :     const uint16_t u16 = fuzzed_data_provider.ConsumeIntegral<uint16_t>();
      62           0 :     const int16_t i16 = fuzzed_data_provider.ConsumeIntegral<int16_t>();
      63           0 :     const uint8_t u8 = fuzzed_data_provider.ConsumeIntegral<uint8_t>();
      64           0 :     const int8_t i8 = fuzzed_data_provider.ConsumeIntegral<int8_t>();
      65             :     // We cannot assume a specific value of std::is_signed<char>::value:
      66             :     // ConsumeIntegral<char>() instead of casting from {u,}int8_t.
      67           0 :     const char ch = fuzzed_data_provider.ConsumeIntegral<char>();
      68           0 :     const bool b = fuzzed_data_provider.ConsumeBool();
      69             : 
      70           0 :     const Consensus::Params& consensus_params = Params().GetConsensus();
      71           0 :     (void)CheckProofOfWork(u256, u32, consensus_params);
      72           0 :     if (u64 <= MAX_MONEY) {
      73           0 :         const uint64_t compressed_money_amount = CompressAmount(u64);
      74           2 :         assert(u64 == DecompressAmount(compressed_money_amount));
      75           0 :         static const uint64_t compressed_money_amount_max = CompressAmount(MAX_MONEY - 1);
      76           0 :         assert(compressed_money_amount <= compressed_money_amount_max);
      77           0 :     } else {
      78           0 :         (void)CompressAmount(u64);
      79             :     }
      80           0 :     static const uint256 u256_min(uint256S("0000000000000000000000000000000000000000000000000000000000000000"));
      81           0 :     static const uint256 u256_max(uint256S("ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"));
      82           0 :     const std::vector<uint256> v256{u256, u256_min, u256_max};
      83           0 :     (void)ComputeMerkleRoot(v256);
      84           0 :     (void)CountBits(u64);
      85           0 :     (void)DecompressAmount(u64);
      86             :     {
      87           0 :         if (std::optional<CAmount> parsed = ParseMoney(FormatMoney(i64))) {
      88           0 :             assert(parsed.value() == i64);
      89           0 :         }
      90             :     }
      91           0 :     (void)GetSizeOfCompactSize(u64);
      92           0 :     (void)GetSpecialScriptSize(u32);
      93           0 :     if (!MultiplicationOverflow(i64, static_cast<int64_t>(u32)) && !AdditionOverflow(i64, static_cast<int64_t>(4)) && !AdditionOverflow(i64 * u32, static_cast<int64_t>(4))) {
      94           0 :         (void)GetVirtualTransactionSize(i64, i64, u32);
      95           0 :     }
      96           0 :     (void)HexDigit(ch);
      97           0 :     (void)MoneyRange(i64);
      98           0 :     (void)ToString(i64);
      99           0 :     (void)IsDigit(ch);
     100           0 :     (void)IsSpace(ch);
     101           0 :     (void)IsSwitchChar(ch);
     102           0 :     (void)memusage::DynamicUsage(ch);
     103           0 :     (void)memusage::DynamicUsage(i16);
     104           0 :     (void)memusage::DynamicUsage(i32);
     105           0 :     (void)memusage::DynamicUsage(i64);
     106           0 :     (void)memusage::DynamicUsage(i8);
     107           0 :     (void)memusage::DynamicUsage(u16);
     108           0 :     (void)memusage::DynamicUsage(u32);
     109           0 :     (void)memusage::DynamicUsage(u64);
     110           0 :     (void)memusage::DynamicUsage(u8);
     111           0 :     const unsigned char uch = static_cast<unsigned char>(u8);
     112           0 :     (void)memusage::DynamicUsage(uch);
     113             :     {
     114           0 :         const std::set<int64_t> i64s{i64, static_cast<int64_t>(u64)};
     115           0 :         const size_t dynamic_usage = memusage::DynamicUsage(i64s);
     116           0 :         const size_t incremental_dynamic_usage = memusage::IncrementalDynamicUsage(i64s);
     117           0 :         assert(dynamic_usage == incremental_dynamic_usage * i64s.size());
     118           0 :     }
     119           0 :     (void)MillisToTimeval(i64);
     120           0 :     (void)SighashToStr(uch);
     121           0 :     (void)SipHashUint256(u64, u64, u256);
     122           0 :     (void)SipHashUint256Extra(u64, u64, u256, u32);
     123           0 :     (void)ToLower(ch);
     124           0 :     (void)ToUpper(ch);
     125             :     {
     126           0 :         if (std::optional<CAmount> parsed = ParseMoney(ValueFromAmount(i64).getValStr())) {
     127           0 :             assert(parsed.value() == i64);
     128           0 :         }
     129             :     }
     130           0 :     if (i32 >= 0 && i32 <= 16) {
     131           0 :         assert(i32 == CScript::DecodeOP_N(CScript::EncodeOP_N(i32)));
     132           0 :     }
     133             : 
     134           0 :     const std::chrono::seconds seconds{i64};
     135           0 :     assert(count_seconds(seconds) == i64);
     136             : 
     137           0 :     const CScriptNum script_num{i64};
     138           0 :     (void)script_num.getint();
     139           0 :     (void)script_num.getvch();
     140             : 
     141           0 :     const arith_uint256 au256 = UintToArith256(u256);
     142           0 :     assert(ArithToUint256(au256) == u256);
     143           0 :     assert(uint256S(au256.GetHex()) == u256);
     144           0 :     (void)au256.bits();
     145           0 :     (void)au256.GetCompact(/* fNegative= */ false);
     146           0 :     (void)au256.GetCompact(/* fNegative= */ true);
     147           0 :     (void)au256.getdouble();
     148           0 :     (void)au256.GetHex();
     149           0 :     (void)au256.GetLow64();
     150           0 :     (void)au256.size();
     151           0 :     (void)au256.ToString();
     152             : 
     153           0 :     const CKeyID key_id{u160};
     154           0 :     const CScriptID script_id{u160};
     155             : 
     156             :     {
     157           0 :         DataStream stream{};
     158             : 
     159           0 :         uint256 deserialized_u256;
     160           0 :         stream << u256;
     161           0 :         stream >> deserialized_u256;
     162           0 :         assert(u256 == deserialized_u256 && stream.empty());
     163             : 
     164           0 :         uint160 deserialized_u160;
     165           0 :         stream << u160;
     166           0 :         stream >> deserialized_u160;
     167           0 :         assert(u160 == deserialized_u160 && stream.empty());
     168             : 
     169             :         uint64_t deserialized_u64;
     170           0 :         stream << u64;
     171           0 :         stream >> deserialized_u64;
     172           0 :         assert(u64 == deserialized_u64 && stream.empty());
     173             : 
     174             :         int64_t deserialized_i64;
     175           0 :         stream << i64;
     176           0 :         stream >> deserialized_i64;
     177           0 :         assert(i64 == deserialized_i64 && stream.empty());
     178             : 
     179             :         uint32_t deserialized_u32;
     180           0 :         stream << u32;
     181           0 :         stream >> deserialized_u32;
     182           0 :         assert(u32 == deserialized_u32 && stream.empty());
     183             : 
     184             :         int32_t deserialized_i32;
     185           0 :         stream << i32;
     186           0 :         stream >> deserialized_i32;
     187           0 :         assert(i32 == deserialized_i32 && stream.empty());
     188             : 
     189             :         uint16_t deserialized_u16;
     190           0 :         stream << u16;
     191           0 :         stream >> deserialized_u16;
     192           0 :         assert(u16 == deserialized_u16 && stream.empty());
     193             : 
     194             :         int16_t deserialized_i16;
     195           0 :         stream << i16;
     196           0 :         stream >> deserialized_i16;
     197           0 :         assert(i16 == deserialized_i16 && stream.empty());
     198             : 
     199             :         uint8_t deserialized_u8;
     200           0 :         stream << u8;
     201           0 :         stream >> deserialized_u8;
     202           0 :         assert(u8 == deserialized_u8 && stream.empty());
     203             : 
     204             :         int8_t deserialized_i8;
     205           0 :         stream << i8;
     206           0 :         stream >> deserialized_i8;
     207           0 :         assert(i8 == deserialized_i8 && stream.empty());
     208             : 
     209             :         bool deserialized_b;
     210           0 :         stream << b;
     211           0 :         stream >> deserialized_b;
     212           0 :         assert(b == deserialized_b && stream.empty());
     213           0 :     }
     214             : 
     215             :     {
     216           0 :         const ServiceFlags service_flags = (ServiceFlags)u64;
     217           0 :         (void)HasAllDesirableServiceFlags(service_flags);
     218           0 :         (void)MayHaveUsefulAddressDB(service_flags);
     219             :     }
     220             : 
     221             :     {
     222           0 :         DataStream stream{};
     223             : 
     224           0 :         ser_writedata64(stream, u64);
     225           0 :         const uint64_t deserialized_u64 = ser_readdata64(stream);
     226           0 :         assert(u64 == deserialized_u64 && stream.empty());
     227             : 
     228           0 :         ser_writedata32(stream, u32);
     229           0 :         const uint32_t deserialized_u32 = ser_readdata32(stream);
     230           0 :         assert(u32 == deserialized_u32 && stream.empty());
     231             : 
     232           0 :         ser_writedata32be(stream, u32);
     233           0 :         const uint32_t deserialized_u32be = ser_readdata32be(stream);
     234           0 :         assert(u32 == deserialized_u32be && stream.empty());
     235             : 
     236           0 :         ser_writedata16(stream, u16);
     237           0 :         const uint16_t deserialized_u16 = ser_readdata16(stream);
     238           0 :         assert(u16 == deserialized_u16 && stream.empty());
     239             : 
     240           0 :         ser_writedata16be(stream, u16);
     241           0 :         const uint16_t deserialized_u16be = ser_readdata16be(stream);
     242           0 :         assert(u16 == deserialized_u16be && stream.empty());
     243             : 
     244           0 :         ser_writedata8(stream, u8);
     245           0 :         const uint8_t deserialized_u8 = ser_readdata8(stream);
     246           0 :         assert(u8 == deserialized_u8 && stream.empty());
     247           0 :     }
     248             : 
     249             :     {
     250           0 :         DataStream stream{};
     251             : 
     252           0 :         WriteCompactSize(stream, u64);
     253             :         try {
     254           0 :             const uint64_t deserialized_u64 = ReadCompactSize(stream);
     255           0 :             assert(u64 == deserialized_u64 && stream.empty());
     256           0 :         } catch (const std::ios_base::failure&) {
     257           0 :         }
     258           0 :     }
     259             : 
     260             :     try {
     261           0 :         CHECK_NONFATAL(b);
     262           0 :     } catch (const NonFatalCheckError&) {
     263           0 :     }
     264           0 : }

Generated by: LCOV version 1.14