Whamcloud - gitweb
Branch HEAD
[fs/lustre-release.git] / lustre / tests / opendevunlink.c
index fde7d36..15ac708 100644 (file)
@@ -2,7 +2,9 @@
  * vim:expandtab:shiftwidth=8:tabstop=8:
  */
 
+#ifndef _GNU_SOURCE
 #define _GNU_SOURCE
+#endif
 
 #include <stdio.h>
 #include <errno.h>
@@ -11,6 +13,8 @@
 #include <sys/stat.h>
 #include <dirent.h>
 #include <string.h>
+#include <unistd.h>
+#include <stdlib.h>
 
 int main(int argc, char **argv)
 {
@@ -34,7 +38,7 @@ int main(int argc, char **argv)
         fprintf(stderr, "creating special file %s\n", dname1);
         rc = mknod(dname1, 0777|S_IFIFO, 0);
         if (rc == -1) {
-                fprintf(stderr, "creating %s fails: %s\n", 
+                fprintf(stderr, "creating %s fails: %s\n",
                         dname1, strerror(errno));
                 exit(1);
         }
@@ -47,7 +51,7 @@ int main(int argc, char **argv)
                         dname1, strerror(errno));
                 exit(1);
         }
-        
+
         // doesn't matter if the two dirs are the same??
         fddev2 = open(dname2, O_RDONLY | O_NONBLOCK);
         if (fddev2 == -1) {
@@ -55,40 +59,38 @@ int main(int argc, char **argv)
                         dname2, strerror(errno));
                 exit(1);
         }
-        
+
         // delete the special file
         fprintf (stderr, "unlinking %s\n", dname1);
         rc = unlink(dname1);
         if (rc) {
-                fprintf(stderr, "unlink %s error: %s\n", 
+                fprintf(stderr, "unlink %s error: %s\n",
                         dname1, strerror(errno));
                 exit(1);
         }
 
-        if (access(dname2, F_OK) == 0){
+        if (access(dname2, F_OK) == 0) {
                 fprintf(stderr, "%s still exists\n", dname2);
                 exit(1);
         }
 
-        if (access(dname1, F_OK) == 0){
+        if (access(dname1, F_OK) == 0) {
                 fprintf(stderr, "%s still exists\n", dname1);
                 exit(1);
         }
 
         // fchmod one special file
         rc = fchmod (fddev1, 0777);
-        if(rc == -1)
-        {
-                fprintf(stderr, "fchmod unlinked special file %s fails: %s\n", 
+        if (rc == -1) {
+                fprintf(stderr, "fchmod unlinked special file %s fails: %s\n",
                         dname1, strerror(errno));
                 exit(1);
         }
-                
+
         // fstat two files to check if they are the same
         rc = fstat(fddev1, &st1);
-        if(rc == -1)
-        {
-                fprintf(stderr, "fstat unlinked special file %s fails: %s\n", 
+        if (rc == -1) {
+                fprintf(stderr, "fstat unlinked special file %s fails: %s\n",
                         dname1, strerror(errno));
                 exit(1);
         }
@@ -100,10 +102,14 @@ int main(int argc, char **argv)
                 exit(1);
         }
 
+#if 0
+        /* We cannot do this any longer, we do not store open special nodes
+         * on MDS after unlink */
         if (st1.st_mode != st2.st_mode) {  // can we do this?
                 fprintf(stderr, "fstat different value on %s and %s\n",                                 dname1, dname2);
                 exit(1);
-        }        
+        }
+#endif
 
         fprintf(stderr, "Ok, everything goes well.\n");
         return 0;