19 return fuzzed_data_provider.ConsumeIntegralInRange<
CAmount>(0, max.value_or(
MAX_MONEY));
25 static const int64_t time_min{946684801};
26 static const int64_t time_max{4133980799};
27 return fuzzed_data_provider.ConsumeIntegralInRange<int64_t>(min.value_or(time_min), max.value_or(time_max));
33 const auto p2wsh_op_true = fuzzed_data_provider.ConsumeBool();
34 tx_mut.
nVersion = fuzzed_data_provider.ConsumeBool() ?
36 fuzzed_data_provider.ConsumeIntegral<int32_t>();
37 tx_mut.
nLockTime = fuzzed_data_provider.ConsumeIntegral<uint32_t>();
38 const auto num_in = fuzzed_data_provider.ConsumeIntegralInRange<
int>(0, max_num_in);
39 const auto num_out = fuzzed_data_provider.ConsumeIntegralInRange<
int>(0, max_num_out);
40 for (
int i = 0; i < num_in; ++i) {
41 const auto& txid_prev = prevout_txids ?
42 PickValue(fuzzed_data_provider, *prevout_txids) :
44 const auto index_out = fuzzed_data_provider.ConsumeIntegralInRange<uint32_t>(0, max_num_out);
59 tx_mut.
vin.push_back(in);
61 for (
int i = 0; i < num_out; ++i) {
62 const auto amount = fuzzed_data_provider.ConsumeIntegralInRange<
CAmount>(-10, 50 *
COIN + 10);
63 const auto script_pk = p2wsh_op_true ?
66 tx_mut.
vout.emplace_back(amount, script_pk);
74 const auto n_elements = fuzzed_data_provider.ConsumeIntegralInRange<
size_t>(0, max_stack_elem_size);
75 for (
size_t i = 0; i < n_elements; ++i) {
87 static constexpr
unsigned MAX_BUFFER_SZ{128};
88 std::vector<uint8_t> buffer(MAX_BUFFER_SZ, uint8_t{
'a'});
89 while (fuzzed_data_provider.ConsumeBool()) {
94 r_script.insert(r_script.end(), buffer.begin(), buffer.begin() + fuzzed_data_provider.ConsumeIntegralInRange(0U, MAX_BUFFER_SZ));
98 r_script << std::vector<uint8_t>{buffer.begin(), buffer.begin() + fuzzed_data_provider.ConsumeIntegralInRange(0U, MAX_BUFFER_SZ)};
104 r_script << fuzzed_data_provider.ConsumeIntegralInRange<int64_t>(0, 22);
105 int num_data{fuzzed_data_provider.ConsumeIntegralInRange(1, 22)};
107 pubkey_comp.front() = fuzzed_data_provider.ConsumeIntegralInRange(2, 3);
108 std::vector<uint8_t> pubkey_uncomp{buffer.begin(), buffer.begin() +
CPubKey::SIZE};
109 pubkey_uncomp.front() = fuzzed_data_provider.ConsumeIntegralInRange(4, 7);
111 auto& pubkey{fuzzed_data_provider.ConsumeBool() ? pubkey_uncomp : pubkey_comp};
112 if (fuzzed_data_provider.ConsumeBool()) {
113 pubkey.back() = num_data;
117 r_script << fuzzed_data_provider.ConsumeIntegralInRange<int64_t>(0, 22);
122 std::copy(vec.begin(), vec.end(), buffer.begin());
126 r_script << fuzzed_data_provider.ConsumeIntegral<int64_t>();
138 if (maybe_p2wsh && fuzzed_data_provider.ConsumeBool()) {
149 return fuzzed_data_provider.ConsumeBool() ?
150 fuzzed_data_provider.PickValueInArray({
155 fuzzed_data_provider.ConsumeIntegral<uint32_t>();
162 fuzzed_data_provider,
183 witness_unknown.
version = fuzzed_data_provider.ConsumeIntegralInRange(2, 16);
184 std::vector<uint8_t> witness_unknown_program_1{fuzzed_data_provider.ConsumeBytes<uint8_t>(40)};
185 if (witness_unknown_program_1.size() < 2) {
186 witness_unknown_program_1 = {0, 0};
188 witness_unknown.length = witness_unknown_program_1.size();
189 std::copy(witness_unknown_program_1.begin(), witness_unknown_program_1.end(), witness_unknown.program);
190 tx_destination = witness_unknown;
192 Assert(call_size == std::variant_size_v<CTxDestination>);
193 return tx_destination;
198 for (
const CTxIn& tx_in : tx.vin) {
199 const Coin& coin = inputs.AccessCoin(tx_in.
prevout);
234 #if defined _GNU_SOURCE && !defined __ANDROID__
235 const cookie_io_functions_t io_hooks = {
241 return fopencookie(
this, mode.c_str(), io_hooks);
256 if (random_bytes.empty()) {
259 std::memcpy(buf, random_bytes.data(), random_bytes.size());
263 fuzzed_file->
m_offset += random_bytes.size();
264 return random_bytes.size();
281 assert(whence == SEEK_SET || whence == SEEK_CUR || whence == SEEK_END);
284 int64_t new_offset = 0;
285 if (whence == SEEK_SET) {
286 new_offset = *offset;
287 }
else if (whence == SEEK_CUR) {
291 new_offset = fuzzed_file->
m_offset + *offset;
292 }
else if (whence == SEEK_END) {
297 new_offset = n + *offset;
299 if (new_offset < 0) {
303 *offset = new_offset;
static constexpr CAmount MAX_MONEY
No amount larger than this (in satoshi) is valid.
int64_t CAmount
Amount in satoshis (Can be negative)
static constexpr CAmount COIN
The amount of satoshis in one BTC.
#define Assert(val)
Identity function.
CCoinsView that adds a memory cache for transactions to another CCoinsView.
An outpoint - a combination of a transaction hash and an index n into its vout.
static constexpr unsigned int COMPRESSED_SIZE
static constexpr unsigned int SIZE
secp256k1:
A hasher class for SHA-256.
void Finalize(unsigned char hash[OUTPUT_SIZE])
CSHA256 & Write(const unsigned char *data, size_t len)
Serialized script, used inside transaction inputs and outputs.
The basic transaction that is broadcasted on the network and contained in blocks.
static const int32_t CURRENT_VERSION
An input of a transaction.
static const uint32_t MAX_SEQUENCE_NONFINAL
This is the maximum sequence number that enables both nLockTime and OP_CHECKLOCKTIMEVERIFY (BIP 65).
static const uint32_t SEQUENCE_FINAL
Setting nSequence to this value for every input in a transaction disables nLockTime/IsFinalTx().
CScriptWitness scriptWitness
Only serialized through CTransaction.
bool IsSpent() const
Either this coin never existed (see e.g.
std::vector< T > ConsumeBytes(size_t num_bytes)
T ConsumeIntegralInRange(T min, T max)
static ssize_t write(void *cookie, const char *buf, size_t size)
FuzzedDataProvider & m_fuzzed_data_provider
static int seek(void *cookie, int64_t *offset, int whence)
static int close(void *cookie)
static ssize_t read(void *cookie, char *buf, size_t size)
constexpr unsigned char * begin()
bool AdditionOverflow(const T i, const T j) noexcept
std::vector< unsigned char > ToByteVector(const T &in)
std::variant< CNoDestination, PKHash, ScriptHash, WitnessV0ScriptHash, WitnessV0KeyHash, WitnessV1Taproot, WitnessUnknown > CTxDestination
A txout script template with a specific destination.
A mutable version of CTransaction.
std::vector< CTxOut > vout
std::vector< std::vector< unsigned char > > stack
CTxDestination subtype to encode any future Witness version.
uint32_t ConsumeSequence(FuzzedDataProvider &fuzzed_data_provider) noexcept
CMutableTransaction ConsumeTransaction(FuzzedDataProvider &fuzzed_data_provider, const std::optional< std::vector< uint256 >> &prevout_txids, const int max_num_in, const int max_num_out) noexcept
CScript ConsumeScript(FuzzedDataProvider &fuzzed_data_provider, const bool maybe_p2wsh) noexcept
int64_t ConsumeTime(FuzzedDataProvider &fuzzed_data_provider, const std::optional< int64_t > &min, const std::optional< int64_t > &max) noexcept
bool ContainsSpentInput(const CTransaction &tx, const CCoinsViewCache &inputs) noexcept
CScriptWitness ConsumeScriptWitness(FuzzedDataProvider &fuzzed_data_provider, const size_t max_stack_elem_size) noexcept
CTxDestination ConsumeTxDestination(FuzzedDataProvider &fuzzed_data_provider) noexcept
CAmount ConsumeMoney(FuzzedDataProvider &fuzzed_data_provider, const std::optional< CAmount > &max) noexcept
CScriptNum ConsumeScriptNum(FuzzedDataProvider &fuzzed_data_provider) noexcept
std::vector< uint8_t > ConsumeRandomLengthByteVector(FuzzedDataProvider &fuzzed_data_provider, const std::optional< size_t > &max_length=std::nullopt) noexcept
auto & PickValue(FuzzedDataProvider &fuzzed_data_provider, Collection &col)
uint256 ConsumeUInt256(FuzzedDataProvider &fuzzed_data_provider) noexcept
size_t CallOneOf(FuzzedDataProvider &fuzzed_data_provider, Callables... callables)
opcodetype ConsumeOpcodeType(FuzzedDataProvider &fuzzed_data_provider) noexcept
void SetFuzzedErrNo(FuzzedDataProvider &fuzzed_data_provider, const std::array< T, size > &errnos)
Sets errno to a value selected from the given std::array errnos.
uint160 ConsumeUInt160(FuzzedDataProvider &fuzzed_data_provider) noexcept
static const std::vector< uint8_t > WITNESS_STACK_ELEM_OP_TRUE
static const CScript P2WSH_OP_TRUE
static constexpr uint32_t MAX_BIP125_RBF_SEQUENCE