[cfe-commits] r146574 - /cfe/trunk/test/Analysis/taint-tester.c
Anna Zaks
ganna at apple.com
Wed Dec 14 10:34:17 PST 2011
Author: zaks
Date: Wed Dec 14 12:34:17 2011
New Revision: 146574
URL: http://llvm.org/viewvc/llvm-project?rev=146574&view=rev
Log:
[analyzer] Re-enable the test which was failing on one of the bots.
I cannot reproduce the failures neither on my machine nor on the same buildbot machine (with the clang binary built on it). Let's see if it fails again..
Modified:
cfe/trunk/test/Analysis/taint-tester.c
Modified: cfe/trunk/test/Analysis/taint-tester.c
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Analysis/taint-tester.c?rev=146574&r1=146573&r2=146574&view=diff
==============================================================================
--- cfe/trunk/test/Analysis/taint-tester.c (original)
+++ cfe/trunk/test/Analysis/taint-tester.c Wed Dec 14 12:34:17 2011
@@ -76,3 +76,49 @@
m = inn;
int mm = m; // expected-warning {{tainted}}
}
+
+// Test getenv.
+char *getenv(const char *name);
+void getenvTest(char *home) {
+ home = getenv("HOME"); // expected-warning 2 {{tainted}}
+ if (home != 0) { // expected-warning 2 {{tainted}}
+ char d = home[0]; // expected-warning 2 {{tainted}}
+ }
+}
+
+typedef struct _FILE FILE;
+extern FILE *stdin;
+extern FILE *stdout;
+extern FILE *stderr;
+int fscanf(FILE *restrict stream, const char *restrict format, ...);
+int fprintf(FILE *stream, const char *format, ...);
+int fclose(FILE *stream);
+FILE *fopen(const char *path, const char *mode);
+
+int fscanfTest(void) {
+ FILE *fp;
+ char s[80];
+ int t;
+
+ // Check if stdin is treated as tainted.
+ fscanf(stdin, "%s %d", s, &t);
+ // Note, here, s is not tainted, but the data s points to is tainted.
+ char *ts = s;
+ char tss = s[0]; // expected-warning 1 {{tainted}}
+ int tt = t; // expected-warning 1 {{tainted}}
+ if((fp=fopen("test", "w")) == 0) // expected-warning 3 {{tainted}}
+ return 1;
+ fprintf(fp, "%s %d", s, t); // expected-warning 2 {{tainted}}
+ fclose(fp); // expected-warning 1 {{tainted}}
+
+ // Check if we propagate taint from stdin when it's used in an assignment.
+ FILE *pfstd = stdin;
+ fscanf(pfstd, "%s %d", s, &t); // TODO: This should be tainted as well.
+
+ // Test fscanf and fopen.
+ if((fp=fopen("test","r")) == 0) // expected-warning 3 {{tainted}}
+ return 1;
+ fscanf(fp, "%s%d", s, &t); // expected-warning 1 {{tainted}}
+ fprintf(stdout, "%s %d", s, t); // expected-warning 1 {{tainted}}
+ return 0;
+}
More information about the cfe-commits
mailing list