diff options
| author | Cristian Cadar <c.cadar@imperial.ac.uk> | 2013-09-25 07:36:44 -0700 | 
|---|---|---|
| committer | Cristian Cadar <c.cadar@imperial.ac.uk> | 2013-09-25 07:36:44 -0700 | 
| commit | 43138101d048394690a90fd9f5a6fb0df916161c (patch) | |
| tree | 70e9d4a75804cc2ef12bda03fd029c013462e123 /test/Runtime/POSIX/Openat.c | |
| parent | 1510c721187f1e838d30fca376af2ab5af90ee6c (diff) | |
| parent | 90601a60fb6a0f22337c46680f150ec04ad3c6cb (diff) | |
| download | klee-43138101d048394690a90fd9f5a6fb0df916161c.tar.gz | |
Merge pull request #25 from paulmar/master
Added some of the common *at functions & others to the model. Obey --max-forks in switch statements.
Diffstat (limited to 'test/Runtime/POSIX/Openat.c')
| -rw-r--r-- | test/Runtime/POSIX/Openat.c | 18 | 
1 files changed, 18 insertions, 0 deletions
| diff --git a/test/Runtime/POSIX/Openat.c b/test/Runtime/POSIX/Openat.c new file mode 100644 index 00000000..d417ee47 --- /dev/null +++ b/test/Runtime/POSIX/Openat.c @@ -0,0 +1,18 @@ +// RUN: %llvmgcc %s -emit-llvm -O0 -c -o %t2.bc +// RUN: %klee --posix-runtime --exit-on-error %t2.bc --sym-files 1 10 +// RUN: test -f klee-last/test000001.ktest + +#include <assert.h> +#include <fcntl.h> + +int main(int argc, char **argv) { + int fd = openat(AT_FDCWD, "A", O_RDWR|O_TRUNC); + if (fd != -1) { + char buf[10]; + assert(read(fd, buf, 10) == 10); + assert(klee_is_symbolic(buf[0])); + } else { + klee_silent_exit(0); + } + return 0; +} | 
