Skip to content

Commit 16b6d34

Browse files
author
MarcoFalke
committed
Merge bitcoin#18519: fuzz: Extend script fuzz test
fa86edf fuzz: Extend script fuzz test (MarcoFalke) Pull request description: ACKs for top commit: practicalswift: ACK fa86edf Tree-SHA512: 611adee9e673183e67f9711e49289fa59e410bb3ac1bb3fcbb7f1ed331bf0d288c7065e256a82eb41a30a4afe53544c836463cf58865d6e40b18795c8716e57c
2 parents 490ae0e + fa86edf commit 16b6d34

File tree

1 file changed

+26
-4
lines changed

1 file changed

+26
-4
lines changed

src/test/fuzz/script.cpp

+26-4
Original file line numberDiff line numberDiff line change
@@ -9,6 +9,7 @@
99
#include <policy/policy.h>
1010
#include <pubkey.h>
1111
#include <script/descriptor.h>
12+
#include <script/interpreter.h>
1213
#include <script/script.h>
1314
#include <script/sign.h>
1415
#include <script/signingprovider.h>
@@ -30,7 +31,10 @@ void initialize()
3031

3132
void test_one_input(const std::vector<uint8_t>& buffer)
3233
{
33-
const CScript script(buffer.begin(), buffer.end());
34+
FuzzedDataProvider fuzzed_data_provider(buffer.data(), buffer.size());
35+
const Optional<CScript> script_opt = ConsumeDeserializable<CScript>(fuzzed_data_provider);
36+
if (!script_opt) return;
37+
const CScript script{*script_opt};
3438

3539
std::vector<unsigned char> compressed;
3640
if (CompressScript(script, compressed)) {
@@ -89,12 +93,30 @@ void test_one_input(const std::vector<uint8_t>& buffer)
8993
ScriptToUniv(script, o4, false);
9094

9195
{
92-
FuzzedDataProvider fuzzed_data_provider(buffer.data(), buffer.size());
9396
const std::vector<uint8_t> bytes = ConsumeRandomLengthByteVector(fuzzed_data_provider);
94-
// DecompressScript(..., ..., bytes) is not guaranteed to be defined if bytes.size() <= 23.
95-
if (bytes.size() >= 24) {
97+
// DecompressScript(..., ..., bytes) is not guaranteed to be defined if the bytes vector is too short
98+
if (bytes.size() >= 32) {
9699
CScript decompressed_script;
97100
DecompressScript(decompressed_script, fuzzed_data_provider.ConsumeIntegral<unsigned int>(), bytes);
98101
}
99102
}
103+
104+
const Optional<CScript> other_script = ConsumeDeserializable<CScript>(fuzzed_data_provider);
105+
if (other_script) {
106+
{
107+
CScript script_mut{script};
108+
(void)FindAndDelete(script_mut, *other_script);
109+
}
110+
const std::vector<std::string> random_string_vector = ConsumeRandomLengthStringVector(fuzzed_data_provider);
111+
const uint32_t u32{fuzzed_data_provider.ConsumeIntegral<uint32_t>()};
112+
const uint32_t flags{u32 | SCRIPT_VERIFY_P2SH};
113+
{
114+
CScriptWitness wit;
115+
for (const auto& s : random_string_vector) {
116+
wit.stack.emplace_back(s.begin(), s.end());
117+
}
118+
(void)CountWitnessSigOps(script, *other_script, &wit, flags);
119+
wit.SetNull();
120+
}
121+
}
100122
}

0 commit comments

Comments
 (0)