From: Fei Jie Date: Tue, 1 Mar 2016 08:55:36 +0000 (+0800) Subject: tests: add rename.test X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=a4128a75f5432bda07b51f379c4e51a4e0e28ae9;p=strace tests: add rename.test * tests/rename.c: New file. * tests/rename.test: New test. * tests/.gitignore: Add rename. * tests/Makefile.am (check_PROGRAMS): Likewise. (TESTS): Add rename.test. --- diff --git a/tests/.gitignore b/tests/.gitignore index e79d3174..a5d586d4 100644 --- a/tests/.gitignore +++ b/tests/.gitignore @@ -81,6 +81,7 @@ readlink readlinkat readv recvmsg +rename restart_syscall rt_sigpending rt_sigprocmask diff --git a/tests/Makefile.am b/tests/Makefile.am index d924b9a4..4603c923 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -129,6 +129,7 @@ check_PROGRAMS = \ readlinkat \ readv \ recvmsg \ + rename \ restart_syscall \ rt_sigpending \ rt_sigprocmask \ @@ -287,6 +288,7 @@ TESTS = \ readlinkat.test \ readv.test \ recvmsg.test \ + rename.test \ rt_sigpending.test \ rt_sigprocmask.test \ rt_sigqueueinfo.test \ diff --git a/tests/rename.c b/tests/rename.c new file mode 100644 index 00000000..2fb88d64 --- /dev/null +++ b/tests/rename.c @@ -0,0 +1,29 @@ +#include "tests.h" +#include +#include + +#ifdef __NR_rename + +# include +# include + +# define OLD_FILE "rename_old" +# define NEW_FILE "rename_new" + +int +main(void) +{ + int rc = syscall(__NR_rename, OLD_FILE, NEW_FILE); + printf("rename(\"%s\", \"%s\") = %d %s (%m)\n", + OLD_FILE, NEW_FILE, rc, + errno == ENOSYS ? "ENOSYS" : "ENOENT"); + + puts("+++ exited with 0 +++"); + return 0; +} + +#else + +SKIP_MAIN_UNDEFINED("__NR_rename") + +#endif diff --git a/tests/rename.test b/tests/rename.test new file mode 100755 index 00000000..6d879505 --- /dev/null +++ b/tests/rename.test @@ -0,0 +1,11 @@ +#!/bin/sh + +# Check rename syscall decoding. + +. "${srcdir=.}/init.sh" + +run_prog > /dev/null +OUT="$LOG.out" +run_strace -erename -a35 $args > "$OUT" +match_diff "$LOG" "$OUT" +rm -f "$OUT"