From: Fei Jie Date: Fri, 25 Mar 2016 09:47:14 +0000 (+0800) Subject: tests: add creat.test X-Git-Tag: v4.12~497 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=8346e63e4308a20adacdea3ffe11fb497bfe3eb5;p=strace tests: add creat.test * tests/creat.c: New file. * tests/creat.test: New test. * tests/.gitignore: Add creat. * tests/Makefile.am (check_PROGRAMS): Likewise. (DECODER_TESTS): Add creat.test. --- diff --git a/tests/.gitignore b/tests/.gitignore index 3cc5ca55..21597617 100644 --- a/tests/.gitignore +++ b/tests/.gitignore @@ -20,6 +20,7 @@ clock_nanosleep clock_xettime copy_file_range count-f +creat dup dup2 dup3 diff --git a/tests/Makefile.am b/tests/Makefile.am index f8e4aaf1..9e440096 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -71,6 +71,7 @@ check_PROGRAMS = \ clock_xettime \ copy_file_range \ count-f \ + creat \ dup \ dup2 \ dup3 \ @@ -243,6 +244,7 @@ DECODER_TESTS = \ clock_nanosleep.test \ clock_xettime.test \ copy_file_range.test \ + creat.test \ dup.test \ dup2.test \ dup3.test \ diff --git a/tests/creat.c b/tests/creat.c new file mode 100644 index 00000000..d922dd7c --- /dev/null +++ b/tests/creat.c @@ -0,0 +1,29 @@ +#include "tests.h" +#include + +#ifdef __NR_creat + +# include +# include +# include +# include + +# define TMP_FILE "creat" + +int +main(void) +{ + int rc = syscall(__NR_creat, TMP_FILE, S_IRUSR); + printf("creat(\"%s\", %#o) = %d %s (%m)\n", + TMP_FILE, S_IRUSR, rc, + errno == ENOSYS ? "ENOSYS" : "ETXTBSY"); + + puts("+++ exited with 0 +++"); + return 0; +} + +#else + +SKIP_MAIN_UNDEFINED("__NR_creat") + +#endif diff --git a/tests/creat.test b/tests/creat.test new file mode 100755 index 00000000..a692e191 --- /dev/null +++ b/tests/creat.test @@ -0,0 +1,11 @@ +#!/bin/sh + +# Check creat syscall decoding. + +. "${srcdir=.}/init.sh" + +run_prog > /dev/null +OUT="$LOG.out" +run_strace -ecreat -a21 $args > "$OUT" +match_diff "$LOG" "$OUT" +rm -f "$OUT"