2 Unix SMB/CIFS implementation.
3 chkpath individual test suite
4 Copyright (C) Andrew Tridgell 2003
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
18 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
22 #include "torture/torture.h"
23 #include "libcli/raw/libcliraw.h"
24 #include "libcli/libcli.h"
25 #include "torture/util.h"
27 #define BASEDIR "\\rawchkpath"
29 #define CHECK_STATUS(status, correct, dos_correct) do { \
30 if (!NT_STATUS_EQUAL(status, correct) && !NT_STATUS_EQUAL(status, dos_correct)) { \
31 printf("(%d) Incorrect status %s - should be %s\n", \
32 __LINE__, nt_errstr(status), nt_errstr(correct)); \
38 static NTSTATUS single_search(struct smbcli_state *cli,
39 TALLOC_CTX *mem_ctx, const char *pattern)
41 union smb_search_first io;
44 io.t2ffirst.level = RAW_SEARCH_TRANS2;
45 io.t2ffirst.data_level = RAW_SEARCH_DATA_STANDARD;
46 io.t2ffirst.in.search_attrib = 0;
47 io.t2ffirst.in.max_count = 1;
48 io.t2ffirst.in.flags = FLAG_TRANS2_FIND_CLOSE;
49 io.t2ffirst.in.storage_type = 0;
50 io.t2ffirst.in.pattern = pattern;
52 status = smb_raw_search_first(cli->tree, mem_ctx,
58 static BOOL test_path(struct smbcli_state *cli, const char *path, NTSTATUS expected, NTSTATUS dos_expected)
62 io.chkpath.in.path = path;
63 status = smb_raw_chkpath(cli->tree, &io);
64 if (!NT_STATUS_EQUAL(status, expected) && !NT_STATUS_EQUAL(status, dos_expected)) {
65 printf("%-40s FAILED %s should be %s or %s\n",
66 path, nt_errstr(status), nt_errstr(expected), nt_errstr(dos_expected));
69 printf("%-40s correct (%s)\n", path, nt_errstr(status));
75 static BOOL test_chkpath(struct smbcli_state *cli, TALLOC_CTX *mem_ctx)
83 io.chkpath.in.path = BASEDIR;
85 status = smb_raw_chkpath(cli->tree, &io);
86 CHECK_STATUS(status, NT_STATUS_OK, NT_STATUS_OK);
88 ret &= test_path(cli, BASEDIR "\\nodir", NT_STATUS_OBJECT_NAME_NOT_FOUND, NT_STATUS_DOS(ERRDOS,ERRbadpath));
90 fnum = create_complex_file(cli, mem_ctx, BASEDIR "\\test.txt..");
92 printf("failed to open test.txt - %s\n", smbcli_errstr(cli->tree));
97 ret &= test_path(cli, BASEDIR "\\test.txt..", NT_STATUS_NOT_A_DIRECTORY, NT_STATUS_DOS(ERRDOS,ERRbadpath));
99 if (!torture_set_file_attribute(cli->tree, BASEDIR, FILE_ATTRIBUTE_HIDDEN)) {
100 printf("failed to set basedir hidden\n");
105 ret &= test_path(cli, BASEDIR, NT_STATUS_OK, NT_STATUS_OK);
106 ret &= test_path(cli, BASEDIR "\\foo\\..\\test.txt..", NT_STATUS_NOT_A_DIRECTORY, NT_STATUS_DOS(ERRDOS,ERRbadpath));
107 ret &= test_path(cli, "", NT_STATUS_OK, NT_STATUS_OK);
108 ret &= test_path(cli, ".", NT_STATUS_OBJECT_NAME_INVALID, NT_STATUS_DOS(ERRDOS,ERRbadpath));
109 ret &= test_path(cli, ".\\", NT_STATUS_OBJECT_NAME_INVALID, NT_STATUS_DOS(ERRDOS,ERRbadpath));
110 ret &= test_path(cli, "\\\\\\.\\", NT_STATUS_OBJECT_NAME_INVALID, NT_STATUS_DOS(ERRDOS,ERRbadpath));
111 ret &= test_path(cli, ".\\.", NT_STATUS_OBJECT_PATH_NOT_FOUND, NT_STATUS_DOS(ERRDOS,ERRbadpath));
112 ret &= test_path(cli, "." BASEDIR, NT_STATUS_OBJECT_PATH_NOT_FOUND, NT_STATUS_DOS(ERRDOS,ERRbadpath));
113 ret &= test_path(cli, BASEDIR "\\.", NT_STATUS_OBJECT_NAME_INVALID, NT_STATUS_DOS(ERRDOS,ERRbadpath));
114 ret &= test_path(cli, BASEDIR "\\.\\test.txt..", NT_STATUS_OBJECT_PATH_NOT_FOUND, NT_STATUS_DOS(ERRDOS,ERRbadpath));
115 ret &= test_path(cli, ".\\.\\", NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
116 ret &= test_path(cli, ".\\.\\.", NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
117 ret &= test_path(cli, ".\\.\\.aaaaa", NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
118 ret &= test_path(cli, "\\.\\", NT_STATUS_OBJECT_NAME_INVALID,NT_STATUS_DOS(ERRDOS,ERRbadpath));
119 ret &= test_path(cli, "\\.\\\\", NT_STATUS_OBJECT_NAME_INVALID,NT_STATUS_DOS(ERRDOS,ERRbadpath));
120 ret &= test_path(cli, "\\.\\\\\\\\\\\\", NT_STATUS_OBJECT_NAME_INVALID,NT_STATUS_DOS(ERRDOS,ERRbadpath));
122 /* Note that the two following paths are identical but
123 give different NT status returns for chkpth and findfirst. */
125 printf("testing findfirst on %s\n", "\\.\\\\\\\\\\\\.");
126 status = single_search(cli, mem_ctx, "\\.\\\\\\\\\\\\.");
127 CHECK_STATUS(status, NT_STATUS_OBJECT_NAME_INVALID,NT_STATUS_DOS(ERRDOS,ERRinvalidname));
129 ret &= test_path(cli, "\\.\\\\\\\\\\\\.", NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
131 /* We expect this open to fail with the same error code as the chkpath below. */
132 printf("testing Open on %s\n", "\\.\\\\\\\\\\\\.");
133 /* findfirst seems to fail with a different error. */
134 fnum1 = smbcli_nt_create_full(cli->tree, "\\.\\\\\\\\\\\\.",
135 0, SEC_RIGHTS_FILE_ALL,
136 FILE_ATTRIBUTE_NORMAL,
137 NTCREATEX_SHARE_ACCESS_DELETE|
138 NTCREATEX_SHARE_ACCESS_READ|
139 NTCREATEX_SHARE_ACCESS_WRITE,
140 NTCREATEX_DISP_OVERWRITE_IF,
142 status = smbcli_nt_error(cli->tree);
143 CHECK_STATUS(status, NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
146 ret &= test_path(cli, "\\.\\\\xxx", NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
147 ret &= test_path(cli, "..\\..\\..", NT_STATUS_OBJECT_PATH_SYNTAX_BAD,NT_STATUS_DOS(ERRDOS,ERRinvalidpath));
148 ret &= test_path(cli, "\\..", NT_STATUS_OBJECT_PATH_SYNTAX_BAD,NT_STATUS_DOS(ERRDOS,ERRinvalidpath));
149 ret &= test_path(cli, "\\.\\\\\\\\\\\\xxx", NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
150 ret &= test_path(cli, BASEDIR"\\.\\", NT_STATUS_OBJECT_NAME_INVALID,NT_STATUS_DOS(ERRDOS,ERRbadpath));
151 ret &= test_path(cli, BASEDIR"\\.\\\\", NT_STATUS_OBJECT_NAME_INVALID,NT_STATUS_DOS(ERRDOS,ERRbadpath));
152 ret &= test_path(cli, BASEDIR"\\.\\nt", NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
153 ret &= test_path(cli, BASEDIR"\\.\\.\\nt", NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
154 ret &= test_path(cli, BASEDIR"\\nt", NT_STATUS_OK, NT_STATUS_OK);
155 ret &= test_path(cli, BASEDIR".\\foo", NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
156 ret &= test_path(cli, BASEDIR"xx\\foo", NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
157 ret &= test_path(cli, ".\\", NT_STATUS_OBJECT_NAME_INVALID,NT_STATUS_DOS(ERRDOS,ERRbadpath));
158 ret &= test_path(cli, ".\\.", NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
159 ret &= test_path(cli, ".\\.\\.\\.\\foo\\.\\.\\", NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
160 ret &= test_path(cli, BASEDIR".\\.\\.\\.\\foo\\.\\.\\", NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
161 ret &= test_path(cli, BASEDIR".\\.\\.\\.\\foo\\..\\.\\", NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
162 ret &= test_path(cli, BASEDIR".", NT_STATUS_OBJECT_NAME_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
163 ret &= test_path(cli, "\\", NT_STATUS_OK,NT_STATUS_OK);
164 ret &= test_path(cli, "\\.", NT_STATUS_OBJECT_NAME_INVALID,NT_STATUS_DOS(ERRDOS,ERRbadpath));
165 ret &= test_path(cli, "\\..\\", NT_STATUS_OBJECT_PATH_SYNTAX_BAD,NT_STATUS_DOS(ERRDOS,ERRinvalidpath));
166 ret &= test_path(cli, "\\..", NT_STATUS_OBJECT_PATH_SYNTAX_BAD,NT_STATUS_DOS(ERRDOS,ERRinvalidpath));
167 ret &= test_path(cli, BASEDIR "\\.", NT_STATUS_OBJECT_NAME_INVALID,NT_STATUS_DOS(ERRDOS,ERRbadpath));
168 ret &= test_path(cli, BASEDIR "\\..", NT_STATUS_OK,NT_STATUS_OK);
169 ret &= test_path(cli, BASEDIR "\\nt\\V S\\VB98\\vb600", NT_STATUS_OBJECT_NAME_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
170 ret &= test_path(cli, BASEDIR "\\nt\\V S\\VB98\\vb6.exe", NT_STATUS_NOT_A_DIRECTORY,NT_STATUS_DOS(ERRDOS,ERRbadpath));
172 /* We expect this open to fail with the same error code as the chkpath below. */
173 printf("testing Open on %s\n", BASEDIR".\\.\\.\\.\\foo\\..\\.\\");
174 /* findfirst seems to fail with a different error. */
175 fnum1 = smbcli_nt_create_full(cli->tree, BASEDIR".\\.\\.\\.\\foo\\..\\.\\",
176 0, SEC_RIGHTS_FILE_ALL,
177 FILE_ATTRIBUTE_NORMAL,
178 NTCREATEX_SHARE_ACCESS_DELETE|
179 NTCREATEX_SHARE_ACCESS_READ|
180 NTCREATEX_SHARE_ACCESS_WRITE,
181 NTCREATEX_DISP_OVERWRITE_IF,
183 status = smbcli_nt_error(cli->tree);
184 CHECK_STATUS(status, NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
186 printf("testing findfirst on %s\n", BASEDIR".\\.\\.\\.\\foo\\..\\.\\");
187 status = single_search(cli, mem_ctx, BASEDIR".\\.\\.\\.\\foo\\..\\.\\");
188 CHECK_STATUS(status, NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
190 /* We expect this open to fail with the same error code as the chkpath below. */
191 /* findfirst seems to fail with a different error. */
192 printf("testing Open on %s\n", BASEDIR "\\nt\\V S\\VB98\\vb6.exe\\3");
193 fnum1 = smbcli_nt_create_full(cli->tree, BASEDIR "\\nt\\V S\\VB98\\vb6.exe\\3",
194 0, SEC_RIGHTS_FILE_ALL,
195 FILE_ATTRIBUTE_NORMAL,
196 NTCREATEX_SHARE_ACCESS_DELETE|
197 NTCREATEX_SHARE_ACCESS_READ|
198 NTCREATEX_SHARE_ACCESS_WRITE,
199 NTCREATEX_DISP_OVERWRITE_IF,
201 status = smbcli_nt_error(cli->tree);
202 CHECK_STATUS(status, NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
204 ret &= test_path(cli, BASEDIR "\\nt\\V S\\VB98\\vb6.exe\\3", NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
205 ret &= test_path(cli, BASEDIR "\\nt\\V S\\VB98\\vb6.exe\\3\\foo", NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
206 ret &= test_path(cli, BASEDIR "\\nt\\3\\foo", NT_STATUS_OBJECT_PATH_NOT_FOUND,NT_STATUS_DOS(ERRDOS,ERRbadpath));
207 ret &= test_path(cli, BASEDIR "\\nt\\V S\\*\\vb6.exe\\3", NT_STATUS_OBJECT_NAME_INVALID,NT_STATUS_DOS(ERRDOS,ERRbadpath));
208 ret &= test_path(cli, BASEDIR "\\nt\\V S\\*\\*\\vb6.exe\\3", NT_STATUS_OBJECT_NAME_INVALID,NT_STATUS_DOS(ERRDOS,ERRbadpath));
211 smbcli_close(cli->tree, fnum);
216 basic testing of chkpath calls
218 BOOL torture_raw_chkpath(struct torture_context *torture)
220 struct smbcli_state *cli;
225 if (!torture_open_connection(&cli, 0)) {
229 mem_ctx = talloc_init("torture_raw_chkpath");
231 if (!torture_setup_dir(cli, BASEDIR)) {
235 if (NT_STATUS_IS_ERR(smbcli_mkdir(cli->tree, BASEDIR "\\nt"))) {
236 printf("Failed to create " BASEDIR " - %s\n", smbcli_errstr(cli->tree));
240 if (NT_STATUS_IS_ERR(smbcli_mkdir(cli->tree, BASEDIR "\\nt\\V S"))) {
241 printf("Failed to create " BASEDIR " - %s\n", smbcli_errstr(cli->tree));
245 if (NT_STATUS_IS_ERR(smbcli_mkdir(cli->tree, BASEDIR "\\nt\\V S\\VB98"))) {
246 printf("Failed to create " BASEDIR " - %s\n", smbcli_errstr(cli->tree));
250 fnum = create_complex_file(cli, mem_ctx, BASEDIR "\\nt\\V S\\VB98\\vb6.exe");
252 printf("failed to open \\nt\\V S\\VB98\\vb6.exe - %s\n", smbcli_errstr(cli->tree));
257 if (!test_chkpath(cli, mem_ctx)) {
263 smb_raw_exit(cli->session);
264 smbcli_deltree(cli->tree, BASEDIR);
266 torture_close_connection(cli);
267 talloc_free(mem_ctx);