5 #include <chainparams.h> 25 static const auto testing_setup = MakeNoLogFileContext<>();
26 g_setup = testing_setup.get();
33 const std::optional<CMutableTransaction> mutable_transaction = ConsumeDeserializable<CMutableTransaction>(fuzzed_data_provider);
35 const unsigned int n_in = fuzzed_data_provider.ConsumeIntegral<
unsigned int>();
37 const bool store = fuzzed_data_provider.ConsumeBool();
40 if (fuzzed_data_provider.ConsumeBool()) {
41 const auto random_bytes = fuzzed_data_provider.ConsumeBytes<
unsigned char>(64);
43 if (random_bytes.size() == 64) {
44 (void)caching_transaction_signature_checker.VerifySchnorrSignature(random_bytes, pub_key,
ConsumeUInt256(fuzzed_data_provider));
48 const auto pub_key = ConsumeDeserializable<CPubKey>(fuzzed_data_provider);
50 if (!random_bytes.empty()) {
51 (void)caching_transaction_signature_checker.VerifyECDSASignature(random_bytes, *pub_key,
ConsumeUInt256(fuzzed_data_provider));
FUZZ_TARGET(script_sigcache,.init=initialize_script_sigcache)
std::vector< B > ConsumeRandomLengthByteVector(FuzzedDataProvider &fuzzed_data_provider, const std::optional< size_t > &max_length=std::nullopt) noexcept
int64_t CAmount
Amount in satoshis (Can be negative)
void initialize_script_sigcache()
CAmount ConsumeMoney(FuzzedDataProvider &fuzzed_data_provider, const std::optional< CAmount > &max) noexcept
A mutable version of CTransaction.
The basic transaction that is broadcasted on the network and contained in blocks. ...
uint256 ConsumeUInt256(FuzzedDataProvider &fuzzed_data_provider) noexcept