From: braam Date: Thu, 5 Dec 2002 14:48:21 +0000 (+0000) Subject: - test program for inode synchronization through fstat & revalidate_inode X-Git-Tag: v1_7_100~1^90~122 X-Git-Url: https://git.whamcloud.com/?a=commitdiff_plain;h=816f6fcfbbde2ed6fedc4c6e3fd6c98db97b710f;p=fs%2Flustre-release.git - test program for inode synchronization through fstat & revalidate_inode - remove setuid.c (sudo will do) --- diff --git a/lustre/tests/multifstat.c b/lustre/tests/multifstat.c new file mode 100644 index 0000000..56948d9 --- /dev/null +++ b/lustre/tests/multifstat.c @@ -0,0 +1,62 @@ +#include +#include +#include +#include +#include +#include +#include + +int main(int argc, char **argv) +{ + int fd1, fd2; + struct stat st1, st2; + + if (argc != 3) { + printf("Usage %s file1 file2\n", argv[0]); + return 1; + } + + + fd1 = open(argv[1], O_CREAT| O_RDWR, 0666); + if (fd1 == -1) { + printf("Error opening %s: %s\n", argv[1], strerror(errno)); + return errno; + } + + fd2 = open(argv[2], O_RDONLY); + if (fd2 == -1) { + printf("Error opening %s: %s\n", argv[2], strerror(errno)); + return errno; + } + + sleep(1); + + if ( write(fd1, "hello", strlen("hello")) != strlen("hello")) { + printf("Error writing: %s\n", strerror(errno)); + return errno; + } + + if ( fstat(fd1, &st1) ) { + printf("Error statting %s: %s\n", argv[1], strerror(errno)); + return errno; + } + + if ( fstat(fd2, &st2) ) { + printf("Error statting %s: %s\n", argv[2], strerror(errno)); + return errno; + } + + if ( st1.st_size != st2.st_size ) { + printf("Sizes don't match %ld, %ld\n", + st1.st_size, st2.st_size); + return 1; + } + + if ( st1.st_mtime != st2.st_mtime ) { + printf("Mtimes don't match %ld, %ld\n", + st1.st_mtime, st2.st_mtime); + return 1; + } + + return 0; +} diff --git a/lustre/tests/sanityN.sh b/lustre/tests/sanityN.sh index 1af967b..b18632e 100644 --- a/lustre/tests/sanityN.sh +++ b/lustre/tests/sanityN.sh @@ -43,6 +43,10 @@ echo -n "test 4: symlink on one mtpt, readlink on another..." [ "Xthis/is/good" = X`perl -e 'print readlink("/mnt/lustre2/lnk");'` ] || error "test 4 fails" echo "pass" +echo -n "test 5: fstat validation on multiple mount points..." +./multifstat /mnt/lustre1/fstatfile /mnt/lustre2/fstatfile || error "test 5 fails" +echo "pass" + $CLEAN $START diff --git a/lustre/tests/setuid.c b/lustre/tests/setuid.c deleted file mode 100644 index 04dba5e..0000000 --- a/lustre/tests/setuid.c +++ /dev/null @@ -1,27 +0,0 @@ -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -int main(int argc, char ** argv) -{ - int rc, fsuid; - - if (argc < 2) { - printf("Usage %s fsuid\n", argv[0]); - return 1; - } - - fsuid = strtoul(argv[2], NULL, 0); - rc = setfsuid(fsuid); - if (rc) { - printf("mknod(%s) error: %s\n", argv[1], strerror(errno)); - } - return rc; -}