2 * Unit test suite for object manager functions
4 * Copyright 2005 Robert Shearman
5 * Copyright 2005 Vitaliy Margolen
7 * This library is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation; either
10 * version 2.1 of the License, or (at your option) any later version.
12 * This library is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
17 * You should have received a copy of the GNU Lesser General Public
18 * License along with this library; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
22 #include "ntdll_test.h"
28 static HANDLE (WINAPI
*pCreateWaitableTimerA
)(SECURITY_ATTRIBUTES
*, BOOL
, LPCSTR
);
29 static BOOLEAN (WINAPI
*pRtlCreateUnicodeStringFromAsciiz
)(PUNICODE_STRING
, LPCSTR
);
30 static VOID (WINAPI
*pRtlInitUnicodeString
)( PUNICODE_STRING
, LPCWSTR
);
31 static VOID (WINAPI
*pRtlFreeUnicodeString
)(PUNICODE_STRING
);
32 static NTSTATUS (WINAPI
*pNtCreateEvent
) ( PHANDLE
, ACCESS_MASK
, const POBJECT_ATTRIBUTES
, BOOLEAN
, BOOLEAN
);
33 static NTSTATUS (WINAPI
*pNtOpenEvent
) ( PHANDLE
, ACCESS_MASK
, const POBJECT_ATTRIBUTES
);
34 static NTSTATUS (WINAPI
*pNtPulseEvent
) ( HANDLE
, PULONG
);
35 static NTSTATUS (WINAPI
*pNtQueryEvent
) ( HANDLE
, EVENT_INFORMATION_CLASS
, PVOID
, ULONG
, PULONG
);
36 static NTSTATUS (WINAPI
*pNtCreateJobObject
)( PHANDLE
, ACCESS_MASK
, POBJECT_ATTRIBUTES
);
37 static NTSTATUS (WINAPI
*pNtOpenJobObject
)( PHANDLE
, ACCESS_MASK
, POBJECT_ATTRIBUTES
);
38 static NTSTATUS (WINAPI
*pNtCreateKey
)( PHANDLE
, ACCESS_MASK
, POBJECT_ATTRIBUTES
, ULONG
,
39 const UNICODE_STRING
*, ULONG
, PULONG
);
40 static NTSTATUS (WINAPI
*pNtOpenKey
)( PHANDLE
, ACCESS_MASK
, POBJECT_ATTRIBUTES
);
41 static NTSTATUS (WINAPI
*pNtDeleteKey
)( HANDLE
);
42 static NTSTATUS (WINAPI
*pNtCreateMailslotFile
)( PHANDLE
, ACCESS_MASK
, POBJECT_ATTRIBUTES
, PIO_STATUS_BLOCK
,
43 ULONG
, ULONG
, ULONG
, PLARGE_INTEGER
);
44 static NTSTATUS (WINAPI
*pNtCreateMutant
)( PHANDLE
, ACCESS_MASK
, const POBJECT_ATTRIBUTES
, BOOLEAN
);
45 static NTSTATUS (WINAPI
*pNtOpenMutant
) ( PHANDLE
, ACCESS_MASK
, const POBJECT_ATTRIBUTES
);
46 static NTSTATUS (WINAPI
*pNtQueryMutant
) ( HANDLE
, MUTANT_INFORMATION_CLASS
, PVOID
, ULONG
, PULONG
);
47 static NTSTATUS (WINAPI
*pNtReleaseMutant
)( HANDLE
, PLONG
);
48 static NTSTATUS (WINAPI
*pNtCreateSemaphore
)( PHANDLE
, ACCESS_MASK
,const POBJECT_ATTRIBUTES
,LONG
,LONG
);
49 static NTSTATUS (WINAPI
*pNtOpenSemaphore
)( PHANDLE
, ACCESS_MASK
, const POBJECT_ATTRIBUTES
);
50 static NTSTATUS (WINAPI
*pNtCreateTimer
) ( PHANDLE
, ACCESS_MASK
, const POBJECT_ATTRIBUTES
, TIMER_TYPE
);
51 static NTSTATUS (WINAPI
*pNtOpenTimer
)( PHANDLE
, ACCESS_MASK
, const POBJECT_ATTRIBUTES
);
52 static NTSTATUS (WINAPI
*pNtCreateSection
)( PHANDLE
, ACCESS_MASK
, const POBJECT_ATTRIBUTES
, const PLARGE_INTEGER
,
53 ULONG
, ULONG
, HANDLE
);
54 static NTSTATUS (WINAPI
*pNtOpenSection
)( PHANDLE
, ACCESS_MASK
, POBJECT_ATTRIBUTES
);
55 static NTSTATUS (WINAPI
*pNtOpenFile
) ( PHANDLE
, ACCESS_MASK
, POBJECT_ATTRIBUTES
, PIO_STATUS_BLOCK
, ULONG
, ULONG
);
56 static NTSTATUS (WINAPI
*pNtClose
) ( HANDLE
);
57 static NTSTATUS (WINAPI
*pNtCreateNamedPipeFile
)( PHANDLE
, ULONG
, POBJECT_ATTRIBUTES
, PIO_STATUS_BLOCK
,
58 ULONG
, ULONG
, ULONG
, ULONG
, ULONG
, ULONG
, ULONG
, ULONG
, ULONG
, PLARGE_INTEGER
);
59 static NTSTATUS (WINAPI
*pNtOpenDirectoryObject
)(PHANDLE
, ACCESS_MASK
, POBJECT_ATTRIBUTES
);
60 static NTSTATUS (WINAPI
*pNtCreateDirectoryObject
)(PHANDLE
, ACCESS_MASK
, POBJECT_ATTRIBUTES
);
61 static NTSTATUS (WINAPI
*pNtOpenSymbolicLinkObject
)(PHANDLE
, ACCESS_MASK
, POBJECT_ATTRIBUTES
);
62 static NTSTATUS (WINAPI
*pNtCreateSymbolicLinkObject
)(PHANDLE
, ACCESS_MASK
, POBJECT_ATTRIBUTES
, PUNICODE_STRING
);
63 static NTSTATUS (WINAPI
*pNtQuerySymbolicLinkObject
)(HANDLE
,PUNICODE_STRING
,PULONG
);
64 static NTSTATUS (WINAPI
*pNtQueryObject
)(HANDLE
,OBJECT_INFORMATION_CLASS
,PVOID
,ULONG
,PULONG
);
65 static NTSTATUS (WINAPI
*pNtReleaseSemaphore
)(HANDLE
, ULONG
, PULONG
);
66 static NTSTATUS (WINAPI
*pNtCreateKeyedEvent
)( HANDLE
*, ACCESS_MASK
, const OBJECT_ATTRIBUTES
*, ULONG
);
67 static NTSTATUS (WINAPI
*pNtOpenKeyedEvent
)( HANDLE
*, ACCESS_MASK
, const OBJECT_ATTRIBUTES
* );
68 static NTSTATUS (WINAPI
*pNtWaitForKeyedEvent
)( HANDLE
, const void *, BOOLEAN
, const LARGE_INTEGER
* );
69 static NTSTATUS (WINAPI
*pNtReleaseKeyedEvent
)( HANDLE
, const void *, BOOLEAN
, const LARGE_INTEGER
* );
70 static NTSTATUS (WINAPI
*pNtCreateIoCompletion
)(PHANDLE
, ACCESS_MASK
, POBJECT_ATTRIBUTES
, ULONG
);
71 static NTSTATUS (WINAPI
*pNtOpenIoCompletion
)( PHANDLE
, ACCESS_MASK
, POBJECT_ATTRIBUTES
);
73 #define KEYEDEVENT_WAIT 0x0001
74 #define KEYEDEVENT_WAKE 0x0002
75 #define KEYEDEVENT_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED | 0x0003)
77 static void test_case_sensitive (void)
79 static const WCHAR buffer1
[] = {'\\','B','a','s','e','N','a','m','e','d','O','b','j','e','c','t','s','\\','t','e','s','t',0};
80 static const WCHAR buffer2
[] = {'\\','B','a','s','e','N','a','m','e','d','O','b','j','e','c','t','s','\\','T','e','s','t',0};
81 static const WCHAR buffer3
[] = {'\\','B','a','s','e','N','a','m','e','d','O','b','j','e','c','t','s','\\','T','E','s','t',0};
82 static const WCHAR buffer4
[] = {'\\','B','A','S','E','N','a','m','e','d','O','b','j','e','c','t','s','\\','t','e','s','t',0};
84 OBJECT_ATTRIBUTES attr
;
86 HANDLE Event
, Mutant
, h
;
88 pRtlInitUnicodeString(&str
, buffer1
);
89 InitializeObjectAttributes(&attr
, &str
, 0, 0, NULL
);
90 status
= pNtCreateMutant(&Mutant
, GENERIC_ALL
, &attr
, FALSE
);
91 ok(status
== STATUS_SUCCESS
, "Failed to create Mutant(%08x)\n", status
);
93 status
= pNtCreateEvent(&Event
, GENERIC_ALL
, &attr
, FALSE
, FALSE
);
94 ok(status
== STATUS_OBJECT_NAME_COLLISION
|| status
== STATUS_OBJECT_TYPE_MISMATCH
,
95 "NtCreateEvent should have failed with STATUS_OBJECT_NAME_COLLISION or STATUS_OBJECT_TYPE_MISMATCH got (%08x)\n", status
);
97 pRtlInitUnicodeString(&str
, buffer2
);
98 InitializeObjectAttributes(&attr
, &str
, 0, 0, NULL
);
99 status
= pNtCreateEvent(&Event
, GENERIC_ALL
, &attr
, FALSE
, FALSE
);
100 ok(status
== STATUS_SUCCESS
, "Failed to create Event(%08x)\n", status
);
102 pRtlInitUnicodeString(&str
, buffer3
);
103 InitializeObjectAttributes(&attr
, &str
, OBJ_CASE_INSENSITIVE
, 0, NULL
);
104 status
= pNtOpenMutant(&h
, GENERIC_ALL
, &attr
);
105 ok(status
== STATUS_OBJECT_TYPE_MISMATCH
,
106 "NtOpenMutant should have failed with STATUS_OBJECT_TYPE_MISMATCH got(%08x)\n", status
);
110 pRtlInitUnicodeString(&str
, buffer4
);
111 InitializeObjectAttributes(&attr
, &str
, OBJ_CASE_INSENSITIVE
, 0, NULL
);
112 status
= pNtCreateMutant(&Mutant
, GENERIC_ALL
, &attr
, FALSE
);
113 ok(status
== STATUS_OBJECT_NAME_COLLISION
|| status
== STATUS_OBJECT_TYPE_MISMATCH
,
114 "NtCreateMutant should have failed with STATUS_OBJECT_NAME_COLLISION or STATUS_OBJECT_TYPE_MISMATCH got (%08x)\n", status
);
116 status
= pNtCreateEvent(&h
, GENERIC_ALL
, &attr
, FALSE
, FALSE
);
117 ok(status
== STATUS_OBJECT_NAME_COLLISION
,
118 "NtCreateEvent should have failed with STATUS_OBJECT_NAME_COLLISION got(%08x)\n", status
);
121 status
= pNtCreateMutant(&Mutant
, GENERIC_ALL
, &attr
, FALSE
);
122 ok(status
== STATUS_OBJECT_PATH_NOT_FOUND
,
123 "NtCreateMutant should have failed with STATUS_OBJECT_PATH_NOT_FOUND got(%08x)\n", status
);
128 static void test_namespace_pipe(void)
130 static const WCHAR buffer1
[] = {'\\','?','?','\\','P','I','P','E','\\','t','e','s','t','\\','p','i','p','e',0};
131 static const WCHAR buffer2
[] = {'\\','?','?','\\','P','I','P','E','\\','T','E','S','T','\\','P','I','P','E',0};
132 static const WCHAR buffer3
[] = {'\\','?','?','\\','p','i','p','e','\\','t','e','s','t','\\','p','i','p','e',0};
133 static const WCHAR buffer4
[] = {'\\','?','?','\\','p','i','p','e','\\','t','e','s','t',0};
134 OBJECT_ATTRIBUTES attr
;
136 IO_STATUS_BLOCK iosb
;
138 LARGE_INTEGER timeout
;
141 timeout
.QuadPart
= -10000;
143 pRtlInitUnicodeString(&str
, buffer1
);
144 InitializeObjectAttributes(&attr
, &str
, 0, 0, NULL
);
145 status
= pNtCreateNamedPipeFile(&pipe
, GENERIC_READ
|GENERIC_WRITE
, &attr
, &iosb
, FILE_SHARE_READ
|FILE_SHARE_WRITE
,
146 FILE_CREATE
, FILE_PIPE_FULL_DUPLEX
, FALSE
, FALSE
, FALSE
, 1, 256, 256, &timeout
);
147 ok(status
== STATUS_SUCCESS
, "Failed to create NamedPipe(%08x)\n", status
);
149 status
= pNtCreateNamedPipeFile(&pipe
, GENERIC_READ
|GENERIC_WRITE
, &attr
, &iosb
, FILE_SHARE_READ
|FILE_SHARE_WRITE
,
150 FILE_CREATE
, FILE_PIPE_FULL_DUPLEX
, FALSE
, FALSE
, FALSE
, 1, 256, 256, &timeout
);
151 ok(status
== STATUS_INSTANCE_NOT_AVAILABLE
,
152 "NtCreateNamedPipeFile should have failed with STATUS_INSTANCE_NOT_AVAILABLE got(%08x)\n", status
);
154 pRtlInitUnicodeString(&str
, buffer2
);
155 InitializeObjectAttributes(&attr
, &str
, 0, 0, NULL
);
156 status
= pNtCreateNamedPipeFile(&pipe
, GENERIC_READ
|GENERIC_WRITE
, &attr
, &iosb
, FILE_SHARE_READ
|FILE_SHARE_WRITE
,
157 FILE_CREATE
, FILE_PIPE_FULL_DUPLEX
, FALSE
, FALSE
, FALSE
, 1, 256, 256, &timeout
);
158 ok(status
== STATUS_INSTANCE_NOT_AVAILABLE
,
159 "NtCreateNamedPipeFile should have failed with STATUS_INSTANCE_NOT_AVAILABLE got(%08x)\n", status
);
161 h
= CreateFileA("\\\\.\\pipe\\test\\pipe", GENERIC_READ
, FILE_SHARE_READ
|FILE_SHARE_WRITE
, NULL
,
162 OPEN_EXISTING
, 0, 0 );
163 ok(h
!= INVALID_HANDLE_VALUE
, "Failed to open NamedPipe (%u)\n", GetLastError());
166 pRtlInitUnicodeString(&str
, buffer3
);
167 InitializeObjectAttributes(&attr
, &str
, 0, 0, NULL
);
168 status
= pNtOpenFile(&h
, GENERIC_READ
, &attr
, &iosb
, FILE_SHARE_READ
|FILE_SHARE_WRITE
, 0);
169 ok(status
== STATUS_OBJECT_PATH_NOT_FOUND
||
170 status
== STATUS_PIPE_NOT_AVAILABLE
||
171 status
== STATUS_OBJECT_NAME_INVALID
|| /* vista */
172 status
== STATUS_OBJECT_NAME_NOT_FOUND
, /* win8 */
173 "NtOpenFile should have failed with STATUS_OBJECT_PATH_NOT_FOUND got(%08x)\n", status
);
175 pRtlInitUnicodeString(&str
, buffer4
);
176 InitializeObjectAttributes(&attr
, &str
, OBJ_CASE_INSENSITIVE
, 0, NULL
);
177 status
= pNtOpenFile(&h
, GENERIC_READ
, &attr
, &iosb
, FILE_SHARE_READ
|FILE_SHARE_WRITE
, 0);
178 ok(status
== STATUS_OBJECT_NAME_NOT_FOUND
||
179 status
== STATUS_OBJECT_NAME_INVALID
, /* vista */
180 "NtOpenFile should have failed with STATUS_OBJECT_NAME_NOT_FOUND got(%08x)\n", status
);
182 str
.Length
-= 4 * sizeof(WCHAR
);
183 status
= pNtOpenFile(&h
, GENERIC_READ
, &attr
, &iosb
, FILE_SHARE_READ
|FILE_SHARE_WRITE
, 0);
184 ok(status
== STATUS_SUCCESS
, "NtOpenFile should have succeeded got %08x\n", status
);
187 str
.Length
-= sizeof(WCHAR
);
188 status
= pNtOpenFile(&h
, GENERIC_READ
, &attr
, &iosb
, FILE_SHARE_READ
|FILE_SHARE_WRITE
, 0);
189 ok(status
== STATUS_SUCCESS
, "NtOpenFile should have succeeded got %08x\n", status
);
195 #define DIRECTORY_QUERY (0x0001)
196 #define SYMBOLIC_LINK_QUERY 0x0001
198 #define DIR_TEST_CREATE_OPEN(n,e) \
201 pRtlCreateUnicodeStringFromAsciiz(&str, n); \
202 status = pNtCreateDirectoryObject( &h, DIRECTORY_QUERY, &attr ); \
203 ok( status == e, "NtCreateDirectoryObject(%s) got %08x\n", n, status ); \
204 if (!status) pNtClose( h ); \
205 status = pNtOpenDirectoryObject( &h, DIRECTORY_QUERY, &attr ); \
206 ok( status == e, "NtOpenDirectoryObject(%s) got %08x\n", n, status ); \
207 if (!status) pNtClose( h ); \
208 pRtlFreeUnicodeString(&str); \
211 static BOOL
is_correct_dir( HANDLE dir
, const char *name
)
215 OBJECT_ATTRIBUTES attr
;
218 pRtlCreateUnicodeStringFromAsciiz(&str
, name
);
219 InitializeObjectAttributes(&attr
, &str
, OBJ_OPENIF
, dir
, NULL
);
220 status
= pNtCreateMutant(&h
, GENERIC_ALL
, &attr
, FALSE
);
221 pRtlFreeUnicodeString(&str
);
222 if (h
) pNtClose( h
);
223 return (status
== STATUS_OBJECT_NAME_EXISTS
);
226 /* return a handle to the BaseNamedObjects dir where kernel32 objects get created */
227 static HANDLE
get_base_dir(void)
229 static const char objname
[] = "om.c_get_base_dir_obj";
232 OBJECT_ATTRIBUTES attr
;
236 h
= CreateMutexA(NULL
, FALSE
, objname
);
237 ok(h
!= 0, "CreateMutexA failed got ret=%p (%d)\n", h
, GetLastError());
238 InitializeObjectAttributes(&attr
, &str
, OBJ_OPENIF
, 0, NULL
);
240 pRtlCreateUnicodeStringFromAsciiz(&str
, "\\BaseNamedObjects\\Local");
241 status
= pNtOpenDirectoryObject(&dir
, DIRECTORY_QUERY
, &attr
);
242 pRtlFreeUnicodeString(&str
);
243 if (!status
&& is_correct_dir( dir
, objname
)) goto done
;
244 if (!status
) pNtClose( dir
);
246 pRtlCreateUnicodeStringFromAsciiz(&str
, "\\BaseNamedObjects");
247 status
= pNtOpenDirectoryObject(&dir
, DIRECTORY_QUERY
, &attr
);
248 pRtlFreeUnicodeString(&str
);
249 if (!status
&& is_correct_dir( dir
, objname
)) goto done
;
250 if (!status
) pNtClose( dir
);
252 for (i
= 0; i
< 20; i
++)
255 sprintf( name
, "\\BaseNamedObjects\\Session\\%u", i
);
256 pRtlCreateUnicodeStringFromAsciiz(&str
, name
);
257 status
= pNtOpenDirectoryObject(&dir
, DIRECTORY_QUERY
, &attr
);
258 pRtlFreeUnicodeString(&str
);
259 if (!status
&& is_correct_dir( dir
, objname
)) goto done
;
260 if (!status
) pNtClose( dir
);
269 static void test_name_collisions(void)
273 OBJECT_ATTRIBUTES attr
;
274 HANDLE dir
, h
, h1
, h2
;
278 InitializeObjectAttributes(&attr
, &str
, 0, 0, NULL
);
279 pRtlCreateUnicodeStringFromAsciiz(&str
, "\\");
280 status
= pNtCreateDirectoryObject( &h
, DIRECTORY_QUERY
, &attr
);
281 ok( status
== STATUS_OBJECT_NAME_COLLISION
, "NtCreateDirectoryObject got %08x\n", status
);
282 InitializeObjectAttributes(&attr
, &str
, OBJ_OPENIF
, 0, NULL
);
284 status
= pNtCreateDirectoryObject( &h
, DIRECTORY_QUERY
, &attr
);
285 ok( status
== STATUS_OBJECT_NAME_EXISTS
, "NtCreateDirectoryObject got %08x\n", status
);
287 status
= pNtCreateMutant(&h
, GENERIC_ALL
, &attr
, FALSE
);
288 ok(status
== STATUS_OBJECT_TYPE_MISMATCH
,
289 "NtCreateMutant should have failed with STATUS_OBJECT_TYPE_MISMATCH got(%08x)\n", status
);
290 pRtlFreeUnicodeString(&str
);
292 pRtlCreateUnicodeStringFromAsciiz(&str
, "\\??\\PIPE\\om.c-mutant");
293 status
= pNtCreateMutant(&h
, GENERIC_ALL
, &attr
, FALSE
);
294 ok(status
== STATUS_OBJECT_TYPE_MISMATCH
|| status
== STATUS_OBJECT_PATH_NOT_FOUND
,
295 "NtCreateMutant should have failed with STATUS_OBJECT_TYPE_MISMATCH got(%08x)\n", status
);
296 pRtlFreeUnicodeString(&str
);
298 if (!(dir
= get_base_dir()))
300 win_skip( "couldn't find the BaseNamedObjects dir\n" );
303 pRtlCreateUnicodeStringFromAsciiz(&str
, "om.c-test");
304 InitializeObjectAttributes(&attr
, &str
, OBJ_OPENIF
, dir
, NULL
);
305 h
= CreateMutexA(NULL
, FALSE
, "om.c-test");
306 ok(h
!= 0, "CreateMutexA failed got ret=%p (%d)\n", h
, GetLastError());
307 status
= pNtCreateMutant(&h1
, GENERIC_ALL
, &attr
, FALSE
);
308 ok(status
== STATUS_OBJECT_NAME_EXISTS
&& h1
!= NULL
,
309 "NtCreateMutant should have succeeded with STATUS_OBJECT_NAME_EXISTS got(%08x)\n", status
);
310 h2
= CreateMutexA(NULL
, FALSE
, "om.c-test");
311 winerr
= GetLastError();
312 ok(h2
!= 0 && winerr
== ERROR_ALREADY_EXISTS
,
313 "CreateMutexA should have succeeded with ERROR_ALREADY_EXISTS got ret=%p (%d)\n", h2
, winerr
);
318 h
= CreateEventA(NULL
, FALSE
, FALSE
, "om.c-test");
319 ok(h
!= 0, "CreateEventA failed got ret=%p (%d)\n", h
, GetLastError());
320 status
= pNtCreateEvent(&h1
, GENERIC_ALL
, &attr
, FALSE
, FALSE
);
321 ok(status
== STATUS_OBJECT_NAME_EXISTS
&& h1
!= NULL
,
322 "NtCreateEvent should have succeeded with STATUS_OBJECT_NAME_EXISTS got(%08x)\n", status
);
323 h2
= CreateEventA(NULL
, FALSE
, FALSE
, "om.c-test");
324 winerr
= GetLastError();
325 ok(h2
!= 0 && winerr
== ERROR_ALREADY_EXISTS
,
326 "CreateEventA should have succeeded with ERROR_ALREADY_EXISTS got ret=%p (%d)\n", h2
, winerr
);
331 h
= CreateSemaphoreA(NULL
, 1, 2, "om.c-test");
332 ok(h
!= 0, "CreateSemaphoreA failed got ret=%p (%d)\n", h
, GetLastError());
333 status
= pNtCreateSemaphore(&h1
, GENERIC_ALL
, &attr
, 1, 2);
334 ok(status
== STATUS_OBJECT_NAME_EXISTS
&& h1
!= NULL
,
335 "NtCreateSemaphore should have succeeded with STATUS_OBJECT_NAME_EXISTS got(%08x)\n", status
);
336 h2
= CreateSemaphoreA(NULL
, 1, 2, "om.c-test");
337 winerr
= GetLastError();
338 ok(h2
!= 0 && winerr
== ERROR_ALREADY_EXISTS
,
339 "CreateSemaphoreA should have succeeded with ERROR_ALREADY_EXISTS got ret=%p (%d)\n", h2
, winerr
);
344 h
= pCreateWaitableTimerA(NULL
, TRUE
, "om.c-test");
345 ok(h
!= 0, "CreateWaitableTimerA failed got ret=%p (%d)\n", h
, GetLastError());
346 status
= pNtCreateTimer(&h1
, GENERIC_ALL
, &attr
, NotificationTimer
);
347 ok(status
== STATUS_OBJECT_NAME_EXISTS
&& h1
!= NULL
,
348 "NtCreateTimer should have succeeded with STATUS_OBJECT_NAME_EXISTS got(%08x)\n", status
);
349 h2
= pCreateWaitableTimerA(NULL
, TRUE
, "om.c-test");
350 winerr
= GetLastError();
351 ok(h2
!= 0 && winerr
== ERROR_ALREADY_EXISTS
,
352 "CreateWaitableTimerA should have succeeded with ERROR_ALREADY_EXISTS got ret=%p (%d)\n", h2
, winerr
);
357 h
= CreateFileMappingA(INVALID_HANDLE_VALUE
, NULL
, PAGE_READWRITE
, 0, 256, "om.c-test");
358 ok(h
!= 0, "CreateFileMappingA failed got ret=%p (%d)\n", h
, GetLastError());
359 size
.u
.LowPart
= 256;
361 status
= pNtCreateSection(&h1
, SECTION_MAP_WRITE
, &attr
, &size
, PAGE_READWRITE
, SEC_COMMIT
, 0);
362 ok(status
== STATUS_OBJECT_NAME_EXISTS
&& h1
!= NULL
,
363 "NtCreateSection should have succeeded with STATUS_OBJECT_NAME_EXISTS got(%08x)\n", status
);
364 h2
= CreateFileMappingA(INVALID_HANDLE_VALUE
, NULL
, PAGE_READWRITE
, 0, 256, "om.c-test");
365 winerr
= GetLastError();
366 ok(h2
!= 0 && winerr
== ERROR_ALREADY_EXISTS
,
367 "CreateFileMappingA should have succeeded with ERROR_ALREADY_EXISTS got ret=%p (%d)\n", h2
, winerr
);
372 pRtlFreeUnicodeString(&str
);
376 static void test_all_kernel_objects( UINT line
, OBJECT_ATTRIBUTES
*attr
,
377 NTSTATUS create_expect
, NTSTATUS open_expect
)
379 UNICODE_STRING target
;
381 NTSTATUS status
, status2
;
384 pRtlCreateUnicodeStringFromAsciiz( &target
, "\\DosDevices" );
385 size
.QuadPart
= 4096;
387 status
= pNtCreateMutant( &ret
, GENERIC_ALL
, attr
, FALSE
);
388 ok( status
== create_expect
, "%u: NtCreateMutant failed %x\n", line
, status
);
389 status2
= pNtOpenMutant( &ret2
, GENERIC_ALL
, attr
);
390 ok( status2
== open_expect
, "%u: NtOpenMutant failed %x\n", line
, status2
);
391 if (!status
) pNtClose( ret
);
392 if (!status2
) pNtClose( ret2
);
393 status
= pNtCreateSemaphore( &ret
, GENERIC_ALL
, attr
, 1, 2 );
394 ok( status
== create_expect
, "%u: NtCreateSemaphore failed %x\n", line
, status
);
395 status2
= pNtOpenSemaphore( &ret2
, GENERIC_ALL
, attr
);
396 ok( status2
== open_expect
, "%u: NtOpenSemaphore failed %x\n", line
, status2
);
397 if (!status
) pNtClose( ret
);
398 if (!status2
) pNtClose( ret2
);
399 status
= pNtCreateEvent( &ret
, GENERIC_ALL
, attr
, 1, 0 );
400 ok( status
== create_expect
, "%u: NtCreateEvent failed %x\n", line
, status
);
401 status2
= pNtOpenEvent( &ret2
, GENERIC_ALL
, attr
);
402 ok( status2
== open_expect
, "%u: NtOpenEvent failed %x\n", line
, status2
);
403 if (!status
) pNtClose( ret
);
404 if (!status2
) pNtClose( ret2
);
405 status
= pNtCreateKeyedEvent( &ret
, GENERIC_ALL
, attr
, 0 );
406 ok( status
== create_expect
, "%u: NtCreateKeyedEvent failed %x\n", line
, status
);
407 status2
= pNtOpenKeyedEvent( &ret2
, GENERIC_ALL
, attr
);
408 ok( status2
== open_expect
, "%u: NtOpenKeyedEvent failed %x\n", line
, status2
);
409 if (!status
) pNtClose( ret
);
410 if (!status2
) pNtClose( ret2
);
411 status
= pNtCreateTimer( &ret
, GENERIC_ALL
, attr
, NotificationTimer
);
412 ok( status
== create_expect
, "%u: NtCreateTimer failed %x\n", line
, status
);
413 status2
= pNtOpenTimer( &ret2
, GENERIC_ALL
, attr
);
414 ok( status2
== open_expect
, "%u: NtOpenTimer failed %x\n", line
, status2
);
415 if (!status
) pNtClose( ret
);
416 if (!status2
) pNtClose( ret2
);
417 status
= pNtCreateIoCompletion( &ret
, GENERIC_ALL
, attr
, 0 );
418 ok( status
== create_expect
, "%u: NtCreateCompletion failed %x\n", line
, status
);
419 status2
= pNtOpenIoCompletion( &ret2
, GENERIC_ALL
, attr
);
420 ok( status2
== open_expect
, "%u: NtOpenCompletion failed %x\n", line
, status2
);
421 if (!status
) pNtClose( ret
);
422 if (!status2
) pNtClose( ret2
);
423 status
= pNtCreateJobObject( &ret
, GENERIC_ALL
, attr
);
424 ok( status
== create_expect
, "%u: NtCreateJobObject failed %x\n", line
, status
);
425 status2
= pNtOpenJobObject( &ret2
, GENERIC_ALL
, attr
);
426 ok( status2
== open_expect
, "%u: NtOpenJobObject failed %x\n", line
, status2
);
427 if (!status
) pNtClose( ret
);
428 if (!status2
) pNtClose( ret2
);
429 status
= pNtCreateDirectoryObject( &ret
, GENERIC_ALL
, attr
);
430 ok( status
== create_expect
, "%u: NtCreateDirectoryObject failed %x\n", line
, status
);
431 status2
= pNtOpenDirectoryObject( &ret2
, GENERIC_ALL
, attr
);
432 ok( status2
== open_expect
, "%u: NtOpenDirectoryObject failed %x\n", line
, status2
);
433 if (!status
) pNtClose( ret
);
434 if (!status2
) pNtClose( ret2
);
435 status
= pNtCreateSymbolicLinkObject( &ret
, GENERIC_ALL
, attr
, &target
);
436 ok( status
== create_expect
, "%u: NtCreateSymbolicLinkObject failed %x\n", line
, status
);
437 status2
= pNtOpenSymbolicLinkObject( &ret2
, GENERIC_ALL
, attr
);
438 ok( status2
== open_expect
, "%u: NtOpenSymbolicLinkObject failed %x\n", line
, status2
);
439 if (!status
) pNtClose( ret
);
440 if (!status2
) pNtClose( ret2
);
441 status
= pNtCreateSection( &ret
, SECTION_MAP_WRITE
, attr
, &size
, PAGE_READWRITE
, SEC_COMMIT
, 0 );
442 ok( status
== create_expect
, "%u: NtCreateSection failed %x\n", line
, status
);
443 status2
= pNtOpenSection( &ret2
, SECTION_MAP_WRITE
, attr
);
444 ok( status2
== open_expect
, "%u: NtOpenSection failed %x\n", line
, status2
);
445 if (!status
) pNtClose( ret
);
446 if (!status2
) pNtClose( ret2
);
447 pRtlFreeUnicodeString( &target
);
450 static void test_name_limits(void)
452 static const WCHAR localW
[] = {'\\','B','a','s','e','N','a','m','e','d','O','b','j','e','c','t','s','\\','L','o','c','a','l',0};
453 static const WCHAR pipeW
[] = {'\\','D','e','v','i','c','e','\\','N','a','m','e','d','P','i','p','e','\\'};
454 static const WCHAR mailslotW
[] = {'\\','D','e','v','i','c','e','\\','M','a','i','l','S','l','o','t','\\'};
455 static const WCHAR registryW
[] = {'\\','R','E','G','I','S','T','R','Y','\\','M','a','c','h','i','n','e','\\','S','O','F','T','W','A','R','E','\\','M','i','c','r','o','s','o','f','t','\\'};
456 OBJECT_ATTRIBUTES attr
, attr2
, attr3
;
457 IO_STATUS_BLOCK iosb
;
458 LARGE_INTEGER size
, timeout
;
459 UNICODE_STRING str
, str2
, target
;
464 InitializeObjectAttributes( &attr
, &str
, 0, 0, NULL
);
465 InitializeObjectAttributes( &attr2
, &str
, 0, (HANDLE
)0xdeadbeef, NULL
);
466 InitializeObjectAttributes( &attr3
, &str
, 0, 0, NULL
);
467 str
.Buffer
= HeapAlloc( GetProcessHeap(), 0, 65536 + sizeof(registryW
));
468 str
.MaximumLength
= 65534;
469 for (i
= 0; i
< 65536 / sizeof(WCHAR
); i
++) str
.Buffer
[i
] = 'a';
470 size
.QuadPart
= 4096;
471 pRtlCreateUnicodeStringFromAsciiz( &target
, "\\DosDevices" );
473 if (!(attr
.RootDirectory
= get_base_dir()))
475 win_skip( "couldn't find the BaseNamedObjects dir\n" );
480 status
= pNtCreateMutant( &ret
, GENERIC_ALL
, &attr2
, FALSE
);
481 ok( status
== STATUS_SUCCESS
, "%u: NtCreateMutant failed %x\n", str
.Length
, status
);
482 attr3
.RootDirectory
= ret
;
483 status
= pNtOpenMutant( &ret2
, GENERIC_ALL
, &attr
);
484 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
, "%u: NtOpenMutant failed %x\n", str
.Length
, status
);
485 status
= pNtOpenMutant( &ret2
, GENERIC_ALL
, &attr3
);
486 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
|| status
== STATUS_INVALID_HANDLE
,
487 "%u: NtOpenMutant failed %x\n", str
.Length
, status
);
489 status
= pNtCreateSemaphore( &ret
, GENERIC_ALL
, &attr2
, 1, 2 );
490 ok( status
== STATUS_SUCCESS
, "%u: NtCreateSemaphore failed %x\n", str
.Length
, status
);
491 attr3
.RootDirectory
= ret
;
492 status
= pNtOpenSemaphore( &ret2
, GENERIC_ALL
, &attr
);
493 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
, "%u: NtOpenSemaphore failed %x\n", str
.Length
, status
);
494 status
= pNtOpenSemaphore( &ret2
, GENERIC_ALL
, &attr3
);
495 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
|| status
== STATUS_INVALID_HANDLE
,
496 "%u: NtOpenSemaphore failed %x\n", str
.Length
, status
);
498 status
= pNtCreateEvent( &ret
, GENERIC_ALL
, &attr2
, 1, 0 );
499 ok( status
== STATUS_SUCCESS
, "%u: NtCreateEvent failed %x\n", str
.Length
, status
);
500 attr3
.RootDirectory
= ret
;
501 status
= pNtOpenEvent( &ret2
, GENERIC_ALL
, &attr
);
502 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
, "%u: NtOpenEvent failed %x\n", str
.Length
, status
);
503 status
= pNtOpenEvent( &ret2
, GENERIC_ALL
, &attr3
);
504 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
|| status
== STATUS_INVALID_HANDLE
,
505 "%u: NtOpenEvent failed %x\n", str
.Length
, status
);
507 status
= pNtCreateKeyedEvent( &ret
, GENERIC_ALL
, &attr2
, 0 );
508 ok( status
== STATUS_SUCCESS
, "%u: NtCreateKeyedEvent failed %x\n", str
.Length
, status
);
509 attr3
.RootDirectory
= ret
;
510 status
= pNtOpenKeyedEvent( &ret2
, GENERIC_ALL
, &attr
);
511 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
, "%u: NtOpenKeyedEvent failed %x\n", str
.Length
, status
);
512 status
= pNtOpenKeyedEvent( &ret2
, GENERIC_ALL
, &attr3
);
513 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
|| status
== STATUS_INVALID_HANDLE
,
514 "%u: NtOpenKeyedEvent failed %x\n", str
.Length
, status
);
516 status
= pNtCreateTimer( &ret
, GENERIC_ALL
, &attr2
, NotificationTimer
);
517 ok( status
== STATUS_SUCCESS
, "%u: NtCreateTimer failed %x\n", str
.Length
, status
);
518 attr3
.RootDirectory
= ret
;
519 status
= pNtOpenTimer( &ret2
, GENERIC_ALL
, &attr
);
520 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
, "%u: NtOpenTimer failed %x\n", str
.Length
, status
);
521 status
= pNtOpenTimer( &ret2
, GENERIC_ALL
, &attr3
);
522 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
|| status
== STATUS_INVALID_HANDLE
,
523 "%u: NtOpenTimer failed %x\n", str
.Length
, status
);
525 status
= pNtCreateIoCompletion( &ret
, GENERIC_ALL
, &attr2
, 0 );
526 ok( status
== STATUS_SUCCESS
, "%u: NtCreateCompletion failed %x\n", str
.Length
, status
);
527 attr3
.RootDirectory
= ret
;
528 status
= pNtOpenIoCompletion( &ret2
, GENERIC_ALL
, &attr
);
529 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
, "%u: NtOpenCompletion failed %x\n", str
.Length
, status
);
530 status
= pNtOpenIoCompletion( &ret2
, GENERIC_ALL
, &attr3
);
531 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
|| status
== STATUS_INVALID_HANDLE
,
532 "%u: NtOpenCompletion failed %x\n", str
.Length
, status
);
534 status
= pNtCreateJobObject( &ret
, GENERIC_ALL
, &attr2
);
535 ok( status
== STATUS_SUCCESS
, "%u: NtCreateJobObject failed %x\n", str
.Length
, status
);
536 attr3
.RootDirectory
= ret
;
537 status
= pNtOpenJobObject( &ret2
, GENERIC_ALL
, &attr
);
538 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
, "%u: NtOpenJobObject failed %x\n", str
.Length
, status
);
539 status
= pNtOpenJobObject( &ret2
, GENERIC_ALL
, &attr3
);
540 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
|| status
== STATUS_INVALID_HANDLE
,
541 "%u: NtOpenJobObject failed %x\n", str
.Length
, status
);
543 status
= pNtCreateDirectoryObject( &ret
, GENERIC_ALL
, &attr2
);
544 ok( status
== STATUS_SUCCESS
, "%u: NtCreateDirectoryObject failed %x\n", str
.Length
, status
);
545 attr3
.RootDirectory
= ret
;
546 status
= pNtOpenDirectoryObject( &ret2
, GENERIC_ALL
, &attr
);
547 ok( status
== STATUS_SUCCESS
|| broken(status
== STATUS_ACCESS_DENIED
), /* winxp */
548 "%u: NtOpenDirectoryObject failed %x\n", str
.Length
, status
);
549 if (!status
) pNtClose( ret2
);
550 status
= pNtOpenDirectoryObject( &ret2
, GENERIC_ALL
, &attr3
);
551 ok( status
== STATUS_SUCCESS
, "%u: NtOpenDirectoryObject failed %x\n", str
.Length
, status
);
554 status
= pNtCreateSymbolicLinkObject( &ret
, GENERIC_ALL
, &attr2
, &target
);
555 ok( status
== STATUS_SUCCESS
, "%u: NtCreateSymbolicLinkObject failed %x\n", str
.Length
, status
);
556 attr3
.RootDirectory
= ret
;
557 status
= pNtOpenSymbolicLinkObject( &ret2
, GENERIC_ALL
, &attr
);
558 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
, "%u: NtOpenSymbolicLinkObject failed %x\n", str
.Length
, status
);
559 status
= pNtOpenSymbolicLinkObject( &ret2
, GENERIC_ALL
, &attr3
);
560 ok( status
== STATUS_SUCCESS
, "%u: NtOpenSymbolicLinkObject failed %x\n", str
.Length
, status
);
563 status
= pNtCreateSection( &ret
, SECTION_MAP_WRITE
, &attr2
, &size
, PAGE_READWRITE
, SEC_COMMIT
, 0 );
564 ok( status
== STATUS_SUCCESS
, "%u: NtCreateSection failed %x\n", str
.Length
, status
);
565 attr3
.RootDirectory
= ret
;
566 status
= pNtOpenSection( &ret2
, SECTION_MAP_WRITE
, &attr
);
567 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
, "%u: NtOpenSection failed %x\n", str
.Length
, status
);
568 status
= pNtOpenSection( &ret2
, SECTION_MAP_WRITE
, &attr3
);
569 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
|| status
== STATUS_INVALID_HANDLE
,
570 "%u: NtOpenSection failed %x\n", str
.Length
, status
);
574 test_all_kernel_objects( __LINE__
, &attr2
, STATUS_OBJECT_NAME_INVALID
, STATUS_OBJECT_NAME_INVALID
);
577 test_all_kernel_objects( __LINE__
, &attr
, STATUS_SUCCESS
, STATUS_SUCCESS
);
580 test_all_kernel_objects( __LINE__
, &attr
, STATUS_OBJECT_NAME_INVALID
, STATUS_OBJECT_NAME_INVALID
);
583 for (attr
.Length
= 0; attr
.Length
<= 2 * sizeof(attr
); attr
.Length
++)
585 if (attr
.Length
== sizeof(attr
))
586 test_all_kernel_objects( __LINE__
, &attr
, STATUS_SUCCESS
, STATUS_SUCCESS
);
588 test_all_kernel_objects( __LINE__
, &attr
, STATUS_INVALID_PARAMETER
, STATUS_INVALID_PARAMETER
);
590 attr
.Length
= sizeof(attr
);
592 /* null attributes or ObjectName, with or without RootDirectory */
593 attr3
.RootDirectory
= 0;
594 attr2
.ObjectName
= attr3
.ObjectName
= NULL
;
595 test_all_kernel_objects( __LINE__
, &attr2
, STATUS_OBJECT_NAME_INVALID
, STATUS_OBJECT_NAME_INVALID
);
596 test_all_kernel_objects( __LINE__
, &attr3
, STATUS_SUCCESS
, STATUS_OBJECT_PATH_SYNTAX_BAD
);
598 attr3
.ObjectName
= &str2
;
599 pRtlInitUnicodeString( &str2
, localW
);
600 status
= pNtOpenSymbolicLinkObject( &ret
, SYMBOLIC_LINK_QUERY
, &attr3
);
601 ok( status
== STATUS_SUCCESS
, "can't open BaseNamedObjects\\Local %x\n", status
);
602 attr3
.ObjectName
= &str
;
603 attr3
.RootDirectory
= ret
;
604 test_all_kernel_objects( __LINE__
, &attr3
, STATUS_OBJECT_TYPE_MISMATCH
, STATUS_OBJECT_TYPE_MISMATCH
);
605 pNtClose( attr3
.RootDirectory
);
607 status
= pNtCreateMutant( &ret
, GENERIC_ALL
, NULL
, FALSE
);
608 ok( status
== STATUS_SUCCESS
, "NULL: NtCreateMutant failed %x\n", status
);
610 status
= pNtOpenMutant( &ret
, GENERIC_ALL
, NULL
);
611 ok( status
== STATUS_INVALID_PARAMETER
, "NULL: NtOpenMutant failed %x\n", status
);
612 status
= pNtCreateSemaphore( &ret
, GENERIC_ALL
, NULL
, 1, 2 );
613 ok( status
== STATUS_SUCCESS
, "NULL: NtCreateSemaphore failed %x\n", status
);
615 status
= pNtOpenSemaphore( &ret
, GENERIC_ALL
, NULL
);
616 ok( status
== STATUS_INVALID_PARAMETER
, "NULL: NtOpenSemaphore failed %x\n", status
);
617 status
= pNtCreateEvent( &ret
, GENERIC_ALL
, NULL
, 1, 0 );
618 ok( status
== STATUS_SUCCESS
, "NULL: NtCreateEvent failed %x\n", status
);
620 status
= pNtOpenEvent( &ret
, GENERIC_ALL
, NULL
);
621 ok( status
== STATUS_INVALID_PARAMETER
, "NULL: NtOpenEvent failed %x\n", status
);
622 status
= pNtCreateKeyedEvent( &ret
, GENERIC_ALL
, NULL
, 0 );
623 ok( status
== STATUS_SUCCESS
, "NULL: NtCreateKeyedEvent failed %x\n", status
);
625 status
= pNtOpenKeyedEvent( &ret
, GENERIC_ALL
, NULL
);
626 ok( status
== STATUS_INVALID_PARAMETER
, "NULL: NtOpenKeyedEvent failed %x\n", status
);
627 status
= pNtCreateTimer( &ret
, GENERIC_ALL
, NULL
, NotificationTimer
);
628 ok( status
== STATUS_SUCCESS
, "NULL: NtCreateTimer failed %x\n", status
);
630 status
= pNtOpenTimer( &ret
, GENERIC_ALL
, NULL
);
631 ok( status
== STATUS_INVALID_PARAMETER
, "NULL: NtOpenTimer failed %x\n", status
);
632 status
= pNtCreateIoCompletion( &ret
, GENERIC_ALL
, NULL
, 0 );
633 ok( status
== STATUS_SUCCESS
, "NULL: NtCreateCompletion failed %x\n", status
);
635 status
= pNtOpenIoCompletion( &ret
, GENERIC_ALL
, NULL
);
636 ok( status
== STATUS_INVALID_PARAMETER
, "NULL: NtOpenCompletion failed %x\n", status
);
637 status
= pNtCreateJobObject( &ret
, GENERIC_ALL
, NULL
);
638 ok( status
== STATUS_SUCCESS
, "NULL: NtCreateJobObject failed %x\n", status
);
640 status
= pNtOpenJobObject( &ret
, GENERIC_ALL
, NULL
);
641 ok( status
== STATUS_INVALID_PARAMETER
, "NULL: NtOpenJobObject failed %x\n", status
);
642 status
= pNtCreateDirectoryObject( &ret
, GENERIC_ALL
, NULL
);
643 ok( status
== STATUS_SUCCESS
, "NULL: NtCreateDirectoryObject failed %x\n", status
);
645 status
= pNtOpenDirectoryObject( &ret
, GENERIC_ALL
, NULL
);
646 ok( status
== STATUS_INVALID_PARAMETER
, "NULL: NtOpenDirectoryObject failed %x\n", status
);
647 status
= pNtCreateSymbolicLinkObject( &ret
, GENERIC_ALL
, NULL
, &target
);
648 ok( status
== STATUS_ACCESS_VIOLATION
|| broken( status
== STATUS_SUCCESS
), /* winxp */
649 "NULL: NtCreateSymbolicLinkObject failed %x\n", status
);
650 if (!status
) pNtClose( ret
);
651 status
= pNtOpenSymbolicLinkObject( &ret
, GENERIC_ALL
, NULL
);
652 ok( status
== STATUS_INVALID_PARAMETER
, "NULL: NtOpenSymbolicLinkObject failed %x\n", status
);
653 status
= pNtCreateSection( &ret
, SECTION_MAP_WRITE
, NULL
, &size
, PAGE_READWRITE
, SEC_COMMIT
, 0 );
654 ok( status
== STATUS_SUCCESS
, "NULL: NtCreateSection failed %x\n", status
);
656 status
= pNtOpenSection( &ret
, SECTION_MAP_WRITE
, NULL
);
657 ok( status
== STATUS_INVALID_PARAMETER
, "NULL: NtOpenSection failed %x\n", status
);
658 attr2
.ObjectName
= attr3
.ObjectName
= &str
;
661 memcpy( str
.Buffer
, pipeW
, sizeof(pipeW
) );
662 for (i
= 0; i
< 65536 / sizeof(WCHAR
); i
++) str
.Buffer
[i
+ sizeof(pipeW
)/sizeof(WCHAR
)] = 'a';
664 attr
.RootDirectory
= 0;
665 attr
.Attributes
= OBJ_CASE_INSENSITIVE
;
666 timeout
.QuadPart
= -10000;
667 status
= pNtCreateNamedPipeFile( &ret
, GENERIC_ALL
, &attr
, &iosb
, FILE_SHARE_READ
|FILE_SHARE_WRITE
,
668 FILE_CREATE
, FILE_PIPE_FULL_DUPLEX
, 0, 0, 0, 1, 256, 256, &timeout
);
669 ok( status
== STATUS_OBJECT_PATH_SYNTAX_BAD
, "%u: NtCreateNamedPipeFile failed %x\n", str
.Length
, status
);
670 status
= pNtCreateNamedPipeFile( &ret
, GENERIC_ALL
, &attr2
, &iosb
, FILE_SHARE_READ
|FILE_SHARE_WRITE
,
671 FILE_CREATE
, FILE_PIPE_FULL_DUPLEX
, 0, 0, 0, 1, 256, 256, &timeout
);
672 ok( status
== STATUS_INVALID_HANDLE
, "%u: NtCreateNamedPipeFile failed %x\n", str
.Length
, status
);
674 status
= pNtCreateNamedPipeFile( &ret
, GENERIC_ALL
, &attr2
, &iosb
, FILE_SHARE_READ
|FILE_SHARE_WRITE
,
675 FILE_CREATE
, FILE_PIPE_FULL_DUPLEX
, 0, 0, 0, 1, 256, 256, &timeout
);
676 ok( status
== STATUS_OBJECT_NAME_INVALID
, "%u: NtCreateNamedPipeFile failed %x\n", str
.Length
, status
);
678 for (attr
.Length
= 0; attr
.Length
<= 2 * sizeof(attr
); attr
.Length
++)
680 status
= pNtCreateNamedPipeFile( &ret
, GENERIC_ALL
, &attr
, &iosb
, FILE_SHARE_READ
|FILE_SHARE_WRITE
,
681 FILE_CREATE
, FILE_PIPE_FULL_DUPLEX
, 0, 0, 0, 1, 256, 256, &timeout
);
682 if (attr
.Length
== sizeof(attr
))
684 ok( status
== STATUS_SUCCESS
, "%u: NtCreateNamedPipeFile failed %x\n", str
.Length
, status
);
687 else ok( status
== STATUS_INVALID_PARAMETER
,
688 "%u: NtCreateNamedPipeFile failed %x\n", str
.Length
, status
);
690 attr
.Length
= sizeof(attr
);
692 status
= pNtCreateNamedPipeFile( &ret
, GENERIC_ALL
, &attr
, &iosb
, FILE_SHARE_READ
|FILE_SHARE_WRITE
,
693 FILE_CREATE
, FILE_PIPE_FULL_DUPLEX
, 0, 0, 0, 1, 256, 256, &timeout
);
694 ok( status
== STATUS_SUCCESS
, "%u: NtCreateNamedPipeFile failed %x\n", str
.Length
, status
);
697 status
= pNtCreateNamedPipeFile( &ret
, GENERIC_ALL
, &attr
, &iosb
, FILE_SHARE_READ
|FILE_SHARE_WRITE
,
698 FILE_CREATE
, FILE_PIPE_FULL_DUPLEX
, 0, 0, 0, 1, 256, 256, &timeout
);
699 ok( status
== STATUS_OBJECT_NAME_INVALID
, "%u: NtCreateNamedPipeFile failed %x\n", str
.Length
, status
);
700 attr3
.RootDirectory
= 0;
701 attr2
.ObjectName
= attr3
.ObjectName
= NULL
;
702 status
= pNtCreateNamedPipeFile( &ret
, GENERIC_ALL
, &attr2
, &iosb
, FILE_SHARE_READ
|FILE_SHARE_WRITE
,
703 FILE_CREATE
, FILE_PIPE_FULL_DUPLEX
, 0, 0, 0, 1, 256, 256, &timeout
);
704 ok( status
== STATUS_OBJECT_NAME_INVALID
, "NULL: NtCreateNamedPipeFile failed %x\n", status
);
705 status
= pNtCreateNamedPipeFile( &ret
, GENERIC_ALL
, &attr3
, &iosb
, FILE_SHARE_READ
|FILE_SHARE_WRITE
,
706 FILE_CREATE
, FILE_PIPE_FULL_DUPLEX
, 0, 0, 0, 1, 256, 256, &timeout
);
707 ok( status
== STATUS_OBJECT_PATH_SYNTAX_BAD
, "NULL: NtCreateNamedPipeFile failed %x\n", status
);
708 status
= pNtCreateNamedPipeFile( &ret
, GENERIC_ALL
, NULL
, &iosb
, FILE_SHARE_READ
|FILE_SHARE_WRITE
,
709 FILE_CREATE
, FILE_PIPE_FULL_DUPLEX
, 0, 0, 0, 1, 256, 256, &timeout
);
710 ok( status
== STATUS_INVALID_PARAMETER
, "NULL: NtCreateNamedPipeFile failed %x\n", status
);
711 attr2
.ObjectName
= attr3
.ObjectName
= &str
;
714 memcpy( str
.Buffer
, mailslotW
, sizeof(mailslotW
) );
715 for (i
= 0; i
< 65536 / sizeof(WCHAR
); i
++) str
.Buffer
[i
+ sizeof(mailslotW
)/sizeof(WCHAR
)] = 'a';
717 status
= pNtCreateMailslotFile( &ret
, GENERIC_ALL
, &attr
, &iosb
, 0, 0, 0, NULL
);
718 ok( status
== STATUS_OBJECT_PATH_SYNTAX_BAD
, "%u: NtCreateMailslotFile failed %x\n", str
.Length
, status
);
719 status
= pNtCreateMailslotFile( &ret
, GENERIC_ALL
, &attr2
, &iosb
, 0, 0, 0, NULL
);
720 ok( status
== STATUS_INVALID_HANDLE
, "%u: NtCreateMailslotFile failed %x\n", str
.Length
, status
);
722 status
= pNtCreateMailslotFile( &ret
, GENERIC_ALL
, &attr2
, &iosb
, 0, 0, 0, NULL
);
723 ok( status
== STATUS_OBJECT_NAME_INVALID
, "%u: NtCreateMailslotFile failed %x\n", str
.Length
, status
);
725 for (attr
.Length
= 0; attr
.Length
<= 2 * sizeof(attr
); attr
.Length
++)
727 status
= pNtCreateMailslotFile( &ret
, GENERIC_ALL
, &attr
, &iosb
, 0, 0, 0, NULL
);
728 if (attr
.Length
== sizeof(attr
))
730 ok( status
== STATUS_SUCCESS
, "%u: NtCreateMailslotFile failed %x\n", str
.Length
, status
);
733 else ok( status
== STATUS_INVALID_PARAMETER
,
734 "%u: NtCreateMailslotFile failed %x\n", str
.Length
, status
);
736 attr
.Length
= sizeof(attr
);
738 status
= pNtCreateMailslotFile( &ret
, GENERIC_ALL
, &attr
, &iosb
, 0, 0, 0, NULL
);
739 ok( status
== STATUS_SUCCESS
, "%u: NtCreateMailslotFile failed %x\n", str
.Length
, status
);
742 status
= pNtCreateMailslotFile( &ret
, GENERIC_ALL
, &attr
, &iosb
, 0, 0, 0, NULL
);
743 ok( status
== STATUS_OBJECT_NAME_INVALID
, "%u: NtCreateMailslotFile failed %x\n", str
.Length
, status
);
744 attr3
.RootDirectory
= 0;
745 attr2
.ObjectName
= attr3
.ObjectName
= NULL
;
746 status
= pNtCreateMailslotFile( &ret
, GENERIC_ALL
, &attr2
, &iosb
, 0, 0, 0, NULL
);
747 ok( status
== STATUS_OBJECT_NAME_INVALID
, "NULL: NtCreateMailslotFile failed %x\n", status
);
748 status
= pNtCreateMailslotFile( &ret
, GENERIC_ALL
, &attr3
, &iosb
, 0, 0, 0, NULL
);
749 ok( status
== STATUS_OBJECT_PATH_SYNTAX_BAD
, "NULL: NtCreateMailslotFile failed %x\n", status
);
750 status
= pNtCreateMailslotFile( &ret
, GENERIC_ALL
, NULL
, &iosb
, 0, 0, 0, NULL
);
751 ok( status
== STATUS_INVALID_PARAMETER
, "NULL: NtCreateMailslotFile failed %x\n", status
);
752 attr2
.ObjectName
= attr3
.ObjectName
= &str
;
755 memcpy( str
.Buffer
, registryW
, sizeof(registryW
) );
756 for (i
= 0; i
< 65536 / sizeof(WCHAR
); i
++) str
.Buffer
[i
+ sizeof(registryW
)/sizeof(WCHAR
)] = 'a';
758 status
= pNtCreateKey( &ret
, GENERIC_ALL
, &attr
, 0, NULL
, 0, NULL
);
760 ok( status
== STATUS_OBJECT_PATH_SYNTAX_BAD
, "%u: NtCreateKey failed %x\n", str
.Length
, status
);
761 status
= pNtCreateKey( &ret
, GENERIC_ALL
, &attr2
, 0, NULL
, 0, NULL
);
762 ok( status
== STATUS_INVALID_HANDLE
, "%u: NtCreateKey failed %x\n", str
.Length
, status
);
763 status
= pNtOpenKey( &ret
, GENERIC_ALL
, &attr2
);
764 ok( status
== STATUS_INVALID_HANDLE
, "%u: NtOpenKey failed %x\n", str
.Length
, status
);
765 str
.Length
= sizeof(registryW
) + 250 * sizeof(WCHAR
) + 1;
766 status
= pNtCreateKey( &ret
, GENERIC_ALL
, &attr
, 0, NULL
, 0, NULL
);
767 ok( status
== STATUS_OBJECT_NAME_INVALID
||
768 status
== STATUS_INVALID_PARAMETER
||
769 broken( status
== STATUS_SUCCESS
), /* wow64 */
770 "%u: NtCreateKey failed %x\n", str
.Length
, status
);
776 str
.Length
= sizeof(registryW
) + 256 * sizeof(WCHAR
);
777 status
= pNtCreateKey( &ret
, GENERIC_ALL
, &attr
, 0, NULL
, 0, NULL
);
778 ok( status
== STATUS_SUCCESS
|| status
== STATUS_ACCESS_DENIED
,
779 "%u: NtCreateKey failed %x\n", str
.Length
, status
);
782 status
= pNtOpenKey( &ret2
, KEY_READ
, &attr
);
783 ok( status
== STATUS_SUCCESS
, "%u: NtOpenKey failed %x\n", str
.Length
, status
);
785 attr3
.RootDirectory
= ret
;
787 status
= pNtOpenKey( &ret2
, KEY_READ
, &attr3
);
788 ok( status
== STATUS_SUCCESS
, "%u: NtOpenKey failed %x\n", str
.Length
, status
);
793 str
.Length
= sizeof(registryW
) + 256 * sizeof(WCHAR
);
794 for (attr
.Length
= 0; attr
.Length
<= 2 * sizeof(attr
); attr
.Length
++)
796 if (attr
.Length
== sizeof(attr
))
798 status
= pNtCreateKey( &ret
, GENERIC_ALL
, &attr
, 0, NULL
, 0, NULL
);
799 ok( status
== STATUS_SUCCESS
, "%u: NtCreateKey failed %x\n", str
.Length
, status
);
800 status
= pNtOpenKey( &ret2
, KEY_READ
, &attr
);
801 ok( status
== STATUS_SUCCESS
, "%u: NtOpenKey failed %x\n", str
.Length
, status
);
808 status
= pNtCreateKey( &ret
, GENERIC_ALL
, &attr
, 0, NULL
, 0, NULL
);
809 ok( status
== STATUS_INVALID_PARAMETER
, "%u: NtCreateKey failed %x\n", str
.Length
, status
);
810 status
= pNtOpenKey( &ret2
, KEY_READ
, &attr
);
811 ok( status
== STATUS_INVALID_PARAMETER
, "%u: NtOpenKey failed %x\n", str
.Length
, status
);
814 attr
.Length
= sizeof(attr
);
816 str
.Length
= sizeof(registryW
) + 256 * sizeof(WCHAR
) + 1;
817 status
= pNtCreateKey( &ret
, GENERIC_ALL
, &attr
, 0, NULL
, 0, NULL
);
818 ok( status
== STATUS_OBJECT_NAME_INVALID
||
819 status
== STATUS_INVALID_PARAMETER
||
820 broken( status
== STATUS_SUCCESS
), /* win7 */
821 "%u: NtCreateKey failed %x\n", str
.Length
, status
);
827 status
= pNtOpenKey( &ret
, GENERIC_ALL
, &attr
);
828 ok( status
== STATUS_OBJECT_NAME_INVALID
||
829 status
== STATUS_INVALID_PARAMETER
||
830 broken( status
== STATUS_OBJECT_NAME_NOT_FOUND
), /* wow64 */
831 "%u: NtOpenKey failed %x\n", str
.Length
, status
);
833 status
= pNtCreateKey( &ret
, GENERIC_ALL
, &attr
, 0, NULL
, 0, NULL
);
834 ok( status
== STATUS_INVALID_PARAMETER
, "%u: NtCreateKey failed %x\n", str
.Length
, status
);
835 status
= pNtOpenKey( &ret
, GENERIC_ALL
, &attr
);
837 ok( status
== STATUS_INVALID_PARAMETER
, "%u: NtOpenKey failed %x\n", str
.Length
, status
);
839 status
= pNtCreateKey( &ret
, GENERIC_ALL
, &attr
, 0, NULL
, 0, NULL
);
840 ok( status
== STATUS_INVALID_PARAMETER
, "%u: NtCreateKey failed %x\n", str
.Length
, status
);
841 status
= pNtOpenKey( &ret
, GENERIC_ALL
, &attr
);
843 ok( status
== STATUS_INVALID_PARAMETER
, "%u: NtOpenKey failed %x\n", str
.Length
, status
);
844 /* some Windows versions change the error past 2050 chars, others past 4066 chars, some don't */
846 status
= pNtCreateKey( &ret
, GENERIC_ALL
, &attr
, 0, NULL
, 0, NULL
);
847 ok( status
== STATUS_BUFFER_OVERFLOW
||
848 status
== STATUS_BUFFER_TOO_SMALL
||
849 status
== STATUS_INVALID_PARAMETER
,
850 "%u: NtCreateKey failed %x\n", str
.Length
, status
);
851 status
= pNtOpenKey( &ret
, GENERIC_ALL
, &attr
);
853 ok( status
== STATUS_BUFFER_OVERFLOW
||
854 status
== STATUS_BUFFER_TOO_SMALL
||
855 status
== STATUS_INVALID_PARAMETER
,
856 "%u: NtOpenKey failed %x\n", str
.Length
, status
);
858 status
= pNtCreateKey( &ret
, GENERIC_ALL
, &attr
, 0, NULL
, 0, NULL
);
859 ok( status
== STATUS_OBJECT_NAME_INVALID
||
860 status
== STATUS_BUFFER_OVERFLOW
||
861 status
== STATUS_BUFFER_TOO_SMALL
,
862 "%u: NtCreateKey failed %x\n", str
.Length
, status
);
863 status
= pNtOpenKey( &ret
, GENERIC_ALL
, &attr
);
865 ok( status
== STATUS_OBJECT_NAME_INVALID
||
866 status
== STATUS_BUFFER_OVERFLOW
||
867 status
== STATUS_BUFFER_TOO_SMALL
,
868 "%u: NtOpenKey failed %x\n", str
.Length
, status
);
869 attr3
.RootDirectory
= 0;
870 attr2
.ObjectName
= attr3
.ObjectName
= NULL
;
871 status
= pNtCreateKey( &ret
, GENERIC_ALL
, &attr2
, 0, NULL
, 0, NULL
);
873 ok( status
== STATUS_ACCESS_VIOLATION
|| status
== STATUS_INVALID_HANDLE
,
874 "NULL: NtCreateKey failed %x\n", status
);
875 status
= pNtCreateKey( &ret
, GENERIC_ALL
, &attr3
, 0, NULL
, 0, NULL
);
877 ok( status
== STATUS_ACCESS_VIOLATION
, "NULL: NtCreateKey failed %x\n", status
);
878 status
= pNtCreateKey( &ret
, GENERIC_ALL
, NULL
, 0, NULL
, 0, NULL
);
879 ok( status
== STATUS_ACCESS_VIOLATION
, "NULL: NtCreateKey failed %x\n", status
);
880 status
= pNtOpenKey( &ret
, GENERIC_ALL
, &attr2
);
881 ok( status
== STATUS_ACCESS_VIOLATION
|| status
== STATUS_INVALID_HANDLE
,
882 "NULL: NtOpenKey failed %x\n", status
);
883 status
= pNtOpenKey( &ret
, GENERIC_ALL
, &attr3
);
884 ok( status
== STATUS_ACCESS_VIOLATION
, "NULL: NtOpenKey failed %x\n", status
);
885 status
= pNtOpenKey( &ret
, GENERIC_ALL
, NULL
);
886 ok( status
== STATUS_ACCESS_VIOLATION
, "NULL: NtOpenKey failed %x\n", status
);
887 attr2
.ObjectName
= attr3
.ObjectName
= &str
;
889 pRtlFreeUnicodeString( &str
);
890 pRtlFreeUnicodeString( &target
);
893 static void test_directory(void)
897 OBJECT_ATTRIBUTES attr
;
898 HANDLE dir
, dir1
, h
, h2
;
901 /* No name and/or no attributes */
902 status
= pNtCreateDirectoryObject(NULL
, DIRECTORY_QUERY
, &attr
);
903 ok(status
== STATUS_ACCESS_VIOLATION
|| status
== STATUS_INVALID_PARAMETER
,
904 "NtCreateDirectoryObject should have failed with STATUS_ACCESS_VIOLATION got(%08x)\n", status
);
905 status
= pNtOpenDirectoryObject(NULL
, DIRECTORY_QUERY
, &attr
);
906 ok(status
== STATUS_ACCESS_VIOLATION
|| status
== STATUS_INVALID_PARAMETER
,
907 "NtOpenDirectoryObject should have failed with STATUS_ACCESS_VIOLATION got(%08x)\n", status
);
909 status
= pNtCreateDirectoryObject(&h
, DIRECTORY_QUERY
, NULL
);
910 ok(status
== STATUS_SUCCESS
, "Failed to create Directory without attributes(%08x)\n", status
);
912 status
= pNtOpenDirectoryObject(&h
, DIRECTORY_QUERY
, NULL
);
913 ok(status
== STATUS_INVALID_PARAMETER
,
914 "NtOpenDirectoryObject should have failed with STATUS_INVALID_PARAMETER got(%08x)\n", status
);
916 InitializeObjectAttributes(&attr
, NULL
, 0, 0, NULL
);
917 status
= pNtCreateDirectoryObject( &dir
, DIRECTORY_QUERY
, &attr
);
918 ok( status
== STATUS_SUCCESS
, "Failed to create directory %08x\n", status
);
919 status
= pNtOpenDirectoryObject( &h
, DIRECTORY_QUERY
, &attr
);
920 ok( status
== STATUS_OBJECT_PATH_SYNTAX_BAD
, "NtOpenDirectoryObject got %08x\n", status
);
923 InitializeObjectAttributes(&attr
, &str
, 0, 0, NULL
);
925 pRtlCreateUnicodeStringFromAsciiz(&str
, "");
926 status
= pNtCreateDirectoryObject( &h
, DIRECTORY_QUERY
, &attr
);
927 ok( status
== STATUS_SUCCESS
, "Failed to create directory %08x\n", status
);
929 status
= pNtOpenDirectoryObject( &h
, DIRECTORY_QUERY
, &attr
);
930 ok( status
== STATUS_OBJECT_PATH_SYNTAX_BAD
, "NtOpenDirectoryObject got %08x\n", status
);
931 pRtlFreeUnicodeString(&str
);
934 DIR_TEST_CREATE_OPEN( "BaseNamedObjects", STATUS_OBJECT_PATH_SYNTAX_BAD
);
935 DIR_TEST_CREATE_OPEN( "\\BaseNamedObjects\\", STATUS_OBJECT_NAME_INVALID
);
936 DIR_TEST_CREATE_OPEN( "\\\\BaseNamedObjects", STATUS_OBJECT_NAME_INVALID
);
937 DIR_TEST_CREATE_OPEN( "\\BaseNamedObjects\\\\om.c-test", STATUS_OBJECT_NAME_INVALID
);
938 DIR_TEST_CREATE_OPEN( "\\BaseNamedObjects\\om.c-test\\", STATUS_OBJECT_PATH_NOT_FOUND
);
940 pRtlCreateUnicodeStringFromAsciiz(&str
, "\\BaseNamedObjects\\om.c-test");
941 status
= pNtCreateDirectoryObject( &h
, DIRECTORY_QUERY
, &attr
);
942 ok( status
== STATUS_SUCCESS
, "Failed to create directory %08x\n", status
);
943 status
= pNtOpenDirectoryObject( &dir1
, DIRECTORY_QUERY
, &attr
);
944 ok( status
== STATUS_SUCCESS
, "Failed to open directory %08x\n", status
);
945 pRtlFreeUnicodeString(&str
);
950 /* Use of root directory */
952 /* Can't use symlinks as a directory */
953 pRtlCreateUnicodeStringFromAsciiz(&str
, "\\BaseNamedObjects\\Local");
954 InitializeObjectAttributes(&attr
, &str
, 0, 0, NULL
);
955 status
= pNtOpenSymbolicLinkObject(&dir
, SYMBOLIC_LINK_QUERY
, &attr
);
956 is_nt4
= (status
== STATUS_OBJECT_NAME_NOT_FOUND
); /* nt4 doesn't have Local\\ symlink */
962 ok(status
== STATUS_SUCCESS
, "Failed to open SymbolicLink(%08x)\n", status
);
963 pRtlFreeUnicodeString(&str
);
964 InitializeObjectAttributes(&attr
, &str
, 0, dir
, NULL
);
965 pRtlCreateUnicodeStringFromAsciiz(&str
, "one more level");
966 status
= pNtCreateDirectoryObject( &h
, DIRECTORY_QUERY
, &attr
);
967 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
, "NtCreateDirectoryObject got %08x\n", status
);
968 pRtlFreeUnicodeString(&str
);
970 pRtlCreateUnicodeStringFromAsciiz( &str
, "\\BaseNamedObjects\\Local\\om.c-test" );
971 InitializeObjectAttributes( &attr
, &str
, 0, 0, NULL
);
972 status
= pNtCreateDirectoryObject( &dir1
, DIRECTORY_QUERY
, &attr
);
973 ok( status
== STATUS_SUCCESS
, "Failed to create directory %08x\n", status
);
974 pRtlFreeUnicodeString( &str
);
975 pRtlCreateUnicodeStringFromAsciiz( &str
, "om.c-test" );
976 InitializeObjectAttributes( &attr
, &str
, 0, dir
, NULL
);
977 status
= pNtOpenDirectoryObject( &h
, DIRECTORY_QUERY
, &attr
);
978 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
, "Failed to open directory %08x\n", status
);
979 if (!status
) pNtClose(h
);
980 pRtlFreeUnicodeString( &str
);
982 pRtlCreateUnicodeStringFromAsciiz( &str
, "om.c-event" );
983 InitializeObjectAttributes( &attr
, &str
, 0, dir1
, NULL
);
984 status
= pNtCreateEvent( &h
, GENERIC_ALL
, &attr
, 1, 0 );
985 ok( status
== STATUS_SUCCESS
, "NtCreateEvent failed %x\n", status
);
986 status
= pNtOpenEvent( &h2
, GENERIC_ALL
, &attr
);
987 ok( status
== STATUS_SUCCESS
, "NtOpenEvent failed %x\n", status
);
989 pRtlFreeUnicodeString( &str
);
990 pRtlCreateUnicodeStringFromAsciiz( &str
, "om.c-test\\om.c-event" );
991 InitializeObjectAttributes( &attr
, &str
, 0, dir
, NULL
);
992 status
= pNtOpenEvent( &h2
, GENERIC_ALL
, &attr
);
993 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
, "NtOpenEvent failed %x\n", status
);
994 pRtlFreeUnicodeString( &str
);
995 pRtlCreateUnicodeStringFromAsciiz( &str
, "\\BasedNamedObjects\\Local\\om.c-test\\om.c-event" );
996 InitializeObjectAttributes( &attr
, &str
, 0, 0, NULL
);
997 status
= pNtOpenEvent( &h2
, GENERIC_ALL
, &attr
);
998 ok( status
== STATUS_OBJECT_PATH_NOT_FOUND
, "NtOpenEvent failed %x\n", status
);
999 pRtlFreeUnicodeString( &str
);
1003 str
.Buffer
= buffer
;
1004 str
.MaximumLength
= sizeof(buffer
);
1006 memset( buffer
, 0xaa, sizeof(buffer
) );
1007 status
= pNtQuerySymbolicLinkObject( dir
, &str
, &len
);
1008 ok( status
== STATUS_SUCCESS
, "NtQuerySymbolicLinkObject failed %08x\n", status
);
1009 if (status
!= STATUS_SUCCESS
)
1011 full_len
= str
.Length
+ sizeof(WCHAR
);
1012 ok( len
== full_len
, "bad length %u/%u\n", len
, full_len
);
1013 if (len
== full_len
)
1014 ok( buffer
[len
/ sizeof(WCHAR
) - 1] == 0, "no terminating null\n" );
1016 str
.MaximumLength
= str
.Length
;
1018 status
= pNtQuerySymbolicLinkObject( dir
, &str
, &len
);
1019 ok( status
== STATUS_BUFFER_TOO_SMALL
, "NtQuerySymbolicLinkObject failed %08x\n", status
);
1020 ok( len
== full_len
, "bad length %u/%u\n", len
, full_len
);
1022 str
.MaximumLength
= 0;
1024 status
= pNtQuerySymbolicLinkObject( dir
, &str
, &len
);
1025 ok( status
== STATUS_BUFFER_TOO_SMALL
, "NtQuerySymbolicLinkObject failed %08x\n", status
);
1026 ok( len
== full_len
, "bad length %u/%u\n", len
, full_len
);
1028 str
.MaximumLength
= str
.Length
+ sizeof(WCHAR
);
1030 status
= pNtQuerySymbolicLinkObject( dir
, &str
, &len
);
1031 ok( status
== STATUS_SUCCESS
, "NtQuerySymbolicLinkObject failed %08x\n", status
);
1032 ok( len
== full_len
, "bad length %u/%u\n", len
, full_len
);
1038 pRtlCreateUnicodeStringFromAsciiz(&str
, "\\BaseNamedObjects");
1039 InitializeObjectAttributes(&attr
, &str
, 0, 0, NULL
);
1040 status
= pNtOpenDirectoryObject( &dir
, DIRECTORY_QUERY
, &attr
);
1041 ok( status
== STATUS_SUCCESS
, "Failed to open directory %08x\n", status
);
1042 pRtlFreeUnicodeString(&str
);
1044 InitializeObjectAttributes(&attr
, NULL
, 0, dir
, NULL
);
1045 status
= pNtOpenDirectoryObject( &h
, DIRECTORY_QUERY
, &attr
);
1046 ok( status
== STATUS_OBJECT_NAME_INVALID
, "NtOpenDirectoryObject got %08x\n", status
);
1048 InitializeObjectAttributes(&attr
, &str
, 0, dir
, NULL
);
1049 DIR_TEST_CREATE_OPEN( "", STATUS_SUCCESS
);
1050 DIR_TEST_CREATE_OPEN( "\\", STATUS_OBJECT_PATH_SYNTAX_BAD
);
1051 DIR_TEST_CREATE_OPEN( "\\om.c-test", STATUS_OBJECT_PATH_SYNTAX_BAD
);
1052 DIR_TEST_CREATE_OPEN( "\\om.c-test\\", STATUS_OBJECT_PATH_SYNTAX_BAD
);
1053 DIR_TEST_CREATE_OPEN( "om.c-test\\", STATUS_OBJECT_PATH_NOT_FOUND
);
1055 pRtlCreateUnicodeStringFromAsciiz(&str
, "om.c-test");
1056 status
= pNtCreateDirectoryObject( &dir1
, DIRECTORY_QUERY
, &attr
);
1057 ok( status
== STATUS_SUCCESS
, "Failed to create directory %08x\n", status
);
1058 status
= pNtOpenDirectoryObject( &h
, DIRECTORY_QUERY
, &attr
);
1059 ok( status
== STATUS_SUCCESS
, "Failed to open directory %08x\n", status
);
1060 pRtlFreeUnicodeString(&str
);
1066 /* Nested directories */
1067 pRtlCreateUnicodeStringFromAsciiz(&str
, "\\");
1068 InitializeObjectAttributes(&attr
, &str
, 0, 0, NULL
);
1069 status
= pNtOpenDirectoryObject( &dir
, DIRECTORY_QUERY
, &attr
);
1070 ok( status
== STATUS_SUCCESS
, "Failed to open directory %08x\n", status
);
1071 InitializeObjectAttributes(&attr
, &str
, 0, dir
, NULL
);
1072 status
= pNtOpenDirectoryObject( &h
, DIRECTORY_QUERY
, &attr
);
1073 ok( status
== STATUS_OBJECT_PATH_SYNTAX_BAD
, "NtOpenDirectoryObject got %08x\n", status
);
1074 pRtlFreeUnicodeString(&str
);
1077 InitializeObjectAttributes(&attr
, &str
, 0, 0, NULL
);
1078 pRtlCreateUnicodeStringFromAsciiz(&str
, "\\BaseNamedObjects\\om.c-test");
1079 status
= pNtCreateDirectoryObject( &dir
, DIRECTORY_QUERY
, &attr
);
1080 ok( status
== STATUS_SUCCESS
, "Failed to create directory %08x\n", status
);
1081 pRtlFreeUnicodeString(&str
);
1082 pRtlCreateUnicodeStringFromAsciiz(&str
, "\\BaseNamedObjects\\om.c-test\\one more level");
1083 status
= pNtCreateDirectoryObject( &h
, DIRECTORY_QUERY
, &attr
);
1084 ok( status
== STATUS_SUCCESS
, "Failed to create directory %08x\n", status
);
1085 pRtlFreeUnicodeString(&str
);
1087 InitializeObjectAttributes(&attr
, &str
, 0, dir
, NULL
);
1088 pRtlCreateUnicodeStringFromAsciiz(&str
, "one more level");
1089 status
= pNtCreateDirectoryObject( &h
, DIRECTORY_QUERY
, &attr
);
1090 ok( status
== STATUS_SUCCESS
, "Failed to create directory %08x\n", status
);
1091 pRtlFreeUnicodeString(&str
);
1098 InitializeObjectAttributes(&attr
, &str
, 0, 0, NULL
);
1099 pRtlCreateUnicodeStringFromAsciiz(&str
, "\\BaseNamedObjects\\Global\\om.c-test");
1100 status
= pNtCreateDirectoryObject( &dir
, DIRECTORY_QUERY
, &attr
);
1101 ok( status
== STATUS_SUCCESS
, "Failed to create directory %08x\n", status
);
1102 pRtlFreeUnicodeString(&str
);
1103 pRtlCreateUnicodeStringFromAsciiz(&str
, "\\BaseNamedObjects\\Local\\om.c-test\\one more level");
1104 status
= pNtCreateDirectoryObject( &h
, DIRECTORY_QUERY
, &attr
);
1105 ok( status
== STATUS_SUCCESS
, "Failed to create directory %08x\n", status
);
1106 pRtlFreeUnicodeString(&str
);
1108 InitializeObjectAttributes(&attr
, &str
, 0, dir
, NULL
);
1109 pRtlCreateUnicodeStringFromAsciiz(&str
, "one more level");
1110 status
= pNtCreateDirectoryObject( &dir
, DIRECTORY_QUERY
, &attr
);
1111 ok( status
== STATUS_SUCCESS
, "Failed to create directory %08x\n", status
);
1112 pRtlFreeUnicodeString(&str
);
1117 /* Create other objects using RootDirectory */
1119 InitializeObjectAttributes(&attr
, &str
, 0, 0, NULL
);
1120 pRtlCreateUnicodeStringFromAsciiz(&str
, "\\BaseNamedObjects");
1121 status
= pNtOpenDirectoryObject( &dir
, DIRECTORY_QUERY
, &attr
);
1122 ok( status
== STATUS_SUCCESS
, "Failed to open directory %08x\n", status
);
1123 pRtlFreeUnicodeString(&str
);
1124 InitializeObjectAttributes(&attr
, &str
, 0, dir
, NULL
);
1126 /* Test invalid paths */
1127 pRtlCreateUnicodeStringFromAsciiz(&str
, "\\om.c-mutant");
1128 status
= pNtCreateMutant(&h
, GENERIC_ALL
, &attr
, FALSE
);
1129 ok(status
== STATUS_OBJECT_PATH_SYNTAX_BAD
,
1130 "NtCreateMutant should have failed with STATUS_OBJECT_PATH_SYNTAX_BAD got(%08x)\n", status
);
1131 pRtlFreeUnicodeString(&str
);
1132 pRtlCreateUnicodeStringFromAsciiz(&str
, "\\om.c-mutant\\");
1133 status
= pNtCreateMutant(&h
, GENERIC_ALL
, &attr
, FALSE
);
1134 ok(status
== STATUS_OBJECT_PATH_SYNTAX_BAD
,
1135 "NtCreateMutant should have failed with STATUS_OBJECT_PATH_SYNTAX_BAD got(%08x)\n", status
);
1136 pRtlFreeUnicodeString(&str
);
1138 pRtlCreateUnicodeStringFromAsciiz(&str
, "om.c\\-mutant");
1139 status
= pNtCreateMutant(&h
, GENERIC_ALL
, &attr
, FALSE
);
1140 ok(status
== STATUS_OBJECT_PATH_NOT_FOUND
,
1141 "NtCreateMutant should have failed with STATUS_OBJECT_PATH_NOT_FOUND got(%08x)\n", status
);
1142 pRtlFreeUnicodeString(&str
);
1144 pRtlCreateUnicodeStringFromAsciiz(&str
, "om.c-mutant");
1145 status
= pNtCreateMutant(&h
, GENERIC_ALL
, &attr
, FALSE
);
1146 ok(status
== STATUS_SUCCESS
, "Failed to create Mutant(%08x)\n", status
);
1147 pRtlFreeUnicodeString(&str
);
1153 static void test_symboliclink(void)
1156 UNICODE_STRING str
, target
;
1157 OBJECT_ATTRIBUTES attr
;
1158 HANDLE dir
, link
, h
;
1159 IO_STATUS_BLOCK iosb
;
1161 /* No name and/or no attributes */
1162 InitializeObjectAttributes(&attr
, NULL
, 0, 0, NULL
);
1163 pRtlCreateUnicodeStringFromAsciiz(&target
, "\\DosDevices");
1164 status
= pNtCreateSymbolicLinkObject( NULL
, SYMBOLIC_LINK_QUERY
, &attr
, &target
);
1165 ok( status
== STATUS_ACCESS_VIOLATION
|| status
== STATUS_INVALID_PARAMETER
,
1166 "NtCreateSymbolicLinkObject got %08x\n", status
);
1167 status
= pNtOpenSymbolicLinkObject( NULL
, SYMBOLIC_LINK_QUERY
, &attr
);
1168 ok( status
== STATUS_ACCESS_VIOLATION
|| status
== STATUS_INVALID_PARAMETER
,
1169 "NtOpenSymbolicLinkObject got %08x\n", status
);
1171 status
= pNtCreateSymbolicLinkObject(&h
, SYMBOLIC_LINK_QUERY
, NULL
, NULL
);
1172 ok(status
== STATUS_ACCESS_VIOLATION
,
1173 "NtCreateSymbolicLinkObject should have failed with STATUS_ACCESS_VIOLATION got(%08x)\n", status
);
1174 status
= pNtOpenSymbolicLinkObject(&h
, SYMBOLIC_LINK_QUERY
, NULL
);
1175 ok(status
== STATUS_INVALID_PARAMETER
,
1176 "NtOpenSymbolicLinkObject should have failed with STATUS_INVALID_PARAMETER got(%08x)\n", status
);
1179 status
= pNtCreateSymbolicLinkObject(&h
, SYMBOLIC_LINK_QUERY
, NULL
, &target
);
1180 ok(status
== STATUS_SUCCESS
|| status
== STATUS_ACCESS_VIOLATION
, /* nt4 */
1181 "NtCreateSymbolicLinkObject failed(%08x)\n", status
);
1182 pRtlFreeUnicodeString(&target
);
1183 if (!status
) pNtClose(h
);
1185 InitializeObjectAttributes(&attr
, NULL
, 0, 0, NULL
);
1186 status
= pNtCreateSymbolicLinkObject(&link
, SYMBOLIC_LINK_QUERY
, &attr
, &target
);
1187 ok(status
== STATUS_INVALID_PARAMETER
||
1188 broken(status
== STATUS_SUCCESS
), /* nt4 */
1189 "NtCreateSymbolicLinkObject should have failed with STATUS_INVALID_PARAMETER got(%08x)\n", status
);
1190 if (!status
) pNtClose(h
);
1191 status
= pNtOpenSymbolicLinkObject(&h
, SYMBOLIC_LINK_QUERY
, &attr
);
1192 ok(status
== STATUS_OBJECT_PATH_SYNTAX_BAD
,
1193 "NtOpenSymbolicLinkObject should have failed with STATUS_OBJECT_PATH_SYNTAX_BAD got(%08x)\n", status
);
1196 pRtlCreateUnicodeStringFromAsciiz(&target
, "anywhere");
1197 InitializeObjectAttributes(&attr
, &str
, 0, 0, NULL
);
1199 pRtlCreateUnicodeStringFromAsciiz(&str
, "");
1200 status
= pNtCreateSymbolicLinkObject(&link
, SYMBOLIC_LINK_QUERY
, &attr
, &target
);
1201 ok(status
== STATUS_SUCCESS
, "Failed to create SymbolicLink(%08x)\n", status
);
1202 status
= pNtOpenSymbolicLinkObject(&h
, SYMBOLIC_LINK_QUERY
, &attr
);
1203 ok(status
== STATUS_OBJECT_PATH_SYNTAX_BAD
,
1204 "NtOpenSymbolicLinkObject should have failed with STATUS_OBJECT_PATH_SYNTAX_BAD got(%08x)\n", status
);
1206 pRtlFreeUnicodeString(&str
);
1208 pRtlCreateUnicodeStringFromAsciiz(&str
, "\\");
1209 status
= pNtCreateSymbolicLinkObject(&h
, SYMBOLIC_LINK_QUERY
, &attr
, &target
);
1210 todo_wine
ok(status
== STATUS_OBJECT_TYPE_MISMATCH
,
1211 "NtCreateSymbolicLinkObject should have failed with STATUS_OBJECT_TYPE_MISMATCH got(%08x)\n", status
);
1212 pRtlFreeUnicodeString(&str
);
1213 pRtlFreeUnicodeString(&target
);
1215 pRtlCreateUnicodeStringFromAsciiz( &target
, "->Somewhere");
1217 pRtlCreateUnicodeStringFromAsciiz( &str
, "BaseNamedObjects" );
1218 status
= pNtCreateSymbolicLinkObject( &h
, SYMBOLIC_LINK_QUERY
, &attr
, &target
);
1219 ok( status
== STATUS_OBJECT_PATH_SYNTAX_BAD
, "NtCreateSymbolicLinkObject got %08x\n", status
);
1220 status
= pNtOpenSymbolicLinkObject( &h
, SYMBOLIC_LINK_QUERY
, &attr
);
1221 ok( status
== STATUS_OBJECT_PATH_SYNTAX_BAD
, "NtOpenSymbolicLinkObject got %08x\n", status
);
1222 pRtlFreeUnicodeString( &str
);
1224 pRtlCreateUnicodeStringFromAsciiz( &str
, "\\BaseNamedObjects\\" );
1225 status
= pNtCreateSymbolicLinkObject( &h
, SYMBOLIC_LINK_QUERY
, &attr
, &target
);
1226 ok( status
== STATUS_OBJECT_NAME_INVALID
, "NtCreateSymbolicLinkObject got %08x\n", status
);
1227 status
= pNtOpenSymbolicLinkObject( &h
, SYMBOLIC_LINK_QUERY
, &attr
);
1228 ok( status
== STATUS_OBJECT_NAME_INVALID
, "NtOpenSymbolicLinkObject got %08x\n", status
);
1229 pRtlFreeUnicodeString( &str
);
1231 pRtlCreateUnicodeStringFromAsciiz( &str
, "\\\\BaseNamedObjects" );
1232 status
= pNtCreateSymbolicLinkObject( &h
, SYMBOLIC_LINK_QUERY
, &attr
, &target
);
1233 ok( status
== STATUS_OBJECT_NAME_INVALID
, "NtCreateSymbolicLinkObject got %08x\n", status
);
1234 status
= pNtOpenSymbolicLinkObject( &h
, SYMBOLIC_LINK_QUERY
, &attr
);
1235 ok( status
== STATUS_OBJECT_NAME_INVALID
, "NtOpenSymbolicLinkObject got %08x\n", status
);
1236 pRtlFreeUnicodeString( &str
);
1238 pRtlCreateUnicodeStringFromAsciiz( &str
, "\\BaseNamedObjects\\\\om.c-test" );
1239 status
= pNtCreateSymbolicLinkObject( &h
, SYMBOLIC_LINK_QUERY
, &attr
, &target
);
1240 ok( status
== STATUS_OBJECT_NAME_INVALID
, "NtCreateSymbolicLinkObject got %08x\n", status
);
1241 status
= pNtOpenSymbolicLinkObject( &h
, SYMBOLIC_LINK_QUERY
, &attr
);
1242 ok( status
== STATUS_OBJECT_NAME_INVALID
, "NtOpenSymbolicLinkObject got %08x\n", status
);
1243 pRtlFreeUnicodeString( &str
);
1245 pRtlCreateUnicodeStringFromAsciiz( &str
, "\\BaseNamedObjects\\om.c-test\\" );
1246 status
= pNtCreateSymbolicLinkObject( &h
, SYMBOLIC_LINK_QUERY
, &attr
, &target
);
1247 ok( status
== STATUS_OBJECT_NAME_INVALID
|| status
== STATUS_OBJECT_PATH_NOT_FOUND
,
1248 "NtCreateSymbolicLinkObject got %08x\n", status
);
1249 status
= pNtOpenSymbolicLinkObject( &h
, SYMBOLIC_LINK_QUERY
, &attr
);
1250 ok( status
== STATUS_OBJECT_NAME_INVALID
|| status
== STATUS_OBJECT_PATH_NOT_FOUND
,
1251 "NtOpenSymbolicLinkObject got %08x\n", status
);
1252 pRtlFreeUnicodeString( &str
);
1253 pRtlFreeUnicodeString(&target
);
1256 if (!(dir
= get_base_dir()))
1258 win_skip( "couldn't find the BaseNamedObjects dir\n" );
1262 InitializeObjectAttributes(&attr
, &str
, 0, dir
, NULL
);
1263 pRtlCreateUnicodeStringFromAsciiz(&str
, "test-link");
1264 pRtlCreateUnicodeStringFromAsciiz(&target
, "\\DosDevices");
1265 status
= pNtCreateSymbolicLinkObject(&link
, SYMBOLIC_LINK_QUERY
, &attr
, &target
);
1266 ok(status
== STATUS_SUCCESS
, "Failed to create SymbolicLink(%08x)\n", status
);
1267 pRtlFreeUnicodeString(&str
);
1268 pRtlFreeUnicodeString(&target
);
1270 pRtlCreateUnicodeStringFromAsciiz(&str
, "test-link\\NUL");
1271 status
= pNtOpenFile(&h
, GENERIC_READ
, &attr
, &iosb
, FILE_SHARE_READ
|FILE_SHARE_WRITE
, 0);
1272 ok(status
== STATUS_SUCCESS
, "Failed to open NUL device(%08x)\n", status
);
1273 status
= pNtOpenFile(&h
, GENERIC_READ
, &attr
, &iosb
, FILE_SHARE_READ
|FILE_SHARE_WRITE
, FILE_DIRECTORY_FILE
);
1274 ok(status
== STATUS_SUCCESS
, "Failed to open NUL device(%08x)\n", status
);
1275 pRtlFreeUnicodeString(&str
);
1282 static void test_query_object(void)
1284 static const WCHAR name
[] = {'\\','B','a','s','e','N','a','m','e','d','O','b','j','e','c','t','s',
1285 '\\','t','e','s','t','_','e','v','e','n','t'};
1286 static const WCHAR type_event
[] = {'E','v','e','n','t'};
1287 static const WCHAR type_file
[] = {'F','i','l','e'};
1288 static const WCHAR type_iocompletion
[] = {'I','o','C','o','m','p','l','e','t','i','o','n'};
1289 static const WCHAR type_directory
[] = {'D','i','r','e','c','t','o','r','y'};
1290 static const WCHAR type_section
[] = {'S','e','c','t','i','o','n'};
1294 ULONG len
, expected_len
;
1295 OBJECT_ATTRIBUTES attr
;
1296 UNICODE_STRING path
, *str
;
1297 char dir
[MAX_PATH
], tmp_path
[MAX_PATH
], file1
[MAX_PATH
+ 16];
1300 InitializeObjectAttributes( &attr
, &path
, 0, 0, 0 );
1302 handle
= CreateEventA( NULL
, FALSE
, FALSE
, "test_event" );
1305 status
= pNtQueryObject( handle
, ObjectNameInformation
, buffer
, 0, &len
);
1306 ok( status
== STATUS_INFO_LENGTH_MISMATCH
, "NtQueryObject failed %x\n", status
);
1307 ok( len
>= sizeof(UNICODE_STRING
) + sizeof(name
) + sizeof(WCHAR
), "unexpected len %u\n", len
);
1310 status
= pNtQueryObject( handle
, ObjectTypeInformation
, buffer
, 0, &len
);
1311 ok( status
== STATUS_INFO_LENGTH_MISMATCH
, "NtQueryObject failed %x\n", status
);
1312 ok( len
>= sizeof(OBJECT_TYPE_INFORMATION
) + sizeof(type_event
) + sizeof(WCHAR
), "unexpected len %u\n", len
);
1315 status
= pNtQueryObject( handle
, ObjectNameInformation
, buffer
, sizeof(UNICODE_STRING
), &len
);
1316 ok( status
== STATUS_INFO_LENGTH_MISMATCH
, "NtQueryObject failed %x\n", status
);
1317 ok( len
>= sizeof(UNICODE_STRING
) + sizeof(name
) + sizeof(WCHAR
), "unexpected len %u\n", len
);
1320 status
= pNtQueryObject( handle
, ObjectTypeInformation
, buffer
, sizeof(OBJECT_TYPE_INFORMATION
), &len
);
1321 ok( status
== STATUS_INFO_LENGTH_MISMATCH
, "NtQueryObject failed %x\n", status
);
1322 ok( len
>= sizeof(OBJECT_TYPE_INFORMATION
) + sizeof(type_event
) + sizeof(WCHAR
), "unexpected len %u\n", len
);
1325 status
= pNtQueryObject( handle
, ObjectNameInformation
, buffer
, sizeof(buffer
), &len
);
1326 ok( status
== STATUS_SUCCESS
, "NtQueryObject failed %x\n", status
);
1327 ok( len
> sizeof(UNICODE_STRING
), "unexpected len %u\n", len
);
1328 str
= (UNICODE_STRING
*)buffer
;
1329 ok( sizeof(UNICODE_STRING
) + str
->Length
+ sizeof(WCHAR
) == len
, "unexpected len %u\n", len
);
1330 ok( str
->Length
>= sizeof(name
), "unexpected len %u\n", str
->Length
);
1331 ok( len
> sizeof(UNICODE_STRING
) + sizeof("\\test_event") * sizeof(WCHAR
),
1332 "name too short %s\n", wine_dbgstr_w(str
->Buffer
) );
1333 /* there can be a \\Sessions prefix in the name */
1334 ok( !memcmp( str
->Buffer
+ (str
->Length
- sizeof(name
)) / sizeof(WCHAR
), name
, sizeof(name
) ),
1335 "wrong name %s\n", wine_dbgstr_w(str
->Buffer
) );
1336 trace( "got %s len %u\n", wine_dbgstr_w(str
->Buffer
), len
);
1338 len
-= sizeof(WCHAR
);
1339 status
= pNtQueryObject( handle
, ObjectNameInformation
, buffer
, len
, &len
);
1340 ok( status
== STATUS_INFO_LENGTH_MISMATCH
, "NtQueryObject failed %x\n", status
);
1341 ok( len
>= sizeof(UNICODE_STRING
) + sizeof(name
) + sizeof(WCHAR
), "unexpected len %u\n", len
);
1344 memset( buffer
, 0, sizeof(buffer
) );
1345 status
= pNtQueryObject( handle
, ObjectTypeInformation
, buffer
, sizeof(buffer
), &len
);
1346 ok( status
== STATUS_SUCCESS
, "NtQueryObject failed %x\n", status
);
1347 ok( len
> sizeof(OBJECT_TYPE_INFORMATION
), "unexpected len %u\n", len
);
1348 str
= (UNICODE_STRING
*)buffer
;
1349 ok( len
>= sizeof(OBJECT_TYPE_INFORMATION
) + str
->Length
+ sizeof(WCHAR
), "unexpected len %u\n", len
);
1350 ok( str
->Buffer
&& !memcmp( str
->Buffer
, type_event
, sizeof(type_event
) ),
1351 "wrong/bad type name %s (%p)\n", wine_dbgstr_w(str
->Buffer
), str
->Buffer
);
1353 len
-= sizeof(WCHAR
);
1354 status
= pNtQueryObject( handle
, ObjectTypeInformation
, buffer
, len
, &len
);
1355 ok( status
== STATUS_INFO_LENGTH_MISMATCH
, "NtQueryObject failed %x\n", status
);
1356 ok( len
>= sizeof(OBJECT_TYPE_INFORMATION
) + sizeof(type_event
) + sizeof(WCHAR
), "unexpected len %u\n", len
);
1360 handle
= CreateEventA( NULL
, FALSE
, FALSE
, NULL
);
1362 status
= pNtQueryObject( handle
, ObjectNameInformation
, buffer
, sizeof(buffer
), &len
);
1363 ok( status
== STATUS_SUCCESS
, "NtQueryObject failed %x\n", status
);
1364 ok( len
== sizeof(UNICODE_STRING
), "unexpected len %u\n", len
);
1365 str
= (UNICODE_STRING
*)buffer
;
1366 ok( str
->Length
== 0, "unexpected len %u\n", len
);
1367 ok( str
->Buffer
== NULL
, "unexpected ptr %p\n", str
->Buffer
);
1370 GetWindowsDirectoryA( dir
, MAX_PATH
);
1371 handle
= CreateFileA( dir
, GENERIC_READ
, FILE_SHARE_READ
| FILE_SHARE_WRITE
, NULL
, OPEN_EXISTING
,
1372 FILE_FLAG_BACKUP_SEMANTICS
, 0 );
1374 status
= pNtQueryObject( handle
, ObjectNameInformation
, buffer
, sizeof(buffer
), &len
);
1375 ok( status
== STATUS_SUCCESS
, "NtQueryObject failed %x\n", status
);
1376 ok( len
> sizeof(UNICODE_STRING
), "unexpected len %u\n", len
);
1377 str
= (UNICODE_STRING
*)buffer
;
1378 expected_len
= sizeof(UNICODE_STRING
) + str
->Length
+ sizeof(WCHAR
);
1379 ok( len
== expected_len
|| broken(len
== expected_len
- sizeof(WCHAR
)), /* NT4 */
1380 "unexpected len %u\n", len
);
1381 trace( "got %s len %u\n", wine_dbgstr_w(str
->Buffer
), len
);
1384 status
= pNtQueryObject( handle
, ObjectNameInformation
, buffer
, 0, &len
);
1385 ok( status
== STATUS_INFO_LENGTH_MISMATCH
|| broken(status
== STATUS_INSUFFICIENT_RESOURCES
),
1386 "NtQueryObject failed %x\n", status
);
1387 ok( len
== expected_len
|| broken(!len
|| len
== sizeof(UNICODE_STRING
)),
1388 "unexpected len %u\n", len
);
1391 status
= pNtQueryObject( handle
, ObjectNameInformation
, buffer
, sizeof(UNICODE_STRING
), &len
);
1392 ok( status
== STATUS_BUFFER_OVERFLOW
|| broken(status
== STATUS_INSUFFICIENT_RESOURCES
1393 || status
== STATUS_INFO_LENGTH_MISMATCH
),
1394 "NtQueryObject failed %x\n", status
);
1395 ok( len
== expected_len
|| broken(!len
),
1396 "unexpected len %u\n", len
);
1399 memset( buffer
, 0, sizeof(buffer
) );
1400 status
= pNtQueryObject( handle
, ObjectTypeInformation
, buffer
, sizeof(buffer
), &len
);
1401 ok( status
== STATUS_SUCCESS
, "NtQueryObject failed %x\n", status
);
1402 ok( len
> sizeof(OBJECT_TYPE_INFORMATION
), "unexpected len %u\n", len
);
1403 str
= (UNICODE_STRING
*)buffer
;
1404 expected_len
= sizeof(OBJECT_TYPE_INFORMATION
) + str
->Length
+ sizeof(WCHAR
);
1405 ok( len
>= expected_len
, "unexpected len %u\n", len
);
1406 ok( str
->Buffer
&& !memcmp( str
->Buffer
, type_file
, sizeof(type_file
) ),
1407 "wrong/bad type name %s (%p)\n", wine_dbgstr_w(str
->Buffer
), str
->Buffer
);
1411 GetTempPathA(MAX_PATH
, tmp_path
);
1412 GetTempFileNameA(tmp_path
, "foo", 0, file1
);
1413 handle
= CreateFileA(file1
, GENERIC_WRITE
| DELETE
, 0, NULL
, CREATE_ALWAYS
, 0, 0);
1415 memset( buffer
, 0, sizeof(buffer
) );
1416 status
= pNtQueryObject( handle
, ObjectTypeInformation
, buffer
, sizeof(buffer
), &len
);
1417 ok( status
== STATUS_SUCCESS
, "NtQueryObject failed %x\n", status
);
1418 ok( len
> sizeof(OBJECT_TYPE_INFORMATION
), "unexpected len %u\n", len
);
1419 str
= (UNICODE_STRING
*)buffer
;
1420 expected_len
= sizeof(OBJECT_TYPE_INFORMATION
) + str
->Length
+ sizeof(WCHAR
);
1421 ok( len
>= expected_len
, "unexpected len %u\n", len
);
1422 ok( str
->Buffer
&& !memcmp( str
->Buffer
, type_file
, sizeof(type_file
) ),
1423 "wrong/bad type name %s (%p)\n", wine_dbgstr_w(str
->Buffer
), str
->Buffer
);
1424 DeleteFileA( file1
);
1427 status
= pNtCreateIoCompletion( &handle
, IO_COMPLETION_ALL_ACCESS
, NULL
, 0 );
1428 ok( status
== STATUS_SUCCESS
, "NtCreateIoCompletion failed %x\n", status
);
1430 memset( buffer
, 0, sizeof(buffer
) );
1431 status
= pNtQueryObject( handle
, ObjectTypeInformation
, buffer
, sizeof(buffer
), &len
);
1432 ok( status
== STATUS_SUCCESS
, "NtQueryObject failed %x\n", status
);
1433 ok( len
> sizeof(OBJECT_TYPE_INFORMATION
), "unexpected len %u\n", len
);
1434 str
= (UNICODE_STRING
*)buffer
;
1435 expected_len
= sizeof(OBJECT_TYPE_INFORMATION
) + str
->Length
+ sizeof(WCHAR
);
1436 ok( len
>= expected_len
, "unexpected len %u\n", len
);
1437 ok( str
->Buffer
&& !memcmp( str
->Buffer
, type_iocompletion
, sizeof(type_iocompletion
) ),
1438 "wrong/bad type name %s (%p)\n", wine_dbgstr_w(str
->Buffer
), str
->Buffer
);
1441 status
= pNtCreateDirectoryObject( &handle
, DIRECTORY_QUERY
, NULL
);
1442 ok(status
== STATUS_SUCCESS
, "Failed to create Directory %08x\n", status
);
1444 memset( buffer
, 0, sizeof(buffer
) );
1445 status
= pNtQueryObject( handle
, ObjectTypeInformation
, buffer
, sizeof(buffer
), &len
);
1446 ok( status
== STATUS_SUCCESS
, "NtQueryObject failed %x\n", status
);
1447 ok( len
> sizeof(OBJECT_TYPE_INFORMATION
), "unexpected len %u\n", len
);
1448 str
= (UNICODE_STRING
*)buffer
;
1449 expected_len
= sizeof(OBJECT_TYPE_INFORMATION
) + str
->Length
+ sizeof(WCHAR
);
1450 ok( len
>= expected_len
, "unexpected len %u\n", len
);
1451 ok( str
->Buffer
&& !memcmp( str
->Buffer
, type_directory
, sizeof(type_directory
) ),
1452 "wrong/bad type name %s (%p)\n", wine_dbgstr_w(str
->Buffer
), str
->Buffer
);
1455 size
.u
.LowPart
= 256;
1456 size
.u
.HighPart
= 0;
1457 status
= pNtCreateSection( &handle
, SECTION_MAP_WRITE
, NULL
, &size
, PAGE_READWRITE
, SEC_COMMIT
, 0 );
1458 ok( status
== STATUS_SUCCESS
, "NtCreateSection returned %x\n", status
);
1460 memset( buffer
, 0, sizeof(buffer
) );
1461 status
= pNtQueryObject( handle
, ObjectTypeInformation
, buffer
, sizeof(buffer
), &len
);
1462 ok( status
== STATUS_SUCCESS
, "NtQueryObject failed %x\n", status
);
1463 ok( len
> sizeof(OBJECT_TYPE_INFORMATION
), "unexpected len %u\n", len
);
1464 str
= (UNICODE_STRING
*)buffer
;
1465 expected_len
= sizeof(OBJECT_TYPE_INFORMATION
) + str
->Length
+ sizeof(WCHAR
);
1466 ok( len
>= expected_len
, "unexpected len %u\n", len
);
1467 ok( str
->Buffer
&& !memcmp( str
->Buffer
, type_section
, sizeof(type_section
) ),
1468 "wrong/bad type name %s (%p)\n", wine_dbgstr_w(str
->Buffer
), str
->Buffer
);
1471 handle
= CreateMailslotA( "\\\\.\\mailslot\\test_mailslot", 100, 1000, NULL
);
1472 ok( handle
!= INVALID_HANDLE_VALUE
, "CreateMailslot failed err %u\n", GetLastError() );
1474 status
= pNtQueryObject( handle
, ObjectNameInformation
, buffer
, sizeof(buffer
), &len
);
1475 ok( status
== STATUS_SUCCESS
, "NtQueryObject returned %x\n", status
);
1476 str
= (UNICODE_STRING
*)buffer
;
1477 ok( len
> sizeof(UNICODE_STRING
), "unexpected len %u\n", len
);
1478 str
= (UNICODE_STRING
*)buffer
;
1479 expected_len
= sizeof(UNICODE_STRING
) + str
->Length
+ sizeof(WCHAR
);
1480 ok( len
== expected_len
|| broken(len
== expected_len
- sizeof(WCHAR
)), /* NT4 */
1481 "unexpected len %u\n", len
);
1482 ok( len
> sizeof(UNICODE_STRING
) + sizeof("\\test_mailslot") * sizeof(WCHAR
),
1483 "name too short %s\n", wine_dbgstr_w(str
->Buffer
) );
1484 trace( "got %s len %u\n", wine_dbgstr_w(str
->Buffer
), len
);
1487 handle
= CreateNamedPipeA( "\\\\.\\pipe\\test_pipe", PIPE_ACCESS_DUPLEX
, PIPE_READMODE_BYTE
,
1488 1, 1000, 1000, 1000, NULL
);
1489 ok( handle
!= INVALID_HANDLE_VALUE
, "CreateNamedPipe failed err %u\n", GetLastError() );
1491 status
= pNtQueryObject( handle
, ObjectNameInformation
, buffer
, sizeof(buffer
), &len
);
1492 ok( status
== STATUS_SUCCESS
, "NtQueryObject returned %x\n", status
);
1493 str
= (UNICODE_STRING
*)buffer
;
1495 ok( len
> sizeof(UNICODE_STRING
), "unexpected len %u\n", len
);
1496 str
= (UNICODE_STRING
*)buffer
;
1497 expected_len
= sizeof(UNICODE_STRING
) + str
->Length
+ sizeof(WCHAR
);
1499 ok( len
== expected_len
|| broken(len
== expected_len
- sizeof(WCHAR
)), /* NT4 */
1500 "unexpected len %u\n", len
);
1502 ok( len
> sizeof(UNICODE_STRING
) + sizeof("\\test_pipe") * sizeof(WCHAR
),
1503 "name too short %s\n", wine_dbgstr_w(str
->Buffer
) );
1504 trace( "got %s len %u\n", wine_dbgstr_w(str
->Buffer
), len
);
1507 pRtlCreateUnicodeStringFromAsciiz( &path
, "\\REGISTRY\\Machine\\Software\\Classes" );
1508 status
= pNtCreateKey( &handle
, KEY_ALL_ACCESS
, &attr
, 0, 0, 0, 0 );
1509 ok( status
== STATUS_SUCCESS
|| status
== STATUS_ACCESS_DENIED
,
1510 "NtCreateKey failed status %x\n", status
);
1511 pRtlFreeUnicodeString( &path
);
1512 if (status
== STATUS_SUCCESS
)
1515 status
= pNtQueryObject( handle
, ObjectNameInformation
, buffer
, sizeof(buffer
), &len
);
1516 ok( status
== STATUS_SUCCESS
, "NtQueryObject returned %x\n", status
);
1517 str
= (UNICODE_STRING
*)buffer
;
1519 ok( len
> sizeof(UNICODE_STRING
), "unexpected len %u\n", len
);
1520 str
= (UNICODE_STRING
*)buffer
;
1521 expected_len
= sizeof(UNICODE_STRING
) + str
->Length
+ sizeof(WCHAR
);
1523 ok( len
== expected_len
|| broken(len
== expected_len
- sizeof(WCHAR
)), /* NT4 */
1524 "unexpected len %u\n", len
);
1526 ok( len
> sizeof(UNICODE_STRING
) + sizeof("\\Classes") * sizeof(WCHAR
),
1527 "name too short %s\n", wine_dbgstr_w(str
->Buffer
) );
1528 trace( "got %s len %u\n", wine_dbgstr_w(str
->Buffer
), len
);
1533 static void test_type_mismatch(void)
1537 OBJECT_ATTRIBUTES attr
;
1539 attr
.Length
= sizeof(attr
);
1540 attr
.RootDirectory
= 0;
1541 attr
.ObjectName
= NULL
;
1542 attr
.Attributes
= 0;
1543 attr
.SecurityDescriptor
= NULL
;
1544 attr
.SecurityQualityOfService
= NULL
;
1546 res
= pNtCreateEvent( &h
, 0, &attr
, 0, 0 );
1547 ok(!res
, "can't create event: %x\n", res
);
1549 res
= pNtReleaseSemaphore( h
, 30, NULL
);
1550 ok(res
== STATUS_OBJECT_TYPE_MISMATCH
, "expected 0xc0000024, got %x\n", res
);
1555 static void test_event(void)
1561 OBJECT_ATTRIBUTES attr
;
1562 EVENT_BASIC_INFORMATION info
;
1563 static const WCHAR eventName
[] = {'\\','B','a','s','e','N','a','m','e','d','O','b','j','e','c','t','s','\\','t','e','s','t','E','v','e','n','t',0};
1565 pRtlInitUnicodeString(&str
, eventName
);
1566 InitializeObjectAttributes(&attr
, &str
, 0, 0, NULL
);
1568 status
= pNtCreateEvent(&Event
, GENERIC_ALL
, &attr
, 1, 0);
1569 ok( status
== STATUS_SUCCESS
, "NtCreateEvent failed %08x\n", status
);
1571 status
= pNtPulseEvent(Event
, NULL
);
1572 ok( status
== STATUS_SUCCESS
, "NtPulseEvent failed %08x\n", status
);
1574 status
= pNtQueryEvent(Event
, EventBasicInformation
, &info
, sizeof(info
), NULL
);
1575 ok( status
== STATUS_SUCCESS
, "NtQueryEvent failed %08x\n", status
);
1576 ok( info
.EventType
== 1 && info
.EventState
== 0,
1577 "NtQueryEvent failed, expected 1 0, got %d %d\n", info
.EventType
, info
.EventState
);
1579 status
= pNtOpenEvent(&Event2
, GENERIC_ALL
, &attr
);
1580 ok( status
== STATUS_SUCCESS
, "NtOpenEvent failed %08x\n", status
);
1584 status
= pNtQueryEvent(Event2
, EventBasicInformation
, &info
, sizeof(info
), NULL
);
1585 ok( status
== STATUS_SUCCESS
, "NtQueryEvent failed %08x\n", status
);
1586 ok( info
.EventType
== 1 && info
.EventState
== 0,
1587 "NtQueryEvent failed, expected 1 0, got %d %d\n", info
.EventType
, info
.EventState
);
1592 static const WCHAR keyed_nameW
[] = {'\\','B','a','s','e','N','a','m','e','d','O','b','j','e','c','t','s',
1593 '\\','W','i','n','e','T','e','s','t','E','v','e','n','t',0};
1595 static DWORD WINAPI
keyed_event_thread( void *arg
)
1599 LARGE_INTEGER timeout
;
1600 OBJECT_ATTRIBUTES attr
;
1604 attr
.Length
= sizeof(attr
);
1605 attr
.RootDirectory
= 0;
1606 attr
.ObjectName
= &str
;
1607 attr
.Attributes
= 0;
1608 attr
.SecurityDescriptor
= NULL
;
1609 attr
.SecurityQualityOfService
= NULL
;
1610 RtlInitUnicodeString( &str
, keyed_nameW
);
1612 status
= pNtOpenKeyedEvent( &handle
, KEYEDEVENT_ALL_ACCESS
, &attr
);
1613 ok( !status
, "NtOpenKeyedEvent failed %x\n", status
);
1615 for (i
= 0; i
< 20; i
++)
1618 status
= pNtWaitForKeyedEvent( handle
, (void *)(i
* 2), 0, NULL
);
1620 status
= pNtReleaseKeyedEvent( handle
, (void *)(i
* 2), 0, NULL
);
1621 ok( status
== STATUS_SUCCESS
, "%li: failed %x\n", i
, status
);
1625 status
= pNtReleaseKeyedEvent( handle
, (void *)0x1234, 0, NULL
);
1626 ok( status
== STATUS_SUCCESS
, "NtReleaseKeyedEvent %x\n", status
);
1628 timeout
.QuadPart
= -10000;
1629 status
= pNtWaitForKeyedEvent( handle
, (void *)0x5678, 0, &timeout
);
1630 ok( status
== STATUS_TIMEOUT
, "NtWaitForKeyedEvent %x\n", status
);
1631 status
= pNtReleaseKeyedEvent( handle
, (void *)0x9abc, 0, &timeout
);
1632 ok( status
== STATUS_TIMEOUT
, "NtReleaseKeyedEvent %x\n", status
);
1638 static void test_keyed_events(void)
1640 OBJECT_ATTRIBUTES attr
;
1642 HANDLE handle
, event
, thread
;
1644 LARGE_INTEGER timeout
;
1647 if (!pNtCreateKeyedEvent
)
1649 win_skip( "Keyed events not supported\n" );
1653 attr
.Length
= sizeof(attr
);
1654 attr
.RootDirectory
= 0;
1655 attr
.ObjectName
= &str
;
1656 attr
.Attributes
= 0;
1657 attr
.SecurityDescriptor
= NULL
;
1658 attr
.SecurityQualityOfService
= NULL
;
1659 RtlInitUnicodeString( &str
, keyed_nameW
);
1661 status
= pNtCreateKeyedEvent( &handle
, KEYEDEVENT_ALL_ACCESS
| SYNCHRONIZE
, &attr
, 0 );
1662 ok( !status
, "NtCreateKeyedEvent failed %x\n", status
);
1664 status
= WaitForSingleObject( handle
, 1000 );
1665 ok( status
== 0, "WaitForSingleObject %x\n", status
);
1667 timeout
.QuadPart
= -100000;
1668 status
= pNtWaitForKeyedEvent( handle
, (void *)255, 0, &timeout
);
1669 ok( status
== STATUS_INVALID_PARAMETER_1
, "NtWaitForKeyedEvent %x\n", status
);
1670 status
= pNtReleaseKeyedEvent( handle
, (void *)255, 0, &timeout
);
1671 ok( status
== STATUS_INVALID_PARAMETER_1
, "NtReleaseKeyedEvent %x\n", status
);
1673 status
= pNtWaitForKeyedEvent( handle
, (void *)254, 0, &timeout
);
1674 ok( status
== STATUS_TIMEOUT
, "NtWaitForKeyedEvent %x\n", status
);
1675 status
= pNtReleaseKeyedEvent( handle
, (void *)254, 0, &timeout
);
1676 ok( status
== STATUS_TIMEOUT
, "NtReleaseKeyedEvent %x\n", status
);
1678 status
= pNtWaitForKeyedEvent( handle
, NULL
, 0, &timeout
);
1679 ok( status
== STATUS_TIMEOUT
, "NtWaitForKeyedEvent %x\n", status
);
1680 status
= pNtReleaseKeyedEvent( handle
, NULL
, 0, &timeout
);
1681 ok( status
== STATUS_TIMEOUT
, "NtReleaseKeyedEvent %x\n", status
);
1683 status
= pNtWaitForKeyedEvent( (HANDLE
)0xdeadbeef, (void *)9, 0, &timeout
);
1684 ok( status
== STATUS_INVALID_PARAMETER_1
, "NtWaitForKeyedEvent %x\n", status
);
1685 status
= pNtReleaseKeyedEvent( (HANDLE
)0xdeadbeef, (void *)9, 0, &timeout
);
1686 ok( status
== STATUS_INVALID_PARAMETER_1
, "NtReleaseKeyedEvent %x\n", status
);
1688 status
= pNtWaitForKeyedEvent( (HANDLE
)0xdeadbeef, (void *)8, 0, &timeout
);
1689 ok( status
== STATUS_INVALID_HANDLE
, "NtWaitForKeyedEvent %x\n", status
);
1690 status
= pNtReleaseKeyedEvent( (HANDLE
)0xdeadbeef, (void *)8, 0, &timeout
);
1691 ok( status
== STATUS_INVALID_HANDLE
, "NtReleaseKeyedEvent %x\n", status
);
1693 thread
= CreateThread( NULL
, 0, keyed_event_thread
, 0, 0, NULL
);
1694 for (i
= 0; i
< 20; i
++)
1697 status
= pNtReleaseKeyedEvent( handle
, (void *)(i
* 2), 0, NULL
);
1699 status
= pNtWaitForKeyedEvent( handle
, (void *)(i
* 2), 0, NULL
);
1700 ok( status
== STATUS_SUCCESS
, "%li: failed %x\n", i
, status
);
1703 status
= pNtWaitForKeyedEvent( handle
, (void *)0x1234, 0, &timeout
);
1704 ok( status
== STATUS_SUCCESS
, "NtWaitForKeyedEvent %x\n", status
);
1705 status
= pNtWaitForKeyedEvent( handle
, (void *)0x5678, 0, &timeout
);
1706 ok( status
== STATUS_TIMEOUT
, "NtWaitForKeyedEvent %x\n", status
);
1707 status
= pNtReleaseKeyedEvent( handle
, (void *)0x9abc, 0, &timeout
);
1708 ok( status
== STATUS_TIMEOUT
, "NtReleaseKeyedEvent %x\n", status
);
1710 ok( WaitForSingleObject( thread
, 30000 ) == 0, "wait failed\n" );
1714 /* test access rights */
1716 status
= pNtCreateKeyedEvent( &handle
, KEYEDEVENT_WAIT
, &attr
, 0 );
1717 ok( !status
, "NtCreateKeyedEvent failed %x\n", status
);
1718 status
= pNtWaitForKeyedEvent( handle
, (void *)8, 0, &timeout
);
1719 ok( status
== STATUS_TIMEOUT
, "NtWaitForKeyedEvent %x\n", status
);
1720 status
= pNtReleaseKeyedEvent( handle
, (void *)8, 0, &timeout
);
1721 ok( status
== STATUS_ACCESS_DENIED
, "NtReleaseKeyedEvent %x\n", status
);
1724 status
= pNtCreateKeyedEvent( &handle
, KEYEDEVENT_WAKE
, &attr
, 0 );
1725 ok( !status
, "NtCreateKeyedEvent failed %x\n", status
);
1726 status
= pNtWaitForKeyedEvent( handle
, (void *)8, 0, &timeout
);
1727 ok( status
== STATUS_ACCESS_DENIED
, "NtWaitForKeyedEvent %x\n", status
);
1728 status
= pNtReleaseKeyedEvent( handle
, (void *)8, 0, &timeout
);
1729 ok( status
== STATUS_TIMEOUT
, "NtReleaseKeyedEvent %x\n", status
);
1732 status
= pNtCreateKeyedEvent( &handle
, KEYEDEVENT_ALL_ACCESS
, &attr
, 0 );
1733 ok( !status
, "NtCreateKeyedEvent failed %x\n", status
);
1734 status
= WaitForSingleObject( handle
, 1000 );
1735 ok( status
== WAIT_FAILED
&& GetLastError() == ERROR_ACCESS_DENIED
,
1736 "WaitForSingleObject %x err %u\n", status
, GetLastError() );
1737 status
= pNtWaitForKeyedEvent( handle
, (void *)8, 0, &timeout
);
1738 ok( status
== STATUS_TIMEOUT
, "NtWaitForKeyedEvent %x\n", status
);
1739 status
= pNtReleaseKeyedEvent( handle
, (void *)8, 0, &timeout
);
1740 ok( status
== STATUS_TIMEOUT
, "NtReleaseKeyedEvent %x\n", status
);
1743 /* GENERIC_READ gives wait access */
1744 status
= pNtCreateKeyedEvent( &handle
, GENERIC_READ
, &attr
, 0 );
1745 ok( !status
, "NtCreateKeyedEvent failed %x\n", status
);
1746 status
= pNtWaitForKeyedEvent( handle
, (void *)8, 0, &timeout
);
1747 ok( status
== STATUS_TIMEOUT
, "NtWaitForKeyedEvent %x\n", status
);
1748 status
= pNtReleaseKeyedEvent( handle
, (void *)8, 0, &timeout
);
1749 ok( status
== STATUS_ACCESS_DENIED
, "NtReleaseKeyedEvent %x\n", status
);
1752 /* GENERIC_WRITE gives wake access */
1753 status
= pNtCreateKeyedEvent( &handle
, GENERIC_WRITE
, &attr
, 0 );
1754 ok( !status
, "NtCreateKeyedEvent failed %x\n", status
);
1755 status
= pNtWaitForKeyedEvent( handle
, (void *)8, 0, &timeout
);
1756 ok( status
== STATUS_ACCESS_DENIED
, "NtWaitForKeyedEvent %x\n", status
);
1757 status
= pNtReleaseKeyedEvent( handle
, (void *)8, 0, &timeout
);
1758 ok( status
== STATUS_TIMEOUT
, "NtReleaseKeyedEvent %x\n", status
);
1760 /* it's not an event */
1761 status
= pNtPulseEvent( handle
, NULL
);
1762 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
, "NtPulseEvent %x\n", status
);
1764 status
= pNtCreateEvent( &event
, GENERIC_ALL
, &attr
, FALSE
, FALSE
);
1765 ok( status
== STATUS_OBJECT_NAME_COLLISION
|| status
== STATUS_OBJECT_TYPE_MISMATCH
,
1766 "CreateEvent %x\n", status
);
1770 status
= pNtCreateEvent( &event
, GENERIC_ALL
, &attr
, FALSE
, FALSE
);
1771 ok( status
== 0, "CreateEvent %x\n", status
);
1772 status
= pNtWaitForKeyedEvent( event
, (void *)8, 0, &timeout
);
1773 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
, "NtWaitForKeyedEvent %x\n", status
);
1774 status
= pNtReleaseKeyedEvent( event
, (void *)8, 0, &timeout
);
1775 ok( status
== STATUS_OBJECT_TYPE_MISMATCH
, "NtReleaseKeyedEvent %x\n", status
);
1779 static void test_null_device(void)
1781 OBJECT_ATTRIBUTES attr
;
1782 IO_STATUS_BLOCK iosb
;
1791 memset(buf
, 0xAA, sizeof(buf
));
1792 memset(&ov
, 0, sizeof(ov
));
1793 ov
.hEvent
= CreateEventA(NULL
, TRUE
, FALSE
, NULL
);
1795 pRtlCreateUnicodeStringFromAsciiz(&str
, "\\Device\\Null");
1796 InitializeObjectAttributes(&attr
, &str
, OBJ_CASE_INSENSITIVE
, 0, NULL
);
1797 status
= pNtOpenSymbolicLinkObject(&null
, SYMBOLIC_LINK_QUERY
, &attr
);
1798 ok(status
== STATUS_OBJECT_TYPE_MISMATCH
,
1799 "expected STATUS_OBJECT_TYPE_MISMATCH, got %08x\n", status
);
1801 status
= pNtOpenFile(&null
, GENERIC_READ
| GENERIC_WRITE
, &attr
, &iosb
,
1802 FILE_SHARE_READ
| FILE_SHARE_WRITE
, 0);
1803 ok(status
== STATUS_SUCCESS
,
1804 "expected STATUS_SUCCESS, got %08x\n", status
);
1806 SetLastError(0xdeadbeef);
1807 ret
= WriteFile(null
, buf
, sizeof(buf
), &num_bytes
, NULL
);
1808 ok(!ret
, "WriteFile unexpectedly succeeded\n");
1809 ok(GetLastError() == ERROR_INVALID_PARAMETER
,
1810 "expected ERROR_INVALID_PARAMETER, got %u\n", GetLastError());
1812 SetLastError(0xdeadbeef);
1813 ret
= ReadFile(null
, buf
, sizeof(buf
), &num_bytes
, NULL
);
1814 ok(!ret
, "ReadFile unexpectedly succeeded\n");
1815 ok(GetLastError() == ERROR_INVALID_PARAMETER
,
1816 "expected ERROR_INVALID_PARAMETER, got %u\n", GetLastError());
1818 num_bytes
= 0xdeadbeef;
1819 SetLastError(0xdeadbeef);
1820 ret
= WriteFile(null
, buf
, sizeof(buf
), &num_bytes
, &ov
);
1821 if (ret
|| GetLastError() != ERROR_IO_PENDING
)
1823 ok(ret
, "WriteFile failed with error %u\n", GetLastError());
1827 num_bytes
= 0xdeadbeef;
1828 ret
= GetOverlappedResult(null
, &ov
, &num_bytes
, TRUE
);
1829 ok(ret
, "GetOverlappedResult failed with error %u\n", GetLastError());
1831 ok(num_bytes
== sizeof(buf
), "expected num_bytes = %u, got %u\n",
1832 (DWORD
)sizeof(buf
), num_bytes
);
1834 num_bytes
= 0xdeadbeef;
1835 SetLastError(0xdeadbeef);
1836 ret
= ReadFile(null
, buf
, sizeof(buf
), &num_bytes
, &ov
);
1837 if (ret
|| GetLastError() != ERROR_IO_PENDING
)
1839 ok(!ret
, "ReadFile unexpectedly succeeded\n");
1843 num_bytes
= 0xdeadbeef;
1844 ret
= GetOverlappedResult(null
, &ov
, &num_bytes
, TRUE
);
1845 ok(!ret
, "GetOverlappedResult unexpectedly succeeded\n");
1847 ok(GetLastError() == ERROR_HANDLE_EOF
,
1848 "expected ERROR_HANDLE_EOF, got %u\n", GetLastError());
1852 null
= CreateFileA("\\\\.\\Null", GENERIC_READ
| GENERIC_WRITE
,
1853 FILE_SHARE_READ
| FILE_SHARE_WRITE
, NULL
,
1854 OPEN_EXISTING
, FILE_ATTRIBUTE_NORMAL
, NULL
);
1855 ok(null
== INVALID_HANDLE_VALUE
, "CreateFileA unexpectedly succeeded\n");
1856 ok(GetLastError() == ERROR_FILE_NOT_FOUND
,
1857 "expected ERROR_FILE_NOT_FOUND, got %u\n", GetLastError());
1859 null
= CreateFileA("\\\\.\\Device\\Null", GENERIC_READ
| GENERIC_WRITE
,
1860 FILE_SHARE_READ
| FILE_SHARE_WRITE
, NULL
,
1861 OPEN_EXISTING
, FILE_ATTRIBUTE_NORMAL
, NULL
);
1862 ok(null
== INVALID_HANDLE_VALUE
, "CreateFileA unexpectedly succeeded\n");
1863 ok(GetLastError() == ERROR_PATH_NOT_FOUND
,
1864 "expected ERROR_PATH_NOT_FOUND, got %u\n", GetLastError());
1866 pRtlFreeUnicodeString(&str
);
1867 CloseHandle(ov
.hEvent
);
1870 static DWORD WINAPI
mutant_thread( void *arg
)
1872 MUTANT_BASIC_INFORMATION info
;
1878 ret
= WaitForSingleObject( mutant
, 1000 );
1879 ok( ret
== WAIT_OBJECT_0
, "WaitForSingleObject failed %08x\n", ret
);
1881 memset(&info
, 0xcc, sizeof(info
));
1882 status
= pNtQueryMutant(mutant
, MutantBasicInformation
, &info
, sizeof(info
), NULL
);
1883 ok( status
== STATUS_SUCCESS
, "NtQueryMutant failed %08x\n", status
);
1884 ok( info
.CurrentCount
== 0, "expected 0, got %d\n", info
.CurrentCount
);
1885 ok( info
.OwnedByCaller
== TRUE
, "expected TRUE, got %d\n", info
.OwnedByCaller
);
1886 ok( info
.AbandonedState
== FALSE
, "expected FALSE, got %d\n", info
.AbandonedState
);
1887 /* abandon mutant */
1892 static void test_mutant(void)
1894 static const WCHAR name
[] = {'\\','B','a','s','e','N','a','m','e','d','O','b','j','e','c','t','s',
1895 '\\','t','e','s','t','_','m','u','t','a','n','t',0};
1896 MUTANT_BASIC_INFORMATION info
;
1897 OBJECT_ATTRIBUTES attr
;
1906 pRtlInitUnicodeString(&str
, name
);
1907 InitializeObjectAttributes(&attr
, &str
, 0, 0, NULL
);
1908 status
= pNtCreateMutant(&mutant
, GENERIC_ALL
, &attr
, TRUE
);
1909 ok( status
== STATUS_SUCCESS
, "Failed to create Mutant(%08x)\n", status
);
1912 status
= pNtQueryMutant(mutant
, MutantBasicInformation
, &info
, 0, NULL
);
1913 ok( status
== STATUS_INFO_LENGTH_MISMATCH
,
1914 "Failed to NtQueryMutant, expected STATUS_INFO_LENGTH_MISMATCH, got %08x\n", status
);
1915 status
= pNtQueryMutant(mutant
, 0x42, &info
, sizeof(info
), NULL
);
1916 ok( status
== STATUS_INVALID_INFO_CLASS
|| broken(status
== STATUS_NOT_IMPLEMENTED
), /* 32-bit on Vista/2k8 */
1917 "Failed to NtQueryMutant, expected STATUS_INVALID_INFO_CLASS, got %08x\n", status
);
1918 status
= pNtQueryMutant((HANDLE
)0xdeadbeef, MutantBasicInformation
, &info
, sizeof(info
), NULL
);
1919 ok( status
== STATUS_INVALID_HANDLE
,
1920 "Failed to NtQueryMutant, expected STATUS_INVALID_HANDLE, got %08x\n", status
);
1924 memset(&info
, 0xcc, sizeof(info
));
1925 status
= pNtQueryMutant(mutant
, MutantBasicInformation
, &info
, sizeof(info
), &len
);
1926 ok( status
== STATUS_SUCCESS
, "NtQueryMutant failed %08x\n", status
);
1927 ok( info
.CurrentCount
== 0, "expected 0, got %d\n", info
.CurrentCount
);
1928 ok( info
.OwnedByCaller
== TRUE
, "expected TRUE, got %d\n", info
.OwnedByCaller
);
1929 ok( info
.AbandonedState
== FALSE
, "expected FALSE, got %d\n", info
.AbandonedState
);
1930 ok( len
== sizeof(info
), "got %u\n", len
);
1932 ret
= WaitForSingleObject( mutant
, 1000 );
1933 ok( ret
== WAIT_OBJECT_0
, "WaitForSingleObject failed %08x\n", ret
);
1935 memset(&info
, 0xcc, sizeof(info
));
1936 status
= pNtQueryMutant(mutant
, MutantBasicInformation
, &info
, sizeof(info
), NULL
);
1937 ok( status
== STATUS_SUCCESS
, "NtQueryMutant failed %08x\n", status
);
1938 ok( info
.CurrentCount
== -1, "expected -1, got %d\n", info
.CurrentCount
);
1939 ok( info
.OwnedByCaller
== TRUE
, "expected TRUE, got %d\n", info
.OwnedByCaller
);
1940 ok( info
.AbandonedState
== FALSE
, "expected FALSE, got %d\n", info
.AbandonedState
);
1943 status
= pNtReleaseMutant(mutant
, &prev
);
1944 ok( status
== STATUS_SUCCESS
, "NtQueryRelease failed %08x\n", status
);
1945 ok( prev
== -1, "NtQueryRelease failed, expected -1, got %d\n", prev
);
1948 status
= pNtReleaseMutant(mutant
, &prev
);
1949 ok( status
== STATUS_SUCCESS
, "NtQueryRelease failed %08x\n", status
);
1950 ok( prev
== 0, "NtQueryRelease failed, expected 0, got %d\n", prev
);
1952 memset(&info
, 0xcc, sizeof(info
));
1953 status
= pNtQueryMutant(mutant
, MutantBasicInformation
, &info
, sizeof(info
), NULL
);
1954 ok( status
== STATUS_SUCCESS
, "NtQueryMutant failed %08x\n", status
);
1955 ok( info
.CurrentCount
== 1, "expected 1, got %d\n", info
.CurrentCount
);
1956 ok( info
.OwnedByCaller
== FALSE
, "expected FALSE, got %d\n", info
.OwnedByCaller
);
1957 ok( info
.AbandonedState
== FALSE
, "expected FALSE, got %d\n", info
.AbandonedState
);
1960 thread
= CreateThread( NULL
, 0, mutant_thread
, mutant
, 0, NULL
);
1961 ret
= WaitForSingleObject( thread
, 1000 );
1962 ok( ret
== WAIT_OBJECT_0
, "WaitForSingleObject failed %08x\n", ret
);
1963 CloseHandle( thread
);
1965 memset(&info
, 0xcc, sizeof(info
));
1966 status
= pNtQueryMutant(mutant
, MutantBasicInformation
, &info
, sizeof(info
), NULL
);
1967 ok( status
== STATUS_SUCCESS
, "NtQueryMutant failed %08x\n", status
);
1968 ok( info
.CurrentCount
== 1, "expected 0, got %d\n", info
.CurrentCount
);
1969 ok( info
.OwnedByCaller
== FALSE
, "expected FALSE, got %d\n", info
.OwnedByCaller
);
1970 ok( info
.AbandonedState
== TRUE
, "expected TRUE, got %d\n", info
.AbandonedState
);
1972 ret
= WaitForSingleObject( mutant
, 1000 );
1973 ok( ret
== WAIT_ABANDONED_0
, "WaitForSingleObject failed %08x\n", ret
);
1975 memset(&info
, 0xcc, sizeof(info
));
1976 status
= pNtQueryMutant(mutant
, MutantBasicInformation
, &info
, sizeof(info
), NULL
);
1977 ok( status
== STATUS_SUCCESS
, "NtQueryMutant failed %08x\n", status
);
1978 ok( info
.CurrentCount
== 0, "expected 0, got %d\n", info
.CurrentCount
);
1979 ok( info
.OwnedByCaller
== TRUE
, "expected TRUE, got %d\n", info
.OwnedByCaller
);
1980 ok( info
.AbandonedState
== FALSE
, "expected FALSE, got %d\n", info
.AbandonedState
);
1987 HMODULE hntdll
= GetModuleHandleA("ntdll.dll");
1988 HMODULE hkernel32
= GetModuleHandleA("kernel32.dll");
1992 skip("not running on NT, skipping test\n");
1996 pCreateWaitableTimerA
= (void *)GetProcAddress(hkernel32
, "CreateWaitableTimerA");
1998 pRtlCreateUnicodeStringFromAsciiz
= (void *)GetProcAddress(hntdll
, "RtlCreateUnicodeStringFromAsciiz");
1999 pRtlFreeUnicodeString
= (void *)GetProcAddress(hntdll
, "RtlFreeUnicodeString");
2000 pNtCreateEvent
= (void *)GetProcAddress(hntdll
, "NtCreateEvent");
2001 pNtCreateJobObject
= (void *)GetProcAddress(hntdll
, "NtCreateJobObject");
2002 pNtOpenJobObject
= (void *)GetProcAddress(hntdll
, "NtOpenJobObject");
2003 pNtCreateKey
= (void *)GetProcAddress(hntdll
, "NtCreateKey");
2004 pNtOpenKey
= (void *)GetProcAddress(hntdll
, "NtOpenKey");
2005 pNtDeleteKey
= (void *)GetProcAddress(hntdll
, "NtDeleteKey");
2006 pNtCreateMailslotFile
= (void *)GetProcAddress(hntdll
, "NtCreateMailslotFile");
2007 pNtCreateMutant
= (void *)GetProcAddress(hntdll
, "NtCreateMutant");
2008 pNtOpenEvent
= (void *)GetProcAddress(hntdll
, "NtOpenEvent");
2009 pNtQueryEvent
= (void *)GetProcAddress(hntdll
, "NtQueryEvent");
2010 pNtPulseEvent
= (void *)GetProcAddress(hntdll
, "NtPulseEvent");
2011 pNtOpenMutant
= (void *)GetProcAddress(hntdll
, "NtOpenMutant");
2012 pNtQueryMutant
= (void *)GetProcAddress(hntdll
, "NtQueryMutant");
2013 pNtReleaseMutant
= (void *)GetProcAddress(hntdll
, "NtReleaseMutant");
2014 pNtOpenFile
= (void *)GetProcAddress(hntdll
, "NtOpenFile");
2015 pNtClose
= (void *)GetProcAddress(hntdll
, "NtClose");
2016 pRtlInitUnicodeString
= (void *)GetProcAddress(hntdll
, "RtlInitUnicodeString");
2017 pNtCreateNamedPipeFile
= (void *)GetProcAddress(hntdll
, "NtCreateNamedPipeFile");
2018 pNtOpenDirectoryObject
= (void *)GetProcAddress(hntdll
, "NtOpenDirectoryObject");
2019 pNtCreateDirectoryObject
= (void *)GetProcAddress(hntdll
, "NtCreateDirectoryObject");
2020 pNtOpenSymbolicLinkObject
= (void *)GetProcAddress(hntdll
, "NtOpenSymbolicLinkObject");
2021 pNtCreateSymbolicLinkObject
= (void *)GetProcAddress(hntdll
, "NtCreateSymbolicLinkObject");
2022 pNtQuerySymbolicLinkObject
= (void *)GetProcAddress(hntdll
, "NtQuerySymbolicLinkObject");
2023 pNtCreateSemaphore
= (void *)GetProcAddress(hntdll
, "NtCreateSemaphore");
2024 pNtOpenSemaphore
= (void *)GetProcAddress(hntdll
, "NtOpenSemaphore");
2025 pNtCreateTimer
= (void *)GetProcAddress(hntdll
, "NtCreateTimer");
2026 pNtOpenTimer
= (void *)GetProcAddress(hntdll
, "NtOpenTimer");
2027 pNtCreateSection
= (void *)GetProcAddress(hntdll
, "NtCreateSection");
2028 pNtOpenSection
= (void *)GetProcAddress(hntdll
, "NtOpenSection");
2029 pNtQueryObject
= (void *)GetProcAddress(hntdll
, "NtQueryObject");
2030 pNtReleaseSemaphore
= (void *)GetProcAddress(hntdll
, "NtReleaseSemaphore");
2031 pNtCreateKeyedEvent
= (void *)GetProcAddress(hntdll
, "NtCreateKeyedEvent");
2032 pNtOpenKeyedEvent
= (void *)GetProcAddress(hntdll
, "NtOpenKeyedEvent");
2033 pNtWaitForKeyedEvent
= (void *)GetProcAddress(hntdll
, "NtWaitForKeyedEvent");
2034 pNtReleaseKeyedEvent
= (void *)GetProcAddress(hntdll
, "NtReleaseKeyedEvent");
2035 pNtCreateIoCompletion
= (void *)GetProcAddress(hntdll
, "NtCreateIoCompletion");
2036 pNtOpenIoCompletion
= (void *)GetProcAddress(hntdll
, "NtOpenIoCompletion");
2038 test_case_sensitive();
2039 test_namespace_pipe();
2040 test_name_collisions();
2043 test_symboliclink();
2044 test_query_object();
2045 test_type_mismatch();
2048 test_keyed_events();