LCOV - code coverage report
Current view: top level - src/test/fuzz - integer.cpp (source / functions) Coverage Total Hit
Test: fuzz_coverage.info Lines: 98.3 % 175 172
Test Date: 2024-12-04 04:00:22 Functions: 100.0 % 3 3
Branches: 54.2 % 260 141

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

Generated by: LCOV version 2.0-1