summaryrefslogtreecommitdiff
path: root/test/stat
diff options
context:
space:
mode:
authorEric Andersen <andersen@codepoet.org>2003-01-24 16:04:35 +0000
committerEric Andersen <andersen@codepoet.org>2003-01-24 16:04:35 +0000
commitce464b8b54384bbc7a63dbfdc6add6cc1997c21e (patch)
tree49582cbcde0733e0a9440b62a4949269c4139af1 /test/stat
parent14c6293257eae377415d84ede9d118988e6474ce (diff)
Better stat tests
Diffstat (limited to 'test/stat')
-rw-r--r--test/stat/.cvsignore12
-rw-r--r--test/stat/Makefile52
-rw-r--r--test/stat/stat.c91
3 files changed, 118 insertions, 37 deletions
diff --git a/test/stat/.cvsignore b/test/stat/.cvsignore
new file mode 100644
index 000000000..341a419b0
--- /dev/null
+++ b/test/stat/.cvsignore
@@ -0,0 +1,12 @@
+stat
+stat.o
+stat.out
+stat64
+stat64.o
+stat64.out
+stat64_glibc
+stat64_glibc.o
+stat64_glibc.out
+stat_glibc
+stat_glibc.o
+stat_glibc.out
diff --git a/test/stat/Makefile b/test/stat/Makefile
index c2d4e75cc..5c284fb05 100644
--- a/test/stat/Makefile
+++ b/test/stat/Makefile
@@ -19,9 +19,10 @@
TESTDIR=../
include $(TESTDIR)/Rules.mak
+CFLAGS64=-D_LARGEFILE_SOURCE -D_LARGEFILE64_SOURCE -D_FILE_OFFSET_BITS=64
-TARGETS=stat stat_glibc
+TARGETS=stat_diff stat64_diff
all: $(TARGETS)
@@ -41,9 +42,7 @@ stat: stat.c Makefile $(TESTDIR)/Config $(TESTDIR)/Rules.mak $(CC)
$(CC) $(CFLAGS) -c $< -o $@.o
$(CC) $(LDFLAGS) $@.o -o $@ $(EXTRA_LIBS)
$(STRIPTOOL) -x -R .note -R .comment $@
- -$(LDD) $@
- ls -l $@
- -./$@
+ -./$@ stat.c > $@.out
-@ echo " "
stat_glibc: stat.c Makefile
@@ -54,12 +53,49 @@ stat_glibc: stat.c Makefile
$(HOSTCC) $(GLIBC_CFLAGS) -c $< -o $@.o
$(HOSTCC) $(GLIBC_LDFLAGS) $@.o -o $@
$(STRIPTOOL) -x -R .note -R .comment $@
- -$(LDD) $@
- ls -l $@
- -./$@
+ -./$@ stat.c > $@.out
+ -@ echo " "
+
+stat_diff: stat stat_glibc
+ -@ echo "-------"
+ -@ echo " "
+ -@ echo "Diffing stat output: "
+ -@ echo " "
+ -diff -u stat_glibc.out stat.out
+ -@ echo " "
+
+stat64: stat.c Makefile $(TESTDIR)/Config $(TESTDIR)/Rules.mak $(CC)
+ -@ echo "-------"
+ -@ echo " "
+ -@ echo "Compiling vs uClibc: "
+ -@ echo " "
+ $(CC) $(CFLAGS) $(CFLAGS64) -c $< -o $@.o
+ $(CC) $(LDFLAGS) $@.o -o $@ $(EXTRA_LIBS)
+ $(STRIPTOOL) -x -R .note -R .comment $@
+ -./$@ stat.c > $@.out
+ -@ echo " "
+
+stat64_glibc: stat.c Makefile
+ -@ echo "-------"
+ -@ echo " "
+ -@ echo "Compiling vs GNU libc: "
+ -@ echo " "
+ $(HOSTCC) $(GLIBC_CFLAGS) $(CFLAGS64) -c $< -o $@.o
+ $(HOSTCC) $(GLIBC_LDFLAGS) $@.o -o $@
+ $(STRIPTOOL) -x -R .note -R .comment $@
+ -./$@ stat.c > $@.out
+ -@ echo " "
+
+stat64_diff: stat64 stat64_glibc
+ -@ echo "-------"
+ -@ echo " "
+ -@ echo "Diffing stat64 output: "
+ -@ echo " "
+ -diff -u stat64_glibc.out stat64.out
-@ echo " "
clean:
- rm -f *.[oa] *~ core $(TARGETS)
+ rm -f *.[oa] *~ core stat stat_glibc stat_glibc.out stat.out \
+ stat64 stat64_glibc stat64_glibc.out stat64.out
diff --git a/test/stat/stat.c b/test/stat/stat.c
index eb99dbc64..9de2b3ef6 100644
--- a/test/stat/stat.c
+++ b/test/stat/stat.c
@@ -1,35 +1,68 @@
-
-#include <sys/stat.h>
#include <stdio.h>
+#include <fcntl.h>
+#include <sys/stat.h>
+void print_struct_stat(char *msg, struct stat *s)
+{
+ printf("%s\n", msg);
+ /* The casts are because glibc thinks it's cool */
+ printf("device : 0x%x\n",(unsigned int)s->st_dev);
+ printf("inode : %d\n",(int)s->st_ino);
+ printf("mode : 0x%x\n",s->st_mode);
+ printf("nlink : %d\n",s->st_nlink);
+ printf("uid : %d\n",s->st_uid);
+ printf("gid : %d\n",s->st_gid);
+ printf("rdev : 0x%x\n",(unsigned int)s->st_rdev);
+ printf("size : %ld\n",s->st_size);
+ printf("blksize : %ld\n",s->st_blksize);
+ printf("blocks : %ld\n",s->st_blocks);
+ printf("atime : %ld\n",s->st_atime);
+ printf("mtime : %ld\n",s->st_mtime);
+ printf("ctime : %ld\n",s->st_ctime);
+}
-int main(int argc,char *argv[])
+int main(int argc,char **argv)
{
- struct stat s;
- int ret;
-
- ret = stat("/",&s);
-
- if(ret<0){
- perror("stat");
- exit(1);
- }
-
- /* The casts are because glibc thinks it's cool */
- printf("device : 0x%x\n",(unsigned int)s.st_dev);
- printf("inode : %d\n",(int)s.st_ino);
- printf("mode : 0x%x\n",s.st_mode);
- printf("nlink : %d\n",s.st_nlink);
- printf("uid : %d\n",s.st_uid);
- printf("gid : %d\n",s.st_gid);
- printf("rdev : 0x%x\n",(unsigned int)s.st_rdev);
- printf("size : %ld\n",s.st_size);
- printf("blksize : %ld\n",s.st_blksize);
- printf("blocks : %ld\n",s.st_blocks);
- printf("atime : %ld\n",s.st_atime);
- printf("mtime : %ld\n",s.st_mtime);
- printf("ctime : %ld\n",s.st_ctime);
-
- exit(0);
+ int fd, ret;
+ char *file;
+ struct stat s;
+
+ if (argc < 2) {
+ fprintf(stderr, "Usage: stat FILE\n");
+ exit(1);
+ }
+ file = argv[1];
+
+ memset(&s, 0, sizeof(struct stat));
+ ret = stat(file, &s);
+ if(ret<0){
+ perror("stat");
+ exit(1);
+ }
+ print_struct_stat("\nTesting stat:", &s);
+
+ memset(&s, 0, sizeof(struct stat));
+ ret = lstat(file, &s);
+ if(ret<0){
+ perror("lstat");
+ exit(1);
+ }
+ print_struct_stat("\nTesting lstat:", &s);
+
+
+ fd = open(file, O_RDONLY);
+ if(fd<0){
+ perror("open");
+ exit(1);
+ }
+ memset(&s, 0, sizeof(struct stat));
+ ret = fstat(fd,&s);
+ if(ret<0){
+ perror("fstat");
+ exit(1);
+ }
+ print_struct_stat("\nTesting fstat:", &s);
+
+ exit(0);
}