Implement NtAccessCheck.
[wine/gsoc-2012-control.git] / dlls / kernel / tests / directory.c
blobccebad98698c3e820262d83c10e1fe1364d05dbf
1 /*
2 * Unit test suite for directory functions.
4 * Copyright 2002 Dmitry Timoshkov
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library 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 GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21 #include <stdarg.h>
23 #include "wine/test.h"
24 #include "windef.h"
25 #include "winbase.h"
26 #include "winerror.h"
28 /* If you change something in these tests, please do the same
29 * for GetSystemDirectory tests.
31 static void test_GetWindowsDirectoryA(void)
33 UINT len, len_with_null;
34 char buf[MAX_PATH];
36 len_with_null = GetWindowsDirectoryA(NULL, 0);
37 ok(len_with_null <= MAX_PATH, "should fit into MAX_PATH\n");
39 lstrcpyA(buf, "foo");
40 len_with_null = GetWindowsDirectoryA(buf, 1);
41 ok(lstrcmpA(buf, "foo") == 0, "should not touch the buffer\n");
43 lstrcpyA(buf, "foo");
44 len = GetWindowsDirectoryA(buf, len_with_null - 1);
45 ok(lstrcmpA(buf, "foo") == 0, "should not touch the buffer\n");
46 ok(len == len_with_null, "GetWindowsDirectoryW returned %d, expected %d\n",
47 len, len_with_null);
49 lstrcpyA(buf, "foo");
50 len = GetWindowsDirectoryA(buf, len_with_null);
51 ok(lstrcmpA(buf, "foo") != 0, "should touch the buffer\n");
52 ok(len == strlen(buf), "returned length should be equal to the length of string\n");
53 ok(len == len_with_null-1, "GetWindowsDirectoryA returned %d, expected %d\n",
54 len, len_with_null-1);
57 static void test_GetWindowsDirectoryW(void)
59 UINT len, len_with_null;
60 WCHAR buf[MAX_PATH];
61 static const WCHAR fooW[] = {'f','o','o',0};
63 len_with_null = GetWindowsDirectoryW(NULL, 0);
64 if (len_with_null==0 && GetLastError()==ERROR_CALL_NOT_IMPLEMENTED)
65 return;
66 ok(len_with_null <= MAX_PATH, "should fit into MAX_PATH\n");
68 lstrcpyW(buf, fooW);
69 len = GetWindowsDirectoryW(buf, 1);
70 ok(lstrcmpW(buf, fooW) == 0, "should not touch the buffer\n");
71 ok(len == len_with_null, "GetWindowsDirectoryW returned %d, expected %d\n",
72 len, len_with_null);
74 lstrcpyW(buf, fooW);
75 len = GetWindowsDirectoryW(buf, len_with_null - 1);
76 ok(lstrcmpW(buf, fooW) == 0, "should not touch the buffer\n");
77 ok(len == len_with_null, "GetWindowsDirectoryW returned %d, expected %d\n",
78 len, len_with_null);
80 lstrcpyW(buf, fooW);
81 len = GetWindowsDirectoryW(buf, len_with_null);
82 ok(lstrcmpW(buf, fooW) != 0, "should touch the buffer\n");
83 ok(len == lstrlenW(buf), "returned length should be equal to the length of string\n");
84 ok(len == len_with_null-1, "GetWindowsDirectoryW returned %d, expected %d\n",
85 len, len_with_null-1);
89 /* If you change something in these tests, please do the same
90 * for GetWindowsDirectory tests.
92 static void test_GetSystemDirectoryA(void)
94 UINT len, len_with_null;
95 char buf[MAX_PATH];
97 len_with_null = GetSystemDirectoryA(NULL, 0);
98 ok(len_with_null <= MAX_PATH, "should fit into MAX_PATH\n");
100 lstrcpyA(buf, "foo");
101 len = GetSystemDirectoryA(buf, 1);
102 ok(lstrcmpA(buf, "foo") == 0, "should not touch the buffer\n");
103 ok(len == len_with_null, "GetSystemDirectoryA returned %d, expected %d\n",
104 len, len_with_null);
106 lstrcpyA(buf, "foo");
107 len = GetSystemDirectoryA(buf, len_with_null - 1);
108 ok(lstrcmpA(buf, "foo") == 0, "should not touch the buffer\n");
109 ok(len == len_with_null, "GetSystemDirectoryA returned %d, expected %d\n",
110 len, len_with_null);
112 lstrcpyA(buf, "foo");
113 len = GetSystemDirectoryA(buf, len_with_null);
114 ok(lstrcmpA(buf, "foo") != 0, "should touch the buffer\n");
115 ok(len == strlen(buf), "returned length should be equal to the length of string\n");
116 ok(len == len_with_null-1, "GetSystemDirectoryW returned %d, expected %d\n",
117 len, len_with_null-1);
120 static void test_GetSystemDirectoryW(void)
122 UINT len, len_with_null;
123 WCHAR buf[MAX_PATH];
124 static const WCHAR fooW[] = {'f','o','o',0};
126 len_with_null = GetSystemDirectoryW(NULL, 0);
127 if (len_with_null==0 && GetLastError()==ERROR_CALL_NOT_IMPLEMENTED)
128 return;
129 ok(len_with_null <= MAX_PATH, "should fit into MAX_PATH\n");
131 lstrcpyW(buf, fooW);
132 len = GetSystemDirectoryW(buf, 1);
133 ok(lstrcmpW(buf, fooW) == 0, "should not touch the buffer\n");
134 ok(len == len_with_null, "GetSystemDirectoryW returned %d, expected %d\n",
135 len, len_with_null);
137 lstrcpyW(buf, fooW);
138 len = GetSystemDirectoryW(buf, len_with_null - 1);
139 ok(lstrcmpW(buf, fooW) == 0, "should not touch the buffer\n");
140 ok(len == len_with_null, "GetSystemDirectoryW returned %d, expected %d\n",
141 len, len_with_null);
143 lstrcpyW(buf, fooW);
144 len = GetSystemDirectoryW(buf, len_with_null);
145 ok(lstrcmpW(buf, fooW) != 0, "should touch the buffer\n");
146 ok(len == lstrlenW(buf), "returned length should be equal to the length of string\n");
147 ok(len == len_with_null-1, "GetSystemDirectoryW returned %d, expected %d\n",
148 len, len_with_null-1);
151 static void test_CreateDirectoryA(void)
153 char tmpdir[MAX_PATH];
154 BOOL ret;
156 ret = CreateDirectoryA(NULL, NULL);
157 ok(ret == FALSE && (GetLastError() == ERROR_PATH_NOT_FOUND ||
158 GetLastError() == ERROR_INVALID_PARAMETER),
159 "CreateDirectoryA(NULL,NULL): ret=%d error=%ld\n",ret,GetLastError());
161 ret = CreateDirectoryA("", NULL);
162 ok(ret == FALSE && (GetLastError() == ERROR_BAD_PATHNAME ||
163 GetLastError() == ERROR_PATH_NOT_FOUND),
164 "CreateDirectoryA(\"\",NULL): ret=%d error=%ld\n",ret,GetLastError());
166 ret = GetSystemDirectoryA(tmpdir, MAX_PATH);
167 ok(ret < MAX_PATH, "System directory should fit into MAX_PATH\n");
169 ret = SetCurrentDirectoryA(tmpdir);
170 ok(ret == TRUE, "could not chdir to the System directory\n");
172 ret = CreateDirectoryA(".", NULL);
173 ok(ret == FALSE && GetLastError() == ERROR_ALREADY_EXISTS, "should not create existing path\n");
175 ret = CreateDirectoryA("..", NULL);
176 ok(ret == FALSE && GetLastError() == ERROR_ALREADY_EXISTS, "should not create existing path\n");
178 GetTempPathA(MAX_PATH, tmpdir);
179 tmpdir[3] = 0; /* truncate the path */
180 ret = CreateDirectoryA(tmpdir, NULL);
181 ok(ret == FALSE && (GetLastError() == ERROR_ALREADY_EXISTS ||
182 GetLastError() == ERROR_ACCESS_DENIED),
183 "CreateDirectoryA(drive_root): ret=%d error=%ld\n",ret,GetLastError());
185 GetTempPathA(MAX_PATH, tmpdir);
186 lstrcatA(tmpdir, "Please Remove Me");
187 ret = CreateDirectoryA(tmpdir, NULL);
188 ok(ret == TRUE, "CreateDirectoryA should always succeed\n");
190 ret = CreateDirectoryA(tmpdir, NULL);
191 ok(ret == FALSE && GetLastError() == ERROR_ALREADY_EXISTS, "should not create existing path\n");
193 ret = RemoveDirectoryA(tmpdir);
194 ok(ret == TRUE, "RemoveDirectoryA should always succeed\n");
196 lstrcatA(tmpdir, "?");
197 ret = CreateDirectoryA(tmpdir, NULL);
198 ok(ret == FALSE && (GetLastError() == ERROR_INVALID_NAME ||
199 GetLastError() == ERROR_PATH_NOT_FOUND),
200 "CreateDirectoryA with ? wildcard name should fail, ret=%s error=%ld\n",
201 ret ? " True" : "False", GetLastError());
202 ret = RemoveDirectoryA(tmpdir);
204 tmpdir[lstrlenA(tmpdir) - 1] = '*';
205 ret = CreateDirectoryA(tmpdir, NULL);
206 ok(ret == FALSE && (GetLastError() == ERROR_INVALID_NAME ||
207 GetLastError() == ERROR_PATH_NOT_FOUND),
208 "CreateDirectoryA with * wildcard name should fail, ret=%s error=%ld\n",
209 ret ? " True" : "False", GetLastError());
210 ret = RemoveDirectoryA(tmpdir);
212 GetTempPathA(MAX_PATH, tmpdir);
213 lstrcatA(tmpdir, "Please Remove Me/Please Remove Me");
214 ret = CreateDirectoryA(tmpdir, NULL);
215 ok(ret == FALSE && GetLastError() == ERROR_PATH_NOT_FOUND,
216 "CreateDirectoryA with multiple nonexistent directories in path should fail\n");
217 ret = RemoveDirectoryA(tmpdir);
221 static void test_CreateDirectoryW(void)
223 WCHAR tmpdir[MAX_PATH];
224 BOOL ret;
225 static const WCHAR empty_strW[] = { 0 };
226 static const WCHAR tmp_dir_name[] = {'P','l','e','a','s','e',' ','R','e','m','o','v','e',' ','M','e',0};
227 static const WCHAR dotW[] = {'.',0};
228 static const WCHAR slashW[] = {'/',0};
229 static const WCHAR dotdotW[] = {'.','.',0};
230 static const WCHAR questionW[] = {'?',0};
232 ret = CreateDirectoryW(NULL, NULL);
233 if (!ret && GetLastError()==ERROR_CALL_NOT_IMPLEMENTED)
234 return;
235 ok(ret == FALSE && GetLastError() == ERROR_PATH_NOT_FOUND, "should not create NULL path\n");
237 ret = CreateDirectoryW(empty_strW, NULL);
238 ok(ret == FALSE && GetLastError() == ERROR_PATH_NOT_FOUND, "should not create empty path\n");
240 ret = GetSystemDirectoryW(tmpdir, MAX_PATH);
241 ok(ret < MAX_PATH, "System directory should fit into MAX_PATH\n");
243 ret = SetCurrentDirectoryW(tmpdir);
244 ok(ret == TRUE, "could not chdir to the System directory\n");
246 ret = CreateDirectoryW(dotW, NULL);
247 ok(ret == FALSE && GetLastError() == ERROR_ALREADY_EXISTS, "should not create existing path\n");
249 ret = CreateDirectoryW(dotdotW, NULL);
250 ok(ret == FALSE && GetLastError() == ERROR_ALREADY_EXISTS, "should not create existing path\n");
252 GetTempPathW(MAX_PATH, tmpdir);
253 tmpdir[3] = 0; /* truncate the path */
254 ret = CreateDirectoryW(tmpdir, NULL);
255 ok(ret == FALSE && GetLastError() == ERROR_ACCESS_DENIED, "should deny access to the drive root\n");
257 GetTempPathW(MAX_PATH, tmpdir);
258 lstrcatW(tmpdir, tmp_dir_name);
259 ret = CreateDirectoryW(tmpdir, NULL);
260 ok(ret == TRUE, "CreateDirectoryW should always succeed\n");
262 ret = CreateDirectoryW(tmpdir, NULL);
263 ok(ret == FALSE && GetLastError() == ERROR_ALREADY_EXISTS, "should not create existing path\n");
265 ret = RemoveDirectoryW(tmpdir);
266 ok(ret == TRUE, "RemoveDirectoryW should always succeed\n");
268 lstrcatW(tmpdir, questionW);
269 ret = CreateDirectoryW(tmpdir, NULL);
270 ok(ret == FALSE && GetLastError() == ERROR_INVALID_NAME,
271 "CreateDirectoryW with ? wildcard name should fail with error 183, ret=%s error=%ld\n",
272 ret ? " True" : "False", GetLastError());
273 ret = RemoveDirectoryW(tmpdir);
275 tmpdir[lstrlenW(tmpdir) - 1] = '*';
276 ret = CreateDirectoryW(tmpdir, NULL);
277 ok(ret == FALSE && GetLastError() == ERROR_INVALID_NAME,
278 "CreateDirectoryW with * wildcard name should fail with error 183, ret=%s error=%ld\n",
279 ret ? " True" : "False", GetLastError());
280 ret = RemoveDirectoryW(tmpdir);
282 GetTempPathW(MAX_PATH, tmpdir);
283 lstrcatW(tmpdir, tmp_dir_name);
284 lstrcatW(tmpdir, slashW);
285 lstrcatW(tmpdir, tmp_dir_name);
286 ret = CreateDirectoryW(tmpdir, NULL);
287 ok(ret == FALSE && GetLastError() == ERROR_PATH_NOT_FOUND,
288 "CreateDirectoryW with multiple nonexistent directories in path should fail\n");
289 ret = RemoveDirectoryW(tmpdir);
292 static void test_RemoveDirectoryA(void)
294 char tmpdir[MAX_PATH];
295 BOOL ret;
297 GetTempPathA(MAX_PATH, tmpdir);
298 lstrcatA(tmpdir, "Please Remove Me");
299 ret = CreateDirectoryA(tmpdir, NULL);
300 ok(ret == TRUE, "CreateDirectoryA should always succeed\n");
302 ret = RemoveDirectoryA(tmpdir);
303 ok(ret == TRUE, "RemoveDirectoryA should always succeed\n");
305 lstrcatA(tmpdir, "?");
306 ret = RemoveDirectoryA(tmpdir);
307 ok(ret == FALSE && (GetLastError() == ERROR_INVALID_NAME ||
308 GetLastError() == ERROR_PATH_NOT_FOUND),
309 "RemoveDirectoryA with ? wildcard name should fail, ret=%s error=%ld\n",
310 ret ? " True" : "False", GetLastError());
312 tmpdir[lstrlenA(tmpdir) - 1] = '*';
313 ret = RemoveDirectoryA(tmpdir);
314 ok(ret == FALSE && (GetLastError() == ERROR_INVALID_NAME ||
315 GetLastError() == ERROR_PATH_NOT_FOUND),
316 "RemoveDirectoryA with * wildcard name should fail, ret=%s error=%ld\n",
317 ret ? " True" : "False", GetLastError());
320 static void test_RemoveDirectoryW(void)
322 WCHAR tmpdir[MAX_PATH];
323 BOOL ret;
324 static const WCHAR tmp_dir_name[] = {'P','l','e','a','s','e',' ','R','e','m','o','v','e',' ','M','e',0};
325 static const WCHAR questionW[] = {'?',0};
327 GetTempPathW(MAX_PATH, tmpdir);
328 lstrcatW(tmpdir, tmp_dir_name);
329 ret = CreateDirectoryW(tmpdir, NULL);
330 if (!ret && GetLastError()==ERROR_CALL_NOT_IMPLEMENTED)
331 return;
333 ok(ret == TRUE, "CreateDirectoryW should always succeed\n");
335 ret = RemoveDirectoryW(tmpdir);
336 ok(ret == TRUE, "RemoveDirectoryW should always succeed\n");
338 lstrcatW(tmpdir, questionW);
339 ret = RemoveDirectoryW(tmpdir);
340 ok(ret == FALSE && GetLastError() == ERROR_INVALID_NAME,
341 "RemoveDirectoryW with wildcard should fail with error 183, ret=%s error=%ld\n",
342 ret ? " True" : "False", GetLastError());
344 tmpdir[lstrlenW(tmpdir) - 1] = '*';
345 ret = RemoveDirectoryW(tmpdir);
346 ok(ret == FALSE && GetLastError() == ERROR_INVALID_NAME,
347 "RemoveDirectoryW with * wildcard name should fail with error 183, ret=%s error=%ld\n",
348 ret ? " True" : "False", GetLastError());
351 static void test_SetCurrentDirectoryA(void)
353 SetLastError(0);
354 ok( !SetCurrentDirectoryA( "\\some_dummy_dir" ), "SetCurrentDirectoryA succeeded\n" );
355 ok( GetLastError() == ERROR_FILE_NOT_FOUND, "wrong error %ld\n", GetLastError() );
356 ok( !SetCurrentDirectoryA( "\\some_dummy\\subdir" ), "SetCurrentDirectoryA succeeded\n" );
357 ok( GetLastError() == ERROR_PATH_NOT_FOUND, "wrong error %ld\n", GetLastError() );
360 START_TEST(directory)
362 test_GetWindowsDirectoryA();
363 test_GetWindowsDirectoryW();
365 test_GetSystemDirectoryA();
366 test_GetSystemDirectoryW();
368 test_CreateDirectoryA();
369 test_CreateDirectoryW();
371 test_RemoveDirectoryA();
372 test_RemoveDirectoryW();
374 test_SetCurrentDirectoryA();