summaryrefslogtreecommitdiffstats
path: root/testsuite/systemtap.syscall/chmod.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/chmod.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/chmod.c')
-rw-r--r--testsuite/systemtap.syscall/chmod.c81
1 files changed, 81 insertions, 0 deletions
diff --git a/testsuite/systemtap.syscall/chmod.c b/testsuite/systemtap.syscall/chmod.c
new file mode 100644
index 00000000..fd7473f4
--- /dev/null
+++ b/testsuite/systemtap.syscall/chmod.c
@@ -0,0 +1,81 @@
+/* COVERAGE: chmod fchmod chown fchown lchown */
+/* COVERAGE: chown16 fchown16 lchown16 */
+#include <unistd.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <sys/syscall.h>
+
+int main()
+{
+ int fd;
+
+ fd = open("foobar",O_WRONLY|O_CREAT, 0666);
+ // open ("foobar", O_WRONLY|O_CREAT, 0666) = 4
+
+ chmod("foobar", 0644);
+ // chmod ("foobar", 0644) = 0
+
+ fchmod(fd, 0444);
+ // fchmod (4, 0444) = 0
+
+ chown("foobar", 5000, -1);
+#ifdef __i386__
+ // chown ("foobar", 5000, -1) =
+#else
+ // chown ("foobar", 5000, NNNN) =
+#endif
+
+ chown("foobar", -1, 5001);
+#ifdef __i386__
+ // chown ("foobar", -1, 5001) =
+#else
+ // chown ("foobar", NNNN, 5001) =
+#endif
+
+ fchown(fd, 5002, -1);
+#ifdef __i386__
+ // fchown (4, 5002, -1) =
+#else
+ // fchown (4, 5002, NNNN) =
+#endif
+
+ fchown(fd, -1, 5003);
+#ifdef __i386__
+ // fchown (4, -1, 5003) =
+#else
+ // fchown (4, NNNN, 5003) =
+#endif
+
+ lchown("foobar", 5004, -1);
+#ifdef __i386__
+ // lchown ("foobar", 5004, -1) =
+#else
+ // lchown ("foobar", 5004, NNNN) =
+#endif
+
+ lchown("foobar", -1, 5005);
+#ifdef __i386__
+ // lchown ("foobar", -1, 5005) =
+#else
+ // lchown ("foobar", NNNN, 5005) =
+#endif
+
+#ifdef __i386__
+ syscall(SYS_chown, "foobar", 5000, -1);
+ // chown16 ("foobar", 5000, -1) =
+ syscall(SYS_chown, "foobar", -1, 5001);
+ // chown16 ("foobar", -1, 5001) =
+ syscall(SYS_fchown, fd, 5002, -1);
+ // fchown16 (4, 5002, -1) =
+ syscall(SYS_fchown, fd, -1, 5003);
+ // fchown16 (4, -1, 5003) =
+ syscall(SYS_lchown, "foobar", 5004, -1);
+ // lchown16 ("foobar", 5004, -1) =
+ syscall(SYS_lchown, "foobar", -1, 5005);
+ // lchown16 ("foobar", -1, 5005) =
+#endif
+
+ close(fd);
+ return 0;
+}