TestIO: Refactoring. Use functions instead of macros.

This commit is contained in:
Frank Zingsheim 2016-10-24 21:43:58 +02:00 committed by Daniel Marjamäki
parent f973a9a9d5
commit 0162f76c63
1 changed files with 93 additions and 54 deletions

View File

@ -67,7 +67,7 @@ private:
TEST_CASE(testPrintf0WithSuffix); // ticket #7069 TEST_CASE(testPrintf0WithSuffix); // ticket #7069
} }
void check(const char code[], bool inconclusive = false, bool portability = false, Settings::PlatformType platform = Settings::Unspecified) { void check(const std::string &code, bool inconclusive = false, bool portability = false, Settings::PlatformType platform = Settings::Unspecified) {
// Clear the error buffer.. // Clear the error buffer..
errout.str(""); errout.str("");
@ -95,9 +95,6 @@ private:
checkIO.invalidScanf(); checkIO.invalidScanf();
} }
void coutCerrMisusage() { void coutCerrMisusage() {
check( check(
"void foo() {\n" "void foo() {\n"
@ -748,64 +745,106 @@ private:
} }
std::string testScanfCode(const std::string & format, const std::string & type) {
return "void f() { " + type + " x; scanf(\"" + format + "\", &x); }";
}
#define TEST_SCANF_CODE(FORMAT,TYPE) "void f() { " TYPE " x; scanf(\"" FORMAT "\", &x); }" std::string testScanfErr(const std::string & format, const std::string & formatStr, const std::string & type) {
return "[test.cpp:1]: (warning) " + format + " in format string (no. 1) requires '" + formatStr + " *' but the argument type is '" + type + " *'.\n";
}
#define TEST_SCANF_ERR(FORMAT,FORMATSTR,TYPE) \ std::string testScanfErrAka(const std::string & format, const std::string & formatStr, const std::string & type, const std::string & akaType) {
"[test.cpp:1]: (warning) " FORMAT " in format string (no. 1) requires '" FORMATSTR " *' but the argument type is '" TYPE " *'.\n" return "[test.cpp:1]: (portability) " + format + " in format string (no. 1) requires '" + formatStr + " *' but the argument type is '" + type + " * {aka " + akaType + " *}'.\n";
}
#define TEST_SCANF_ERR_AKA(FORMAT,FORMATSTR,TYPE,AKATYPE) \ void testScanfNoWarn(const char *filename, unsigned int linenr,
"[test.cpp:1]: (portability) " FORMAT " in format string (no. 1) requires '" FORMATSTR " *' but the argument type is '" TYPE " * {aka " AKATYPE " *}'.\n" const std::string & format, const std::string & /* formatStr */ , const std::string & type) {
const std::string code = testScanfCode(format, type);
#define TEST_SCANF_NOWARN(FORMAT, FORMATSTR, TYPE) \ check(code, true, false, Settings::Unix32);
check(TEST_SCANF_CODE(FORMAT,TYPE), true, false, Settings::Unix32); \ assertEquals(filename, linenr, "", errout.str());
ASSERT_EQUALS("", errout.str()); \ check(code, true, false, Settings::Unix64);
check(TEST_SCANF_CODE(FORMAT,TYPE), true, false, Settings::Unix64); \ assertEquals(filename, linenr, "", errout.str());
ASSERT_EQUALS("", errout.str()); \ check(code, true, false, Settings::Win32A);
check(TEST_SCANF_CODE(FORMAT,TYPE), true, false, Settings::Win32A); \ assertEquals(filename, linenr, "", errout.str());
ASSERT_EQUALS("", errout.str()); \ check(code, true, false, Settings::Win64);
check(TEST_SCANF_CODE(FORMAT,TYPE), true, false, Settings::Win64); \ assertEquals(filename, linenr, "", errout.str());
ASSERT_EQUALS("", errout.str()); }
#define TEST_SCANF_WARN(FORMAT, FORMATSTR, TYPE) \ void testScanfWarn(const char *filename, unsigned int linenr,
check(TEST_SCANF_CODE(FORMAT,TYPE), true, false, Settings::Unix32); \ const std::string & format, const std::string & formatStr, const std::string & type) {
ASSERT_EQUALS(TEST_SCANF_ERR(FORMAT,FORMATSTR,TYPE), errout.str()); \ const std::string code = testScanfCode(format, type);
check(TEST_SCANF_CODE(FORMAT,TYPE), true, false, Settings::Unix64); \ const std::string testScanfErrString = testScanfErr(format,formatStr,type);
ASSERT_EQUALS(TEST_SCANF_ERR(FORMAT,FORMATSTR,TYPE), errout.str()); \
check(TEST_SCANF_CODE(FORMAT,TYPE), true, false, Settings::Win32A); \
ASSERT_EQUALS(TEST_SCANF_ERR(FORMAT,FORMATSTR,TYPE), errout.str()); \
check(TEST_SCANF_CODE(FORMAT,TYPE), true, false, Settings::Win64); \
ASSERT_EQUALS(TEST_SCANF_ERR(FORMAT,FORMATSTR,TYPE), errout.str());
#define TEST_SCANF_WARN_AKA(FORMAT, FORMATSTR, TYPE, AKATYPE, AKATYPE_WIN64) \ check(code, true, false, Settings::Unix32);
check(TEST_SCANF_CODE(FORMAT,TYPE), true, true, Settings::Unix32); \ assertEquals(filename, linenr, testScanfErrString, errout.str());
ASSERT_EQUALS(TEST_SCANF_ERR_AKA(FORMAT,FORMATSTR,TYPE,AKATYPE), errout.str()); \ check(code, true, false, Settings::Unix64);
check(TEST_SCANF_CODE(FORMAT,TYPE), true, true, Settings::Unix64); \ assertEquals(filename, linenr, testScanfErrString, errout.str());
ASSERT_EQUALS(TEST_SCANF_ERR_AKA(FORMAT,FORMATSTR,TYPE,AKATYPE), errout.str()); \ check(code, true, false, Settings::Win32A);
check(TEST_SCANF_CODE(FORMAT,TYPE), true, true, Settings::Win32A); \ assertEquals(filename, linenr, testScanfErrString, errout.str());
ASSERT_EQUALS(TEST_SCANF_ERR_AKA(FORMAT,FORMATSTR,TYPE,AKATYPE), errout.str()); \ check(code, true, false, Settings::Win64);
check(TEST_SCANF_CODE(FORMAT,TYPE), true, true, Settings::Win64); \ assertEquals(filename, linenr, testScanfErrString, errout.str());
ASSERT_EQUALS(TEST_SCANF_ERR_AKA(FORMAT,FORMATSTR,TYPE,AKATYPE_WIN64), errout.str()); }
#define TEST_SCANF_WARN_AKA_WIN64(FORMAT, FORMATSTR, TYPE, AKATYPE_WIN64) \ void testScanfWarnAka(const char *filename, unsigned int linenr,
check(TEST_SCANF_CODE(FORMAT,TYPE), true, true, Settings::Unix32); \ const std::string & format, const std::string & formatStr, const std::string & type,
ASSERT_EQUALS("", errout.str()); \ const std::string & akaType, const std::string & akaTypeWin64) {
check(TEST_SCANF_CODE(FORMAT,TYPE), true, true, Settings::Unix64); \ const std::string code = testScanfCode(format, type);
ASSERT_EQUALS("", errout.str()); \ const std::string testScanfErrAkaString = testScanfErrAka(format,formatStr,type,akaType);
check(TEST_SCANF_CODE(FORMAT,TYPE), true, true, Settings::Win32A); \ const std::string testScanfErrAkaWin64String = testScanfErrAka(format,formatStr,type,akaTypeWin64);
ASSERT_EQUALS("", errout.str()); \
check(TEST_SCANF_CODE(FORMAT,TYPE), true, true, Settings::Win64); \
ASSERT_EQUALS(TEST_SCANF_ERR_AKA(FORMAT,FORMATSTR,TYPE,AKATYPE_WIN64), errout.str());
#define TEST_SCANF_WARN_AKA_WIN32(FORMAT, FORMATSTR, TYPE, AKATYPE) \ check(code, true, true, Settings::Unix32);
check(TEST_SCANF_CODE(FORMAT,TYPE), true, true, Settings::Unix32); \ assertEquals(filename, linenr, testScanfErrAkaString, errout.str());
ASSERT_EQUALS(TEST_SCANF_ERR_AKA(FORMAT,FORMATSTR,TYPE,AKATYPE), errout.str()); \ check(code, true, true, Settings::Unix64);
check(TEST_SCANF_CODE(FORMAT,TYPE), true, true, Settings::Unix64); \ assertEquals(filename, linenr, testScanfErrAkaString, errout.str());
ASSERT_EQUALS(TEST_SCANF_ERR_AKA(FORMAT,FORMATSTR,TYPE,AKATYPE), errout.str()); \ check(code, true, true, Settings::Win32A);
check(TEST_SCANF_CODE(FORMAT,TYPE), true, true, Settings::Win32A); \ assertEquals(filename, linenr, testScanfErrAkaString, errout.str());
ASSERT_EQUALS(TEST_SCANF_ERR_AKA(FORMAT,FORMATSTR,TYPE,AKATYPE), errout.str()); \ check(code, true, true, Settings::Win64);
check(TEST_SCANF_CODE(FORMAT,TYPE), true, true, Settings::Win64); \ assertEquals(filename, linenr, testScanfErrAkaWin64String, errout.str());
ASSERT_EQUALS("", errout.str()); }
void testScanfWarnAkaWin64(const char *filename, unsigned int linenr,
const std::string & format, const std::string & formatStr, const std::string & type,
const std::string & akaTypeWin64) {
const std::string code = testScanfCode(format, type);
const std::string testScanfErrAkaWin64String = testScanfErrAka(format,formatStr,type,akaTypeWin64);
check(code, true, true, Settings::Unix32);
assertEquals(filename, linenr, "", errout.str());
check(code, true, true, Settings::Unix64);
assertEquals(filename, linenr, "", errout.str());
check(code, true, true, Settings::Win32A);
assertEquals(filename, linenr, "", errout.str());
check(code, true, true, Settings::Win64);
assertEquals(filename, linenr, testScanfErrAkaWin64String, errout.str());
}
void testScanfWarnAkaWin32(const char *filename, unsigned int linenr,
const std::string & format, const std::string & formatStr, const std::string & type,
const std::string & akaType) {
const std::string code = testScanfCode(format, type);
const std::string testScanfErrAkaString = testScanfErrAka(format,formatStr,type,akaType);
check(code, true, true, Settings::Unix32);
assertEquals(filename, linenr, testScanfErrAkaString, errout.str());
check(code, true, true, Settings::Unix64);
assertEquals(filename, linenr, testScanfErrAkaString, errout.str());
check(code, true, true, Settings::Win32A);
assertEquals(filename, linenr, testScanfErrAkaString, errout.str());
check(code, true, true, Settings::Win64);
assertEquals(filename, linenr, "", errout.str());
}
#define TEST_SCANF_NOWARN(FORMAT, FORMATSTR, TYPE) \
testScanfNoWarn(__FILE__, __LINE__, FORMAT, FORMATSTR, TYPE)
#define TEST_SCANF_WARN(FORMAT, FORMATSTR, TYPE) \
testScanfWarn(__FILE__, __LINE__, FORMAT, FORMATSTR, TYPE)
#define TEST_SCANF_WARN_AKA(FORMAT, FORMATSTR, TYPE, AKATYPE, AKATYPE_WIN64) \
testScanfWarnAka(__FILE__, __LINE__, FORMAT, FORMATSTR, TYPE, AKATYPE, AKATYPE_WIN64)
#define TEST_SCANF_WARN_AKA_WIN64(FORMAT, FORMATSTR, TYPE, AKATYPE_WIN64) \
testScanfWarnAkaWin64(__FILE__, __LINE__, FORMAT, FORMATSTR, TYPE, AKATYPE_WIN64)
#define TEST_SCANF_WARN_AKA_WIN32(FORMAT, FORMATSTR, TYPE, AKATYPE_WIN32) \
testScanfWarnAkaWin32(__FILE__, __LINE__, FORMAT, FORMATSTR, TYPE, AKATYPE_WIN32)
void testScanfArgument() { void testScanfArgument() {
check("void foo() {\n" check("void foo() {\n"