• Home
  • History
  • Annotate
  • Line#
  • Navigate
  • Raw
  • Download
  • only in /asuswrt-rt-n18u-9.0.0.4.380.2695/release/src-rt/router/samba-3.5.8/source4/torture/basic/
1/*
2   Unix SMB/CIFS implementation.
3
4   directory scanning tests
5
6   Copyright (C) Andrew Tridgell 2003
7
8   This program is free software; you can redistribute it and/or modify
9   it under the terms of the GNU General Public License as published by
10   the Free Software Foundation; either version 3 of the License, or
11   (at your option) any later version.
12
13   This program is distributed in the hope that it will be useful,
14   but WITHOUT ANY WARRANTY; without even the implied warranty of
15   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16   GNU General Public License for more details.
17
18   You should have received a copy of the GNU General Public License
19   along with this program.  If not, see <http://www.gnu.org/licenses/>.
20*/
21
22#include "includes.h"
23#include "libcli/libcli.h"
24#include "torture/torture.h"
25#include "torture/util.h"
26#include "system/filesys.h"
27
28static void list_fn(struct clilist_file_info *finfo, const char *name, void *state)
29{
30
31}
32
33/*
34  test directory listing speed
35 */
36bool torture_dirtest1(struct torture_context *tctx,
37		      struct smbcli_state *cli)
38{
39	int i;
40	int fnum;
41	bool correct = true;
42	extern int torture_numops;
43	struct timeval tv;
44
45	torture_comment(tctx, "Creating %d random filenames\n", torture_numops);
46
47	srandom(0);
48	tv = timeval_current();
49	for (i=0;i<torture_numops;i++) {
50		char *fname;
51		asprintf(&fname, "\\%x", (int)random());
52		fnum = smbcli_open(cli->tree, fname, O_RDWR|O_CREAT, DENY_NONE);
53		if (fnum == -1) {
54			fprintf(stderr,"(%s) Failed to open %s\n",
55				__location__, fname);
56			return false;
57		}
58		smbcli_close(cli->tree, fnum);
59		free(fname);
60	}
61
62	torture_comment(tctx, "Matched %d\n", smbcli_list(cli->tree, "a*.*", 0, list_fn, NULL));
63	torture_comment(tctx, "Matched %d\n", smbcli_list(cli->tree, "b*.*", 0, list_fn, NULL));
64	torture_comment(tctx, "Matched %d\n", smbcli_list(cli->tree, "xyzabc", 0, list_fn, NULL));
65
66	torture_comment(tctx, "dirtest core %g seconds\n", timeval_elapsed(&tv));
67
68	srandom(0);
69	for (i=0;i<torture_numops;i++) {
70		char *fname;
71		asprintf(&fname, "\\%x", (int)random());
72		smbcli_unlink(cli->tree, fname);
73		free(fname);
74	}
75
76	return correct;
77}
78
79bool torture_dirtest2(struct torture_context *tctx,
80		      struct smbcli_state *cli)
81{
82	int i;
83	int fnum, num_seen;
84	bool correct = true;
85	extern int torture_entries;
86
87	if (!torture_setup_dir(cli, "\\LISTDIR")) {
88		return false;
89	}
90
91	torture_comment(tctx, "Creating %d files\n", torture_entries);
92
93	/* Create torture_entries files and torture_entries directories. */
94	for (i=0;i<torture_entries;i++) {
95		char *fname;
96		asprintf(&fname, "\\LISTDIR\\f%d", i);
97		fnum = smbcli_nt_create_full(cli->tree, fname, 0,
98					     SEC_RIGHTS_FILE_ALL,
99					     FILE_ATTRIBUTE_ARCHIVE,
100					     NTCREATEX_SHARE_ACCESS_READ|NTCREATEX_SHARE_ACCESS_WRITE,
101					     NTCREATEX_DISP_OVERWRITE_IF, 0, 0);
102		if (fnum == -1) {
103			fprintf(stderr,"(%s) Failed to open %s, error=%s\n",
104				__location__, fname, smbcli_errstr(cli->tree));
105			return false;
106		}
107		free(fname);
108		smbcli_close(cli->tree, fnum);
109	}
110	for (i=0;i<torture_entries;i++) {
111		char *fname;
112		asprintf(&fname, "\\LISTDIR\\d%d", i);
113		if (NT_STATUS_IS_ERR(smbcli_mkdir(cli->tree, fname))) {
114			fprintf(stderr,"(%s) Failed to open %s, error=%s\n",
115				__location__, fname, smbcli_errstr(cli->tree));
116			return false;
117		}
118		free(fname);
119	}
120
121	/* Now ensure that doing an old list sees both files and directories. */
122	num_seen = smbcli_list_old(cli->tree, "\\LISTDIR\\*", FILE_ATTRIBUTE_DIRECTORY, list_fn, NULL);
123	torture_comment(tctx, "num_seen = %d\n", num_seen );
124	/* We should see (torture_entries) each of files & directories + . and .. */
125	if (num_seen != (2*torture_entries)+2) {
126		correct = false;
127		fprintf(stderr,"(%s) entry count mismatch, should be %d, was %d\n",
128			__location__, (2*torture_entries)+2, num_seen);
129	}
130
131
132	/* Ensure if we have the "must have" bits we only see the
133	 * relevant entries.
134	 */
135	num_seen = smbcli_list_old(cli->tree, "\\LISTDIR\\*", (FILE_ATTRIBUTE_DIRECTORY<<8)|FILE_ATTRIBUTE_DIRECTORY, list_fn, NULL);
136	torture_comment(tctx, "num_seen = %d\n", num_seen );
137	if (num_seen != torture_entries+2) {
138		correct = false;
139		fprintf(stderr,"(%s) entry count mismatch, should be %d, was %d\n",
140			__location__, torture_entries+2, num_seen);
141	}
142
143	num_seen = smbcli_list_old(cli->tree, "\\LISTDIR\\*", (FILE_ATTRIBUTE_ARCHIVE<<8)|FILE_ATTRIBUTE_DIRECTORY, list_fn, NULL);
144	torture_comment(tctx, "num_seen = %d\n", num_seen );
145	if (num_seen != torture_entries) {
146		correct = false;
147		fprintf(stderr,"(%s) entry count mismatch, should be %d, was %d\n",
148			__location__, torture_entries, num_seen);
149	}
150
151	/* Delete everything. */
152	if (smbcli_deltree(cli->tree, "\\LISTDIR") == -1) {
153		fprintf(stderr,"(%s) Failed to deltree %s, error=%s\n", "\\LISTDIR",
154			__location__, smbcli_errstr(cli->tree));
155		return false;
156	}
157
158#if 0
159	torture_comment(tctx, "Matched %d\n", smbcli_list(cli->tree, "a*.*", 0, list_fn, NULL));
160	torture_comment(tctx, "Matched %d\n", smbcli_list(cli->tree, "b*.*", 0, list_fn, NULL));
161	torture_comment(tctx, "Matched %d\n", smbcli_list(cli->tree, "xyzabc", 0, list_fn, NULL));
162#endif
163
164	return correct;
165}
166