summaryrefslogtreecommitdiffstats
path: root/testsuite/systemtap.syscall/openclose.c
diff options
context:
space:
mode:
authorfche <fche>2006-08-12 05:13:09 +0000
committerfche <fche>2006-08-12 05:13:09 +0000
commit814bc89d4635f101b2c0077598f31aad95ed15b7 (patch)
tree407a49dbaf446af4751f5068607a7fb8dad0611d /testsuite/systemtap.syscall/openclose.c
parent6b6d04673a1ef175821afc7d4fabdb496698e8e3 (diff)
downloadsystemtap-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.c58
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;
+}