fuzz: Limit toxic test globals to their respective scope

This commit is contained in:
MarcoFalke 2021-05-04 09:30:58 +02:00
parent e2d4e67a8f
commit cf83b82cf0
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