Merge bitcoin/bitcoin#21849: fuzz: Limit toxic test globals to their respective scope

cf83b82cf0 fuzz: Limit toxic test globals to their respective scope (MarcoFalke)

Pull request description:

  Globals in one fuzz target are toxic to all other fuzz targets, because we link all fuzz targets into one binary. Any code called by constructing the global will affect all other targets. This leads to incorrect coverage stats, false-positive crashes, ...

ACKs for top commit:
  practicalswift:
    cr ACK cf83b82cf0: non-toxic is better than toxic!
  laanwj:
    Code review ACK cf83b82cf0

Tree-SHA512: 5b3a37bcb36fce4160c94f877b2c07704527e3e1842092375c793d2eca77b996ae62889326094020855666bb34fa019fcfe92e8ff8430ce0372227f03ab2b907
This commit is contained in:
MarcoFalke 2021-05-04 17:21:34 +02:00
commit 3f8f238deb
No known key found for this signature in database
GPG key ID: CE2B75697E69A548

View file

@ -133,8 +133,7 @@ unsigned int ParseScriptFlags(const std::string& str)
std::vector<std::string> words; std::vector<std::string> words;
boost::algorithm::split(words, str, boost::algorithm::is_any_of(",")); boost::algorithm::split(words, str, boost::algorithm::is_any_of(","));
for (const std::string& word : words) for (const std::string& word : words) {
{
auto it = FLAG_NAMES.find(word); auto it = FLAG_NAMES.find(word);
if (it == FLAG_NAMES.end()) throw std::runtime_error("Unknown verification flag " + word); if (it == FLAG_NAMES.end()) throw std::runtime_error("Unknown verification flag " + word);
flags |= it->second; flags |= it->second;
@ -186,15 +185,19 @@ void Test(const std::string& str)
} }
} }
ECCVerifyHandle handle; void test_init()
{
static ECCVerifyHandle handle;
}
} // namespace FUZZ_TARGET_INIT_HIDDEN(script_assets_test_minimizer, test_init, /* hidden */ true)
FUZZ_TARGET_INIT_HIDDEN(script_assets_test_minimizer, FuzzFrameworkEmptyInitFun, /* hidden */ true)
{ {
if (buffer.size() < 2 || buffer.back() != '\n' || buffer[buffer.size() - 2] != ',') return; if (buffer.size() < 2 || buffer.back() != '\n' || buffer[buffer.size() - 2] != ',') return;
const std::string str((const char*)buffer.data(), buffer.size() - 2); const std::string str((const char*)buffer.data(), buffer.size() - 2);
try { try {
Test(str); Test(str);
} catch (const std::runtime_error&) {} } catch (const std::runtime_error&) {
} }
}
} // namespace