diff options
author | fche <fche> | 2006-08-12 05:13:09 +0000 |
---|---|---|
committer | fche <fche> | 2006-08-12 05:13:09 +0000 |
commit | 814bc89d4635f101b2c0077598f31aad95ed15b7 (patch) | |
tree | 407a49dbaf446af4751f5068607a7fb8dad0611d /testsuite/systemtap.syscall/openclose.c | |
parent | 6b6d04673a1ef175821afc7d4fabdb496698e8e3 (diff) | |
download | systemtap-steved-814bc89d4635f101b2c0077598f31aad95ed15b7.tar.gz systemtap-steved-814bc89d4635f101b2c0077598f31aad95ed15b7.tar.xz systemtap-steved-814bc89d4635f101b2c0077598f31aad95ed15b7.zip |
2006-08-12 Frank Ch. Eigler <fche@elastic.org>
* configure.ac, Makefile.am: Descend into testsuite/
directory. Remove local test logic.
* configure, Makefile.in: Regenerated.
* runtest.sh: Not yet removed.
* HACKING: Update for new testsuite layout.
2006-08-12 Frank Ch. Eigler <fche@elastic.org>
* all: Reorganized old pass-1..4 tests one dejagnu bucket.
Moved over old pass-5 tests, except for disabled syscalls tests.
* Makefile (installcheck): New target for running pass-1..5
tests against installed systemtap.
Diffstat (limited to 'testsuite/systemtap.syscall/openclose.c')
-rw-r--r-- | testsuite/systemtap.syscall/openclose.c | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/testsuite/systemtap.syscall/openclose.c b/testsuite/systemtap.syscall/openclose.c new file mode 100644 index 00000000..a35f1a59 --- /dev/null +++ b/testsuite/systemtap.syscall/openclose.c @@ -0,0 +1,58 @@ +/* COVERAGE: open close creat */ +#define _GNU_SOURCE +#include <stdio.h> +#include <sys/types.h> +#include <sys/stat.h> +#include <fcntl.h> +#include <stdlib.h> +#include <unistd.h> + + +int main() +{ + int fd1, fd2; + + fd2 = creat("foobar1",S_IREAD|S_IWRITE); + // open ("foobar1", O_WRONLY|O_CREAT|O_TRUNC, 0600) = NNNN + + fd1 = open("foobar2",O_WRONLY|O_CREAT, S_IRWXU); + // open ("foobar2", O_WRONLY|O_CREAT, 0700) = NNNN + close(fd1); + // close (NNNN) = 0 + + fd1 = open("foobar2",O_RDONLY); + // open ("foobar2", O_RDONLY) = NNNN + close(fd1); + // close (NNNN) = 0 + + fd1 = open("foobar2",O_RDWR); + // open ("foobar2", O_RDWR) = NNNN + close(fd1); + // close (NNNN) = 0 + + fd1 = open("foobar2",O_APPEND|O_WRONLY); + // open ("foobar2", O_WRONLY|O_APPEND) = NNNN + close(fd1); + // close (NNNN) = 0 + + fd1 = open("foobar2",O_DIRECT|O_RDWR); + // open ("foobar2", O_RDWR|O_DIRECT) = NNNN + close(fd1); + // close (NNNN) = 0 + + fd1 = open("foobar2",O_NOATIME|O_SYNC|O_RDWR); + // open ("foobar2", O_RDWR|O_NOATIME|O_SYNC) = NNNN + close(fd1); + // close (NNNN) = 0 + + /* Now test some bad opens */ + fd1 = open("/",O_WRONLY); + // open ("/", O_WRONLY) = -NNNN (EISDIR) + close (fd1); + // close (NNNN) = -NNNN (EBADF) + + fd1 = open("foobar2",O_WRONLY|O_CREAT|O_EXCL, S_IRWXU); + // open ("foobar2", O_WRONLY|O_CREAT|O_EXCL, 0700) = -NNNN (EEXIST) + + return 0; +} |