summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--source/Makefile.in2
-rw-r--r--source/include/client.h2
-rw-r--r--source/lib/charcnv.c1
-rw-r--r--source/torture/torture.c3
-rw-r--r--source/torture/utable.c82
5 files changed, 86 insertions, 4 deletions
diff --git a/source/Makefile.in b/source/Makefile.in
index 8dd1dbbdd1c..f0236a7d78a 100644
--- a/source/Makefile.in
+++ b/source/Makefile.in
@@ -320,7 +320,7 @@ UMOUNT_OBJ = client/smbumount.o \
NMBLOOKUP_OBJ = utils/nmblookup.o $(PARAM_OBJ) $(UBIQX_OBJ) \
$(LIBSMB_OBJ) $(LIB_OBJ)
-SMBTORTURE_OBJ = torture/torture.o torture/nbio.o torture/scanner.o \
+SMBTORTURE_OBJ = torture/torture.o torture/nbio.o torture/scanner.o torture/utable.o \
torture/denytest.o \
$(LIBSMB_OBJ) $(PARAM_OBJ) $(UBIQX_OBJ) $(LIB_OBJ)
diff --git a/source/include/client.h b/source/include/client.h
index 61a5633b981..d694afd72b3 100644
--- a/source/include/client.h
+++ b/source/include/client.h
@@ -45,7 +45,7 @@ typedef struct file_info
time_t atime;
time_t ctime;
pstring name;
- char short_name[13];
+ char short_name[13*3]; /* the *3 is to cope with multi-byte */
} file_info;
struct print_job_info
diff --git a/source/lib/charcnv.c b/source/lib/charcnv.c
index 0e7d5241f4a..5afc638a8d8 100644
--- a/source/lib/charcnv.c
+++ b/source/lib/charcnv.c
@@ -100,7 +100,6 @@ size_t convert_string(charset_t from, charset_t to,
smb_iconv_t descriptor;
if (srclen == -1) srclen = strlen(src)+1;
- if (destlen == -1) destlen = strlen(dest)+1;
if (!initialised) {
initialised = 1;
diff --git a/source/torture/torture.c b/source/torture/torture.c
index 33260dcc544..a34f9aa0853 100644
--- a/source/torture/torture.c
+++ b/source/torture/torture.c
@@ -424,7 +424,7 @@ static BOOL rw_torture3(struct cli_state *c, char *lockfname)
static BOOL rw_torture2(struct cli_state *c1, struct cli_state *c2)
{
- char *lockfname = "\\torture.lck";
+ char *lockfname = "\\torture2.lck";
int fnum1;
int fnum2;
int i;
@@ -2989,6 +2989,7 @@ static struct {
{"W2K", run_w2ktest, 0},
{"TRANS2SCAN", torture_trans2_scan, 0},
{"NTTRANSSCAN", torture_nttrans_scan, 0},
+ {"UTABLE", torture_utable, 0},
{NULL, NULL, 0}};
diff --git a/source/torture/utable.c b/source/torture/utable.c
new file mode 100644
index 00000000000..c710815d9cd
--- /dev/null
+++ b/source/torture/utable.c
@@ -0,0 +1,82 @@
+/*
+ Unix SMB/Netbios implementation.
+ Version 3.0
+ SMB torture tester - unicode table dumper
+ Copyright (C) Andrew Tridgell 2001
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+*/
+
+#define NO_SYSLOG
+
+#include "includes.h"
+
+BOOL torture_utable(int dummy)
+{
+ static struct cli_state cli;
+ fstring fname, alt_name;
+ int fnum;
+ smb_ucs2_t c2;
+ int c, len;
+ int chars_allowed=0, alt_allowed=0;
+
+ printf("starting utable\n");
+
+ if (!torture_open_connection(&cli)) {
+ return False;
+ }
+
+ cli_mkdir(&cli, "\\utable");
+
+ for (c=1; c < 0x10000; c++) {
+ char *p;
+
+ SSVAL(&c2, 0, c);
+ fstrcpy(fname, "\\utable\\x");
+ p = fname+strlen(fname);
+ len = convert_string(CH_UCS2, CH_UNIX,
+ &c2, 2,
+ p, sizeof(fname)-strlen(fname));
+ p[len] = 0;
+ fstrcat(fname,"_a_long_extension");
+
+ fnum = cli_open(&cli, fname, O_RDWR | O_CREAT | O_TRUNC,
+ DENY_NONE);
+ if (fnum == -1) continue;
+
+ chars_allowed++;
+
+ cli_qpathinfo_alt_name(&cli, fname, alt_name);
+
+ if (strncmp(alt_name, "X_A_L", 5) != 0) {
+ alt_allowed++;
+ /* d_printf("fname=[%s] alt_name=[%s]\n", fname, alt_name); */
+ }
+
+ cli_close(&cli, fnum);
+ cli_unlink(&cli, fname);
+
+ if (c % 100 == 0) {
+ printf("%d (%d/%d)\r", c, chars_allowed, alt_allowed);
+ }
+ }
+ printf("%d (%d/%d)\n", c, chars_allowed, alt_allowed);
+
+ cli_rmdir(&cli, "\\utable");
+
+ d_printf("%d chars allowed %d alt chars allowed\n", chars_allowed, alt_allowed);
+
+ return True;
+}