From: Fei Jie Date: Fri, 25 Mar 2016 09:47:16 +0000 (+0800) Subject: tests: add renameat.test X-Git-Tag: v4.12~495 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=896479de7630f08f730eaeb6996010363f981570;p=strace tests: add renameat.test * tests/renameat.c: New file. * tests/renameat.test: New test. * tests/.gitignore: Add renameat. * tests/Makefile.am (check_PROGRAMS): Likewise. (DECODER_TESTS): Add renameat.test. --- diff --git a/tests/.gitignore b/tests/.gitignore index ba3b8f5b..0100e6cf 100644 --- a/tests/.gitignore +++ b/tests/.gitignore @@ -94,6 +94,7 @@ readlinkat readv recvmsg rename +renameat restart_syscall rt_sigpending rt_sigprocmask diff --git a/tests/Makefile.am b/tests/Makefile.am index a7e9d96a..3ff50680 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -143,6 +143,7 @@ check_PROGRAMS = \ readv \ recvmsg \ rename \ + renameat\ restart_syscall \ rt_sigpending \ rt_sigprocmask \ @@ -311,6 +312,7 @@ DECODER_TESTS = \ readv.test \ recvmsg.test \ rename.test \ + renameat.test \ rt_sigpending.test \ rt_sigprocmask.test \ rt_sigqueueinfo.test \ diff --git a/tests/renameat.c b/tests/renameat.c new file mode 100644 index 00000000..f17e9b01 --- /dev/null +++ b/tests/renameat.c @@ -0,0 +1,31 @@ +#include "tests.h" +#include +#include + +#ifdef __NR_renameat + +# include +# include + +# define OLD_FILE "renameat_old" +# define NEW_FILE "renameat_new" + +int +main(void) +{ + const long int fd_old = (long int) 0xdeadbeefffffffff; + const long int fd_new = (long int) 0xdeadbeeffffffffe; + int rc = syscall(__NR_renameat, fd_old, OLD_FILE, fd_new, NEW_FILE); + printf("renameat(%d, \"%s\", %d, \"%s\") = %d %s (%m)\n", + (int) fd_old, OLD_FILE, (int) fd_new, NEW_FILE, rc, + errno == ENOSYS ? "ENOSYS" : "EBADF"); + + puts("+++ exited with 0 +++"); + return 0; +} + +#else + +SKIP_MAIN_UNDEFINED("__NR_renameat") + +#endif diff --git a/tests/renameat.test b/tests/renameat.test new file mode 100755 index 00000000..728b18dc --- /dev/null +++ b/tests/renameat.test @@ -0,0 +1,11 @@ +#!/bin/sh + +# Check rename syscall decoding. + +. "${srcdir=.}/init.sh" + +run_prog > /dev/null +OUT="$LOG.out" +run_strace -erenameat $args > "$OUT" +match_diff "$LOG" "$OUT" +rm -f "$OUT"