mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-10 20:03:34 -03:00
tests: Avoid hitting some known minor tinyformat issues when fuzzing strprintf(...)
This commit is contained in:
parent
b063cb690f
commit
470e2ac602
1 changed files with 33 additions and 14 deletions
|
@ -8,7 +8,6 @@
|
||||||
#include <util/strencodings.h>
|
#include <util/strencodings.h>
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <cassert>
|
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
@ -27,7 +26,7 @@ void test_one_input(const std::vector<uint8_t>& buffer)
|
||||||
// * strprintf("%.222222200000000$", 1.1);
|
// * strprintf("%.222222200000000$", 1.1);
|
||||||
//
|
//
|
||||||
// Upstream bug report: https://github.com/c42f/tinyformat/issues/70
|
// Upstream bug report: https://github.com/c42f/tinyformat/issues/70
|
||||||
if (format_string.find("%") != std::string::npos && digits_in_format_specifier >= 7) {
|
if (format_string.find('%') != std::string::npos && digits_in_format_specifier >= 7) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -35,7 +34,7 @@ void test_one_input(const std::vector<uint8_t>& buffer)
|
||||||
// * strprintf("%1$*1$*", -11111111);
|
// * strprintf("%1$*1$*", -11111111);
|
||||||
//
|
//
|
||||||
// Upstream bug report: https://github.com/c42f/tinyformat/issues/70
|
// Upstream bug report: https://github.com/c42f/tinyformat/issues/70
|
||||||
if (format_string.find("%") != std::string::npos && format_string.find("$") != std::string::npos && format_string.find("*") != std::string::npos && digits_in_format_specifier > 0) {
|
if (format_string.find('%') != std::string::npos && format_string.find('$') != std::string::npos && format_string.find('*') != std::string::npos && digits_in_format_specifier > 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -96,7 +95,7 @@ void test_one_input(const std::vector<uint8_t>& buffer)
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
switch (fuzzed_data_provider.ConsumeIntegralInRange(0, 13)) {
|
switch (fuzzed_data_provider.ConsumeIntegralInRange(0, 5)) {
|
||||||
case 0:
|
case 0:
|
||||||
(void)strprintf(format_string, fuzzed_data_provider.ConsumeRandomLengthString(32));
|
(void)strprintf(format_string, fuzzed_data_provider.ConsumeRandomLengthString(32));
|
||||||
break;
|
break;
|
||||||
|
@ -115,32 +114,52 @@ void test_one_input(const std::vector<uint8_t>& buffer)
|
||||||
case 5:
|
case 5:
|
||||||
(void)strprintf(format_string, fuzzed_data_provider.ConsumeBool());
|
(void)strprintf(format_string, fuzzed_data_provider.ConsumeBool());
|
||||||
break;
|
break;
|
||||||
case 6:
|
}
|
||||||
|
} catch (const tinyformat::format_error&) {
|
||||||
|
}
|
||||||
|
|
||||||
|
if (format_string.find('%') != std::string::npos && format_string.find('c') != std::string::npos) {
|
||||||
|
// Avoid triggering the following:
|
||||||
|
// * strprintf("%c", 1.31783e+38);
|
||||||
|
// tinyformat.h:244:36: runtime error: 1.31783e+38 is outside the range of representable values of type 'char'
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (format_string.find('%') != std::string::npos && format_string.find('*') != std::string::npos) {
|
||||||
|
// Avoid triggering the following:
|
||||||
|
// * strprintf("%*", -2.33527e+38);
|
||||||
|
// tinyformat.h:283:65: runtime error: -2.33527e+38 is outside the range of representable values of type 'int'
|
||||||
|
// * strprintf("%*", -2147483648);
|
||||||
|
// tinyformat.h:763:25: runtime error: negation of -2147483648 cannot be represented in type 'int'; cast to an unsigned type to negate this value to itself
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
switch (fuzzed_data_provider.ConsumeIntegralInRange(0, 7)) {
|
||||||
|
case 0:
|
||||||
(void)strprintf(format_string, fuzzed_data_provider.ConsumeFloatingPoint<float>());
|
(void)strprintf(format_string, fuzzed_data_provider.ConsumeFloatingPoint<float>());
|
||||||
break;
|
break;
|
||||||
case 7:
|
case 1:
|
||||||
(void)strprintf(format_string, fuzzed_data_provider.ConsumeFloatingPoint<double>());
|
(void)strprintf(format_string, fuzzed_data_provider.ConsumeFloatingPoint<double>());
|
||||||
break;
|
break;
|
||||||
case 8:
|
case 2:
|
||||||
(void)strprintf(format_string, fuzzed_data_provider.ConsumeIntegral<int16_t>());
|
(void)strprintf(format_string, fuzzed_data_provider.ConsumeIntegral<int16_t>());
|
||||||
break;
|
break;
|
||||||
case 9:
|
case 3:
|
||||||
(void)strprintf(format_string, fuzzed_data_provider.ConsumeIntegral<uint16_t>());
|
(void)strprintf(format_string, fuzzed_data_provider.ConsumeIntegral<uint16_t>());
|
||||||
break;
|
break;
|
||||||
case 10:
|
case 4:
|
||||||
(void)strprintf(format_string, fuzzed_data_provider.ConsumeIntegral<int32_t>());
|
(void)strprintf(format_string, fuzzed_data_provider.ConsumeIntegral<int32_t>());
|
||||||
break;
|
break;
|
||||||
case 11:
|
case 5:
|
||||||
(void)strprintf(format_string, fuzzed_data_provider.ConsumeIntegral<uint32_t>());
|
(void)strprintf(format_string, fuzzed_data_provider.ConsumeIntegral<uint32_t>());
|
||||||
break;
|
break;
|
||||||
case 12:
|
case 6:
|
||||||
(void)strprintf(format_string, fuzzed_data_provider.ConsumeIntegral<int64_t>());
|
(void)strprintf(format_string, fuzzed_data_provider.ConsumeIntegral<int64_t>());
|
||||||
break;
|
break;
|
||||||
case 13:
|
case 7:
|
||||||
(void)strprintf(format_string, fuzzed_data_provider.ConsumeIntegral<uint64_t>());
|
(void)strprintf(format_string, fuzzed_data_provider.ConsumeIntegral<uint64_t>());
|
||||||
break;
|
break;
|
||||||
default:
|
|
||||||
assert(false);
|
|
||||||
}
|
}
|
||||||
} catch (const tinyformat::format_error&) {
|
} catch (const tinyformat::format_error&) {
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue