Removed version number from file header.
[kai/samba.git] / source3 / torture / utable.c
index ea36487f64eaefc5a0e04d1b80ce6ebc2fac9997..2b5a912062fecee7ce5ce48c92fdf12344df0026 100644 (file)
@@ -1,6 +1,5 @@
 /* 
-   Unix SMB/Netbios implementation.
-   Version 3.0
+   Unix SMB/CIFS implementation.
    SMB torture tester - unicode table dumper
    Copyright (C) Andrew Tridgell 2001
    
@@ -29,8 +28,9 @@ BOOL torture_utable(int dummy)
        fstring fname, alt_name;
        int fnum;
        smb_ucs2_t c2;
-       int c, len;
+       int c, len, fd;
        int chars_allowed=0, alt_allowed=0;
+       uint8 valid[0x10000];
 
        printf("starting utable\n");
 
@@ -38,7 +38,10 @@ BOOL torture_utable(int dummy)
                return False;
        }
 
+       memset(valid, 0, sizeof(valid));
+
        cli_mkdir(&cli, "\\utable");
+       cli_unlink(&cli, "\\utable\\*");
 
        for (c=1; c < 0x10000; c++) {
                char *p;
@@ -62,7 +65,8 @@ BOOL torture_utable(int dummy)
 
                if (strncmp(alt_name, "X_A_L", 5) != 0) {
                        alt_allowed++;
-                       /* d_printf("fname=[%s] alt_name=[%s]\n", fname, alt_name); */
+                       valid[c] = 1;
+                       d_printf("fname=[%s] alt_name=[%s]\n", fname, alt_name);
                }
 
                cli_close(&cli, fnum);
@@ -78,6 +82,15 @@ BOOL torture_utable(int dummy)
 
        d_printf("%d chars allowed   %d alt chars allowed\n", chars_allowed, alt_allowed);
 
+       fd = open("valid.dat", O_WRONLY|O_CREAT|O_TRUNC, 0644);
+       if (fd == -1) {
+               d_printf("Failed to create valid.dat - %s", strerror(errno));
+               return False;
+       }
+       write(fd, valid, 0x10000);
+       close(fd);
+       d_printf("wrote valid.dat\n");
+
        return True;
 }
 
@@ -89,7 +102,7 @@ static char *form_name(int c)
        char *p;
        int len;
 
-       fstrcpy(fname, "\\utable\\x");
+       fstrcpy(fname, "\\utable\\");
        p = fname+strlen(fname);
        SSVAL(&c2, 0, c);
 
@@ -97,7 +110,6 @@ static char *form_name(int c)
                             &c2, 2, 
                             p, sizeof(fname)-strlen(fname));
        p[len] = 0;
-       fstrcat(fname,"_a_long_extension");
        return fname;
 }
 
@@ -106,46 +118,64 @@ BOOL torture_casetable(int dummy)
        static struct cli_state cli;
        char *fname;
        int fnum;
-       int c;
-
-       printf("starting utable\n");
+       int c, i;
+#define MAX_EQUIVALENCE 8
+       smb_ucs2_t equiv[0x10000][MAX_EQUIVALENCE];
+       printf("starting casetable\n");
 
        if (!torture_open_connection(&cli)) {
                return False;
        }
 
+       memset(equiv, 0, sizeof(equiv));
+
        cli_mkdir(&cli, "\\utable");
        cli_unlink(&cli, "\\utable\\*");
 
        for (c=1; c < 0x10000; c++) {
+               size_t size;
+
+               if (c == '.' || c == '\\') continue;
+
+               printf("%04x\n", c);
+
                fname = form_name(c);
                fnum = cli_nt_create_full(&cli, fname, 
                                          GENERIC_ALL_ACCESS, 
                                          FILE_ATTRIBUTE_NORMAL,
                                          FILE_SHARE_NONE,
-                                         FILE_CREATE, 0);
+                                         FILE_OPEN_IF, 0);
+
+               if (fnum == -1) continue;
 
-               if (fnum == -1 && 
-                   NT_STATUS_EQUAL(cli_nt_error(&cli),NT_STATUS_OBJECT_NAME_COLLISION)) {
+               size = 0;
+
+               if (!cli_qfileinfo(&cli, fnum, NULL, &size, 
+                                  NULL, NULL, NULL, NULL, NULL)) continue;
+
+               if (size > 0) {
                        /* found a character equivalence! */
-                       int c2;
-                       
-                       fnum = cli_nt_create_full(&cli, fname, 
-                                                 GENERIC_ALL_ACCESS, 
-                                                 FILE_ATTRIBUTE_NORMAL,
-                                                 FILE_SHARE_NONE,
-                                                 FILE_OPEN, 0);
-                       if (fnum == -1 || 
-                           cli_read(&cli, fnum, (char *)&c2, 0, sizeof(c2)) != sizeof(c2)) {
-                               continue;
+                       int c2[MAX_EQUIVALENCE];
+
+                       if (size/sizeof(int) >= MAX_EQUIVALENCE) {
+                               printf("too many chars match?? size=%d c=0x%04x\n",
+                                      size, c);
+                               cli_close(&cli, fnum);
+                               return False;
                        }
 
-                       printf("%04x == %04x\n", c, c2);
-                       cli_close(&cli, fnum);
-                       continue;
+                       cli_read(&cli, fnum, (char *)c2, 0, size);
+                       printf("%04x: ", c);
+                       equiv[c][0] = c;
+                       for (i=0; i<size/sizeof(int); i++) {
+                               printf("%04x ", c2[i]);
+                               equiv[c][i+1] = c2[i];
+                       }
+                       printf("\n");
+                       fflush(stdout);
                }
 
-               cli_write(&cli, fnum, 0, (char *)&c, 0, sizeof(c));
+               cli_write(&cli, fnum, 0, (char *)&c, size, sizeof(c));
                cli_close(&cli, fnum);
        }