Merge pull request #486 from orbitcowboy/master
testuninitvar: moved more tests to checkUninitVar2
This commit is contained in:
commit
3686b22528
|
@ -2046,16 +2046,16 @@ private:
|
||||||
}
|
}
|
||||||
|
|
||||||
void uninitvar_typeof() {
|
void uninitvar_typeof() {
|
||||||
checkUninitVar("void f() {\n"
|
checkUninitVar2("void f() {\n"
|
||||||
" struct Fred *fred;\n"
|
" struct Fred *fred;\n"
|
||||||
" typeof(fred->x);\n"
|
" typeof(fred->x);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void f() {\n"
|
checkUninitVar2("void f() {\n"
|
||||||
" struct SData * s;\n"
|
" struct SData * s;\n"
|
||||||
" ab(typeof(s->status));\n"
|
" ab(typeof(s->status));\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void f() {\n"
|
checkUninitVar("void f() {\n"
|
||||||
|
@ -3603,9 +3603,9 @@ private:
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: pFile\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: pFile\n", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void f(FILE * pFile) {\n"
|
checkUninitVar2("void f(FILE * pFile) {\n"
|
||||||
" clearerr (pFile);\n"
|
" clearerr (pFile);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// fclose
|
// fclose
|
||||||
|
@ -3615,9 +3615,9 @@ private:
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: pFile\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: pFile\n", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void f(FILE * pFile) {\n"
|
checkUninitVar2("void f(FILE * pFile) {\n"
|
||||||
" fclose (pFile);\n"
|
" fclose (pFile);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// fopen
|
// fopen
|
||||||
|
@ -3635,9 +3635,9 @@ private:
|
||||||
ASSERT_EQUALS("[test.cpp:4]: (error) Uninitialized variable: filename\n"
|
ASSERT_EQUALS("[test.cpp:4]: (error) Uninitialized variable: filename\n"
|
||||||
"[test.cpp:4]: (error) Uninitialized variable: mode\n", errout.str());
|
"[test.cpp:4]: (error) Uninitialized variable: mode\n", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void f(FILE * name, char *mode) {\n"
|
checkUninitVar2("void f(FILE * name, char *mode) {\n"
|
||||||
" fopen (name, mode);\n"
|
" fopen (name, mode);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// feof
|
// feof
|
||||||
|
@ -3647,9 +3647,9 @@ private:
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: pFile\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: pFile\n", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void f(FILE * pFile) {\n"
|
checkUninitVar2("void f(FILE * pFile) {\n"
|
||||||
" feof (pFile);\n"
|
" feof (pFile);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// ferror
|
// ferror
|
||||||
|
@ -3659,9 +3659,9 @@ private:
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: pFile\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: pFile\n", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void f(FILE * pFile) {\n"
|
checkUninitVar2("void f(FILE * pFile) {\n"
|
||||||
" ferror (pFile);\n"
|
" ferror (pFile);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// fflush
|
// fflush
|
||||||
|
@ -3671,9 +3671,9 @@ private:
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: pFile\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: pFile\n", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void f(FILE * pFile) {\n"
|
checkUninitVar2("void f(FILE * pFile) {\n"
|
||||||
" fflush (pFile);\n"
|
" fflush (pFile);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// fgetc
|
// fgetc
|
||||||
|
@ -3683,9 +3683,9 @@ private:
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: pFile\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: pFile\n", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void f(FILE * pFile) {\n"
|
checkUninitVar2("void f(FILE * pFile) {\n"
|
||||||
" fgetc (pFile);\n"
|
" fgetc (pFile);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
|
|
||||||
|
@ -3698,15 +3698,15 @@ private:
|
||||||
ASSERT_EQUALS("[test.cpp:4]: (error) Uninitialized variable: f\n"
|
ASSERT_EQUALS("[test.cpp:4]: (error) Uninitialized variable: f\n"
|
||||||
"[test.cpp:4]: (error) Uninitialized variable: p\n", errout.str());
|
"[test.cpp:4]: (error) Uninitialized variable: p\n", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void f(FILE * f) {\n"
|
checkUninitVar2("void f(FILE * f) {\n"
|
||||||
" fpos_t p;"
|
" fpos_t p;"
|
||||||
" fgetpos (f, &p);\n"
|
" fgetpos (f, &p);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void f(FILE * f, fpos_t *p) {\n"
|
checkUninitVar2("void f(FILE * f, fpos_t *p) {\n"
|
||||||
" fgetpos (f, p);\n"
|
" fgetpos (f, p);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// fsetpos
|
// fsetpos
|
||||||
|
@ -3738,15 +3738,15 @@ private:
|
||||||
ASSERT_EQUALS("[test.cpp:4]: (error) Uninitialized variable: n\n"
|
ASSERT_EQUALS("[test.cpp:4]: (error) Uninitialized variable: n\n"
|
||||||
"[test.cpp:4]: (error) Uninitialized variable: s\n", errout.str());
|
"[test.cpp:4]: (error) Uninitialized variable: s\n", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void f(char * s, int n) {\n"
|
checkUninitVar2("void f(char * s, int n) {\n"
|
||||||
" FILE *f;\n"
|
" FILE *f;\n"
|
||||||
" fgets (s, n, f);\n"
|
" fgets (s, n, f);\n"
|
||||||
"}");
|
"}");
|
||||||
TODO_ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: f\n","", errout.str());
|
TODO_ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: f\n","", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void f(char * s, int n, FILE *f) {\n"
|
checkUninitVar2("void f(char * s, int n, FILE *f) {\n"
|
||||||
" fgets (s, n, f);\n"
|
" fgets (s, n, f);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// fputc
|
// fputc
|
||||||
|
@ -3758,9 +3758,9 @@ private:
|
||||||
ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: c\n"
|
ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: c\n"
|
||||||
"[test.cpp:3]: (error) Uninitialized variable: f\n", errout.str());
|
"[test.cpp:3]: (error) Uninitialized variable: f\n", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void f(int c, FILE *f) {\n"
|
checkUninitVar2("void f(int c, FILE *f) {\n"
|
||||||
" fputc (c, f);\n"
|
" fputc (c, f);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// fputs
|
// fputs
|
||||||
|
@ -3772,9 +3772,9 @@ private:
|
||||||
ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: c\n"
|
ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: c\n"
|
||||||
"[test.cpp:3]: (error) Uninitialized variable: f\n", errout.str());
|
"[test.cpp:3]: (error) Uninitialized variable: f\n", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void f(char *c, FILE *f) {\n"
|
checkUninitVar2("void f(char *c, FILE *f) {\n"
|
||||||
" fputs (c, f);\n"
|
" fputs (c, f);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// ftell
|
// ftell
|
||||||
|
@ -3784,9 +3784,9 @@ private:
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:2]: (error) Uninitialized variable: f\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:2]: (error) Uninitialized variable: f\n", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void f( FILE *f) {\n"
|
checkUninitVar2("void f( FILE *f) {\n"
|
||||||
" ftell (f);\n"
|
" ftell (f);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// puts
|
// puts
|
||||||
|
@ -3796,44 +3796,44 @@ private:
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:2]: (error) Uninitialized variable: c\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:2]: (error) Uninitialized variable: c\n", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void f( char *c) {\n"
|
checkUninitVar2("void f( char *c) {\n"
|
||||||
" puts (c);\n"
|
" puts (c);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// putchar
|
// putchar
|
||||||
checkUninitVar("void f() {\n"
|
checkUninitVar2("void f() {\n"
|
||||||
" char *c;"
|
" char *c;"
|
||||||
" putchar (*c);\n"
|
" putchar (*c);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:2]: (error) Uninitialized variable: c\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:2]: (error) Uninitialized variable: c\n", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void f( char *c) {\n"
|
checkUninitVar2("void f( char *c) {\n"
|
||||||
" putchar (*c);\n"
|
" putchar (*c);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// #6116 False positive uninitvar - first argument to wcstombs()
|
// #6116 False positive uninitvar - first argument to wcstombs()
|
||||||
checkUninitVar("void f( wchar_t *wstr) {\n"
|
checkUninitVar2("void f( wchar_t *wstr) {\n"
|
||||||
" char buf[10];\n"
|
" char buf[10];\n"
|
||||||
" wcstombs (buf, wstr, 3);\n"
|
" wcstombs (buf, wstr, 3);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
checkUninitVar("void f( char *str) {\n"
|
checkUninitVar2("void f( char *str) {\n"
|
||||||
" wchar_t wbuf[10];\n"
|
" wchar_t wbuf[10];\n"
|
||||||
" mbstowcs (wbuf, str, 3);\n"
|
" mbstowcs (wbuf, str, 3);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void foo() {\n"
|
checkUninitVar2("void foo() {\n"
|
||||||
" char buf[10];\n"
|
" char buf[10];\n"
|
||||||
" tmpnam(buf);\n"
|
" tmpnam(buf);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
checkUninitVar("void foo() {\n"
|
checkUninitVar2("void foo() {\n"
|
||||||
" char *ptr;\n"
|
" char *ptr;\n"
|
||||||
" tmpnam(ptr);\n"
|
" tmpnam(ptr);\n"
|
||||||
"}");
|
"}");
|
||||||
TODO_ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: ptr\n", "", errout.str());
|
TODO_ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: ptr\n", "", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3893,10 +3893,10 @@ private:
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:4]: (error) Uninitialized variable: fd\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:4]: (error) Uninitialized variable: fd\n", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void no_uninitvar(int fd, char *buf)\n"
|
checkUninitVar2("void no_uninitvar(int fd, char *buf)\n"
|
||||||
"{\n"
|
"{\n"
|
||||||
" write(fd, buf, sizeof(buf));\n"
|
" write(fd, buf, 8);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
|
|
||||||
|
@ -3914,29 +3914,29 @@ private:
|
||||||
ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: buf\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: buf\n", errout.str());
|
||||||
|
|
||||||
// avoid false positives
|
// avoid false positives
|
||||||
checkUninitVar("void no_uninitvar(char *buf) {\n"
|
checkUninitVar2("void no_uninitvar(char *buf) {\n"
|
||||||
" write(STDOUT_FILENO, buf, sizeof(buf));\n"
|
" write(STDOUT_FILENO, buf, 8);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void no_uninitvar() {\n"
|
checkUninitVar2("void no_uninitvar() {\n"
|
||||||
" char buf[1] = {'c'};\n"
|
" char buf[1] = {'c'};\n"
|
||||||
" write(STDOUT_FILENO, &buf, 1);\n"
|
" write(STDOUT_FILENO, &buf, 1);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
|
|
||||||
// check the third parameter of the posix function write
|
// check the third parameter of the posix function write
|
||||||
checkUninitVar("void uninitvar(char *buf) {\n"
|
checkUninitVar2("void uninitvar(char *buf) {\n"
|
||||||
" int nbytes;\n"
|
" int nbytes;\n"
|
||||||
" write(STDOUT_FILENO, buf, nbytes);\n"
|
" write(STDOUT_FILENO, buf, nbytes);\n"
|
||||||
"}");
|
"}");
|
||||||
TODO_ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: nbytes\n", "", errout.str());
|
TODO_ASSERT_EQUALS("[test.cpp:3]: (error) Uninitialized variable: nbytes\n", "", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void no_uninitvar(char *buf, int nbytes)\n"
|
checkUninitVar2("void no_uninitvar(char *buf, int nbytes)\n"
|
||||||
"{\n"
|
"{\n"
|
||||||
" write(STDOUT_FILENO, buf, nbytes);\n"
|
" write(STDOUT_FILENO, buf, nbytes);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue