cppcheck/test/testincompletestatement.cpp

177 lines
4.1 KiB
C++
Raw Normal View History

2008-12-18 22:28:57 +01:00
/*
* Cppcheck - A tool for static C/C++ code analysis
* Copyright (C) 2007-2010 Daniel Marjamäki and Cppcheck team.
2008-12-18 22:28:57 +01:00
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
2008-12-18 22:28:57 +01:00
*/
// Check for unused variables..
2008-12-18 22:28:57 +01:00
#include "testsuite.h"
2009-10-25 12:49:06 +01:00
#include "tokenize.h"
#include "checkother.h"
2008-12-18 22:28:57 +01:00
#include <sstream>
extern std::ostringstream errout;
class TestIncompleteStatement : public TestFixture
{
public:
TestIncompleteStatement() : TestFixture("TestIncompleteStatement")
{ }
private:
void check(const char code[])
2008-12-18 22:28:57 +01:00
{
// Tokenize..
Tokenizer tokenizer;
std::istringstream istr(code);
tokenizer.tokenize(istr, "test.cpp");
2008-12-18 22:28:57 +01:00
tokenizer.simplifyTokenList();
// Clear the error buffer..
errout.str("");
Settings settings(Settings::testSettings());
2009-01-12 18:12:14 +01:00
2008-12-18 22:28:57 +01:00
// Check for unused variables..
2009-03-20 18:16:21 +01:00
CheckOther checkOther(&tokenizer, &settings, this);
checkOther.checkIncompleteStatement();
2008-12-18 22:28:57 +01:00
}
void run()
{
TEST_CASE(test1);
TEST_CASE(test2);
2009-02-05 19:57:53 +01:00
TEST_CASE(test3);
TEST_CASE(test4);
TEST_CASE(test5);
TEST_CASE(test_numeric);
TEST_CASE(intarray);
TEST_CASE(structarraynull);
TEST_CASE(structarray);
2008-12-18 22:28:57 +01:00
}
void test1()
{
check("void foo()\n"
"{\n"
" const char def[] =\n"
"#ifdef ABC\n"
" \"abc\";\n"
"#else\n"
" \"not abc\";\n"
"#endif\n"
"}\n");
ASSERT_EQUALS("", errout.str());
2008-12-18 22:28:57 +01:00
}
void test2()
{
check("void foo()\n"
"{\n"
2009-02-05 19:57:53 +01:00
" \"abc\";\n"
"}\n");
2008-12-18 22:28:57 +01:00
ASSERT_EQUALS("[test.cpp:3]: (style) Redundant code: Found a statement that begins with string constant\n", errout.str());
2008-12-18 22:28:57 +01:00
}
2009-02-05 19:57:53 +01:00
void test3()
{
check("void foo()\n"
"{\n"
" const char *str[] = { \"abc\" };\n"
"}\n");
ASSERT_EQUALS("", errout.str());
2009-02-05 19:57:53 +01:00
}
void test4()
{
check("void foo()\n"
"{\n"
"const char *a =\n"
"{\n"
"\"hello \"\n"
"\"more \"\n"
"\"world\"\n"
"};\n"
"}\n");
ASSERT_EQUALS("", errout.str());
}
void test5()
{
check("void foo()\n"
"{\n"
" 50;\n"
"}\n");
ASSERT_EQUALS("[test.cpp:3]: (style) Redundant code: Found a statement that begins with numeric constant\n", errout.str());
}
void test_numeric()
{
check("struct P\n"
"{\n"
"double a;\n"
"double b;\n"
"};\n"
"void f()\n"
"{\n"
"const P values[2] =\n"
"{\n"
"{ 346.1,114.1 }, { 347.1,111.1 }\n"
"};\n"
"}\n");
ASSERT_EQUALS("", errout.str());
}
void intarray()
{
check("int arr[] = { 100/2, 1*100 };\n");
ASSERT_EQUALS("", errout.str());
}
void structarraynull()
{
check("struct st arr[] = {\n"
" { 100/2, 1*100 }\n"
" { 90, 70 }\n"
"}\n");
ASSERT_EQUALS("", errout.str());
}
void structarray()
{
check("struct st arr[] = {\n"
" { 100/2, 1*100 }\n"
" { 90, 70 }\n"
"};\n");
ASSERT_EQUALS("", errout.str());
}
2008-12-18 22:28:57 +01:00
};
REGISTER_TEST(TestIncompleteStatement)
2008-12-18 22:28:57 +01:00