+/*\r
+ * Unit test suite for object manager functions\r
+ *\r
+ * Copyright 2005 Robert Shearman\r
+ * Copyright 2005 Vitaliy Margolen\r
+ *\r
+ * This library is free software; you can redistribute it and/or\r
+ * modify it under the terms of the GNU Lesser General Public\r
+ * License as published by the Free Software Foundation; either\r
+ * version 2.1 of the License, or (at your option) any later version.\r
+ *\r
+ * This library is distributed in the hope that it will be useful,\r
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of\r
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU\r
+ * Lesser General Public License for more details.\r
+ *\r
+ * You should have received a copy of the GNU Lesser General Public\r
+ * License along with this library; if not, write to the Free Software\r
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA\r
+ */\r
+\r
+#include "ntdll_test.h"\r
+#include "winternl.h"\r
+#include "stdio.h"\r
+#include "winnt.h"\r
+#include "stdlib.h"\r
+\r
+static NTSTATUS (WINAPI *pRtlCreateUnicodeStringFromAsciiz)(PUNICODE_STRING, LPCSTR);\r
+static VOID (WINAPI *pRtlInitUnicodeString)( PUNICODE_STRING, LPCWSTR );\r
+static VOID (WINAPI *pRtlFreeUnicodeString)(PUNICODE_STRING);\r
+static NTSTATUS (WINAPI *pNtCreateEvent) ( PHANDLE, ACCESS_MASK, const POBJECT_ATTRIBUTES, BOOLEAN, BOOLEAN);\r
+static NTSTATUS (WINAPI *pNtCreateMutant)( PHANDLE, ACCESS_MASK, const POBJECT_ATTRIBUTES, BOOLEAN );\r
+static NTSTATUS (WINAPI *pNtOpenMutant) ( PHANDLE, ACCESS_MASK, const POBJECT_ATTRIBUTES );\r
+static NTSTATUS (WINAPI *pNtCreateSemaphore)( PHANDLE, ACCESS_MASK,const POBJECT_ATTRIBUTES,LONG,LONG );\r
+static NTSTATUS (WINAPI *pNtCreateTimer) ( PHANDLE, ACCESS_MASK, const POBJECT_ATTRIBUTES, TIMER_TYPE );\r
+static NTSTATUS (WINAPI *pNtCreateSection)( PHANDLE, ACCESS_MASK, const POBJECT_ATTRIBUTES, const PLARGE_INTEGER,\r
+ ULONG, ULONG, HANDLE );\r
+static NTSTATUS (WINAPI *pNtOpenFile) ( PHANDLE, ACCESS_MASK, POBJECT_ATTRIBUTES, PIO_STATUS_BLOCK, ULONG, ULONG );\r
+static NTSTATUS (WINAPI *pNtClose) ( HANDLE );\r
+static NTSTATUS (WINAPI *pNtCreateNamedPipeFile)( PHANDLE, ULONG, POBJECT_ATTRIBUTES, PIO_STATUS_BLOCK,\r
+ ULONG, ULONG, ULONG, ULONG, ULONG, ULONG, ULONG, ULONG, ULONG, PLARGE_INTEGER );\r
+static NTSTATUS (WINAPI *pNtOpenDirectoryObject)(PHANDLE, ACCESS_MASK, POBJECT_ATTRIBUTES);\r
+static NTSTATUS (WINAPI *pNtCreateDirectoryObject)(PHANDLE, ACCESS_MASK, POBJECT_ATTRIBUTES);\r
+static NTSTATUS (WINAPI *pNtOpenSymbolicLinkObject)(PHANDLE, ACCESS_MASK, POBJECT_ATTRIBUTES);\r
+static NTSTATUS (WINAPI *pNtCreateSymbolicLinkObject)(PHANDLE, ACCESS_MASK, POBJECT_ATTRIBUTES, PUNICODE_STRING);\r
+\r
+\r
+void test_case_sensitive (void)\r
+{\r
+ 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};\r
+ 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};\r
+ 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};\r
+ 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};\r
+ NTSTATUS status;\r
+ OBJECT_ATTRIBUTES attr;\r
+ UNICODE_STRING str;\r
+ HANDLE Event, Mutant, h;\r
+\r
+ pRtlInitUnicodeString(&str, buffer1);\r
+ InitializeObjectAttributes(&attr, &str, 0, 0, NULL);\r
+ status = pNtCreateMutant(&Mutant, GENERIC_ALL, &attr, FALSE);\r
+ ok(status == STATUS_SUCCESS, "Failed to create Mutant(%08lx)\n", status);\r
+\r
+ status = pNtCreateEvent(&Event, GENERIC_ALL, &attr, FALSE, FALSE);\r
+ ok(status == STATUS_OBJECT_NAME_COLLISION,\r
+ "NtCreateEvent should have failed with STATUS_OBJECT_NAME_COLLISION got(%08lx)\n", status);\r
+\r
+ pRtlInitUnicodeString(&str, buffer2);\r
+ InitializeObjectAttributes(&attr, &str, 0, 0, NULL);\r
+ status = pNtCreateEvent(&Event, GENERIC_ALL, &attr, FALSE, FALSE);\r
+ ok(status == STATUS_SUCCESS, "Failed to create Event(%08lx)\n", status);\r
+\r
+ pRtlInitUnicodeString(&str, buffer3);\r
+ InitializeObjectAttributes(&attr, &str, OBJ_CASE_INSENSITIVE, 0, NULL);\r
+ status = pNtOpenMutant(&h, GENERIC_ALL, &attr);\r
+ ok(status == STATUS_OBJECT_TYPE_MISMATCH,\r
+ "NtOpenMutant should have failed with STATUS_OBJECT_TYPE_MISMATCH got(%08lx)\n", status);\r
+\r
+ pNtClose(Mutant);\r
+\r
+ pRtlInitUnicodeString(&str, buffer4);\r
+ InitializeObjectAttributes(&attr, &str, OBJ_CASE_INSENSITIVE, 0, NULL);\r
+ status = pNtCreateMutant(&Mutant, GENERIC_ALL, &attr, FALSE);\r
+ ok(status == STATUS_OBJECT_NAME_COLLISION,\r
+ "NtCreateMutant should have failed with STATUS_OBJECT_NAME_COLLISION got(%08lx)\n", status);\r
+\r
+ status = pNtCreateEvent(&h, GENERIC_ALL, &attr, FALSE, FALSE);\r
+ ok(status == STATUS_OBJECT_NAME_COLLISION,\r
+ "NtCreateEvent should have failed with STATUS_OBJECT_NAME_COLLISION got(%08lx)\n", status);\r
+\r
+ attr.Attributes = 0;\r
+ status = pNtCreateMutant(&Mutant, GENERIC_ALL, &attr, FALSE);\r
+ todo_wine ok(status == STATUS_OBJECT_PATH_NOT_FOUND,\r
+ "NtCreateMutant should have failed with STATUS_OBJECT_PATH_NOT_FOUND got(%08lx)\n", status);\r
+\r
+ pNtClose(Event);\r
+}\r
+\r
+void test_namespace_pipe(void)\r
+{\r
+ static const WCHAR buffer1[] = {'\\','?','?','\\','P','I','P','E','\\','t','e','s','t','\\','p','i','p','e',0};\r
+ static const WCHAR buffer2[] = {'\\','?','?','\\','P','I','P','E','\\','T','E','S','T','\\','P','I','P','E',0};\r
+ static const WCHAR buffer3[] = {'\\','?','?','\\','p','i','p','e','\\','t','e','s','t','\\','p','i','p','e',0};\r
+ static const WCHAR buffer4[] = {'\\','?','?','\\','p','i','p','e','\\','t','e','s','t',0};\r
+ OBJECT_ATTRIBUTES attr;\r
+ UNICODE_STRING str;\r
+ IO_STATUS_BLOCK iosb;\r
+ NTSTATUS status;\r
+ LARGE_INTEGER timeout;\r
+ HANDLE pipe, h;\r
+\r
+ timeout.QuadPart = -10000;\r
+\r
+ pRtlInitUnicodeString(&str, buffer1);\r
+ InitializeObjectAttributes(&attr, &str, 0, 0, NULL);\r
+ status = pNtCreateNamedPipeFile(&pipe, GENERIC_READ|GENERIC_WRITE, &attr, &iosb, FILE_SHARE_READ|FILE_SHARE_WRITE,\r
+ FILE_CREATE, FILE_PIPE_FULL_DUPLEX, FALSE, FALSE, FALSE, 1, 256, 256, &timeout);\r
+ ok(status == STATUS_SUCCESS, "Failed to create NamedPipe(%08lx)\n", status);\r
+\r
+ status = pNtCreateNamedPipeFile(&pipe, GENERIC_READ|GENERIC_WRITE, &attr, &iosb, FILE_SHARE_READ|FILE_SHARE_WRITE,\r
+ FILE_CREATE, FILE_PIPE_FULL_DUPLEX, FALSE, FALSE, FALSE, 1, 256, 256, &timeout);\r
+ ok(status == STATUS_INSTANCE_NOT_AVAILABLE,\r
+ "NtCreateNamedPipeFile should have failed with STATUS_INSTANCE_NOT_AVAILABLE got(%08lx)\n", status);\r
+\r
+ pRtlInitUnicodeString(&str, buffer2);\r
+ InitializeObjectAttributes(&attr, &str, 0, 0, NULL);\r
+ status = pNtCreateNamedPipeFile(&pipe, GENERIC_READ|GENERIC_WRITE, &attr, &iosb, FILE_SHARE_READ|FILE_SHARE_WRITE,\r
+ FILE_CREATE, FILE_PIPE_FULL_DUPLEX, FALSE, FALSE, FALSE, 1, 256, 256, &timeout);\r
+ todo_wine ok(status == STATUS_INSTANCE_NOT_AVAILABLE,\r
+ "NtCreateNamedPipeFile should have failed with STATUS_INSTANCE_NOT_AVAILABLE got(%08lx)\n", status);\r
+\r
+ attr.Attributes = OBJ_CASE_INSENSITIVE;\r
+ status = pNtOpenFile(&h, GENERIC_READ, &attr, &iosb, FILE_SHARE_READ|FILE_SHARE_WRITE, FILE_OPEN);\r
+ ok(status == STATUS_SUCCESS, "Failed to open NamedPipe(%08lx)\n", status);\r
+ pNtClose(h);\r
+\r
+ pRtlInitUnicodeString(&str, buffer3);\r
+ InitializeObjectAttributes(&attr, &str, 0, 0, NULL);\r
+ status = pNtOpenFile(&h, GENERIC_READ, &attr, &iosb, FILE_SHARE_READ|FILE_SHARE_WRITE, FILE_OPEN);\r
+ todo_wine ok(status == STATUS_OBJECT_PATH_NOT_FOUND || status == STATUS_PIPE_NOT_AVAILABLE,\r
+ "pNtOpenFile should have failed with STATUS_OBJECT_PATH_NOT_FOUND got(%08lx)\n", status);\r
+\r
+ pRtlInitUnicodeString(&str, buffer4);\r
+ InitializeObjectAttributes(&attr, &str, OBJ_CASE_INSENSITIVE, 0, NULL);\r
+ status = pNtOpenFile(&h, GENERIC_READ, &attr, &iosb, FILE_SHARE_READ|FILE_SHARE_WRITE, FILE_OPEN);\r
+ ok(status == STATUS_OBJECT_NAME_NOT_FOUND,\r
+ "pNtOpenFile should have failed with STATUS_OBJECT_NAME_NOT_FOUND got(%08lx)\n", status);\r
+\r
+ pNtClose(pipe);\r
+}\r
+\r
+#define DIRECTORY_QUERY (0x0001)\r
+#define SYMBOLIC_LINK_QUERY 0x0001\r
+\r
+#define DIR_TEST_CREATE_FAILURE(h,e) \\r
+ status = pNtCreateDirectoryObject(h, DIRECTORY_QUERY, &attr);\\r
+ ok(status == e,"NtCreateDirectoryObject should have failed with %s got(%08lx)\n", #e, status);\r
+#define DIR_TEST_OPEN_FAILURE(h,e) \\r
+ status = pNtOpenDirectoryObject(h, DIRECTORY_QUERY, &attr);\\r
+ ok(status == e,"NtOpenDirectoryObject should have failed with %s got(%08lx)\n", #e, status);\r
+#define DIR_TEST_CREATE_OPEN_FAILURE(h,n,e) \\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, n);\\r
+ DIR_TEST_CREATE_FAILURE(h,e) DIR_TEST_OPEN_FAILURE(h,e)\\r
+ pRtlFreeUnicodeString(&str);\r
+\r
+#define DIR_TEST_CREATE_SUCCESS(h) \\r
+ status = pNtCreateDirectoryObject(h, DIRECTORY_QUERY, &attr); \\r
+ ok(status == STATUS_SUCCESS, "Failed to create Directory(%08lx)\n", status);\r
+#define DIR_TEST_OPEN_SUCCESS(h) \\r
+ status = pNtOpenDirectoryObject(h, DIRECTORY_QUERY, &attr); \\r
+ ok(status == STATUS_SUCCESS, "Failed to open Directory(%08lx)\n", status);\r
+#define DIR_TEST_CREATE_OPEN_SUCCESS(h,n) \\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, n);\\r
+ DIR_TEST_CREATE_SUCCESS(h) pNtClose(h); DIR_TEST_OPEN_SUCCESS(h) pNtClose(h); \\r
+ pRtlFreeUnicodeString(&str);\r
+\r
+static void test_name_collisions(void)\r
+{\r
+ NTSTATUS status;\r
+ UNICODE_STRING str;\r
+ OBJECT_ATTRIBUTES attr;\r
+ HANDLE dir, h, h1, h2;\r
+ DWORD winerr;\r
+ LARGE_INTEGER size;\r
+\r
+ InitializeObjectAttributes(&attr, &str, 0, 0, NULL);\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "\\");\r
+ h = 0;\r
+ todo_wine{ DIR_TEST_CREATE_FAILURE(&h, STATUS_OBJECT_NAME_COLLISION) }\r
+ ok(h == 0, "Failed create returned valid handle! (%p)\n", h);\r
+ InitializeObjectAttributes(&attr, &str, OBJ_OPENIF, 0, NULL);\r
+\r
+ todo_wine{ DIR_TEST_CREATE_FAILURE(&h, STATUS_OBJECT_NAME_EXISTS) }\r
+ pNtClose(h);\r
+ status = pNtCreateMutant(&h, GENERIC_ALL, &attr, FALSE);\r
+ todo_wine ok(status == STATUS_OBJECT_TYPE_MISMATCH,\r
+ "NtCreateMutant should have failed with STATUS_OBJECT_TYPE_MISMATCH got(%08lx)\n", status);\r
+ pRtlFreeUnicodeString(&str);\r
+\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "\\??\\PIPE\\om.c-mutant");\r
+ status = pNtCreateMutant(&h, GENERIC_ALL, &attr, FALSE);\r
+ todo_wine ok(status == STATUS_OBJECT_TYPE_MISMATCH,\r
+ "NtCreateMutant should have failed with STATUS_OBJECT_TYPE_MISMATCH got(%08lx)\n", status);\r
+ pRtlFreeUnicodeString(&str);\r
+\r
+\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "\\BaseNamedObjects");\r
+ DIR_TEST_OPEN_SUCCESS(&dir)\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "om.c-test");\r
+ InitializeObjectAttributes(&attr, &str, OBJ_OPENIF, dir, NULL);\r
+ \r
+ h = CreateMutexA(NULL, FALSE, "om.c-test");\r
+ ok(h != 0, "CreateMutexA failed got ret=%p (%ld)\n", h, GetLastError());\r
+ status = pNtCreateMutant(&h1, GENERIC_ALL, &attr, FALSE);\r
+ ok(status == STATUS_OBJECT_NAME_EXISTS && h1 != NULL,\r
+ "NtCreateMutant should have succeeded with STATUS_OBJECT_NAME_EXISTS got(%08lx)\n", status);\r
+ h2 = CreateMutexA(NULL, FALSE, "om.c-test");\r
+ winerr = GetLastError();\r
+ ok(h2 != 0 && winerr == ERROR_ALREADY_EXISTS,\r
+ "CreateMutexA should have succeeded with ERROR_ALREADY_EXISTS got ret=%p (%ld)\n", h2, winerr);\r
+ pNtClose(h);\r
+ pNtClose(h1);\r
+ pNtClose(h2);\r
+\r
+ h = CreateEventA(NULL, FALSE, FALSE, "om.c-test");\r
+ ok(h != 0, "CreateEventA failed got ret=%p (%ld)\n", h, GetLastError());\r
+ status = pNtCreateEvent(&h1, GENERIC_ALL, &attr, FALSE, FALSE);\r
+ ok(status == STATUS_OBJECT_NAME_EXISTS && h1 != NULL,\r
+ "NtCreateEvent should have succeeded with STATUS_OBJECT_NAME_EXISTS got(%08lx)\n", status);\r
+ h2 = CreateEventA(NULL, FALSE, FALSE, "om.c-test");\r
+ winerr = GetLastError();\r
+ ok(h2 != 0 && winerr == ERROR_ALREADY_EXISTS,\r
+ "CreateEventA should have succeeded with ERROR_ALREADY_EXISTS got ret=%p (%ld)\n", h2, winerr);\r
+ pNtClose(h);\r
+ pNtClose(h1);\r
+ pNtClose(h2);\r
+\r
+ h = CreateSemaphoreA(NULL, 1, 2, "om.c-test");\r
+ ok(h != 0, "CreateSemaphoreA failed got ret=%p (%ld)\n", h, GetLastError());\r
+ status = pNtCreateSemaphore(&h1, GENERIC_ALL, &attr, 1, 2);\r
+ ok(status == STATUS_OBJECT_NAME_EXISTS && h1 != NULL,\r
+ "NtCreateSemaphore should have succeeded with STATUS_OBJECT_NAME_EXISTS got(%08lx)\n", status);\r
+ h2 = CreateSemaphoreA(NULL, 1, 2, "om.c-test");\r
+ winerr = GetLastError();\r
+ ok(h2 != 0 && winerr == ERROR_ALREADY_EXISTS,\r
+ "CreateSemaphoreA should have succeeded with ERROR_ALREADY_EXISTS got ret=%p (%ld)\n", h2, winerr);\r
+ pNtClose(h);\r
+ pNtClose(h1);\r
+ pNtClose(h2);\r
+ \r
+ h = CreateWaitableTimerA(NULL, TRUE, "om.c-test");\r
+ ok(h != 0, "CreateWaitableTimerA failed got ret=%p (%ld)\n", h, GetLastError());\r
+ status = pNtCreateTimer(&h1, GENERIC_ALL, &attr, NotificationTimer);\r
+ ok(status == STATUS_OBJECT_NAME_EXISTS && h1 != NULL,\r
+ "NtCreateTimer should have succeeded with STATUS_OBJECT_NAME_EXISTS got(%08lx)\n", status);\r
+ h2 = CreateWaitableTimerA(NULL, TRUE, "om.c-test");\r
+ winerr = GetLastError();\r
+ ok(h2 != 0 && winerr == ERROR_ALREADY_EXISTS,\r
+ "CreateWaitableTimerA should have succeeded with ERROR_ALREADY_EXISTS got ret=%p (%ld)\n", h2, winerr);\r
+ pNtClose(h);\r
+ pNtClose(h1);\r
+ pNtClose(h2);\r
+\r
+ h = CreateFileMappingA(INVALID_HANDLE_VALUE, NULL, PAGE_READWRITE, 0, 256, "om.c-test");\r
+ ok(h != 0, "CreateFileMappingA failed got ret=%p (%ld)\n", h, GetLastError());\r
+ size.u.LowPart = 256;\r
+ size.u.HighPart = 0;\r
+ status = pNtCreateSection(&h1, SECTION_MAP_WRITE, &attr, &size, PAGE_READWRITE, SEC_COMMIT, 0);\r
+ ok(status == STATUS_OBJECT_NAME_EXISTS && h1 != NULL,\r
+ "NtCreateSection should have succeeded with STATUS_OBJECT_NAME_EXISTS got(%08lx)\n", status);\r
+ h2 = CreateFileMappingA(INVALID_HANDLE_VALUE, NULL, PAGE_READWRITE, 0, 256, "om.c-test");\r
+ winerr = GetLastError();\r
+ ok(h2 != 0 && winerr == ERROR_ALREADY_EXISTS,\r
+ "CreateFileMappingA should have succeeded with ERROR_ALREADY_EXISTS got ret=%p (%ld)\n", h2, winerr);\r
+ pNtClose(h);\r
+ pNtClose(h1);\r
+ pNtClose(h2);\r
+\r
+ pRtlFreeUnicodeString(&str);\r
+ pNtClose(dir);\r
+}\r
+\r
+void test_directory(void)\r
+{\r
+ NTSTATUS status;\r
+ UNICODE_STRING str;\r
+ OBJECT_ATTRIBUTES attr;\r
+ HANDLE dir, dir1, h;\r
+\r
+ /* No name and/or no attributes */\r
+ status = pNtCreateDirectoryObject(NULL, DIRECTORY_QUERY, &attr);\r
+ todo_wine ok(status == STATUS_ACCESS_VIOLATION,\r
+ "NtCreateDirectoryObject should have failed with STATUS_ACCESS_VIOLATION got(%08lx)\n", status);\r
+ status = pNtOpenDirectoryObject(NULL, DIRECTORY_QUERY, &attr);\r
+ todo_wine ok(status == STATUS_ACCESS_VIOLATION,\r
+ "NtOpenDirectoryObject should have failed with STATUS_ACCESS_VIOLATION got(%08lx)\n", status);\r
+\r
+ status = pNtCreateDirectoryObject(&h, DIRECTORY_QUERY, NULL);\r
+ ok(status == STATUS_SUCCESS, "Failed to create Directory without attributes(%08lx)\n", status);\r
+ pNtClose(h);\r
+ status = pNtOpenDirectoryObject(&h, DIRECTORY_QUERY, NULL);\r
+ todo_wine ok(status == STATUS_INVALID_PARAMETER,\r
+ "NtOpenDirectoryObject should have failed with STATUS_INVALID_PARAMETER got(%08lx)\n", status);\r
+\r
+ InitializeObjectAttributes(&attr, NULL, 0, 0, NULL);\r
+ DIR_TEST_CREATE_SUCCESS(&dir)\r
+ todo_wine{ DIR_TEST_OPEN_FAILURE(&h, STATUS_OBJECT_PATH_SYNTAX_BAD) }\r
+\r
+ /* Bad name */\r
+ InitializeObjectAttributes(&attr, &str, 0, 0, NULL);\r
+\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "");\r
+ DIR_TEST_CREATE_SUCCESS(&h)\r
+ pNtClose(h);\r
+ todo_wine{ DIR_TEST_OPEN_FAILURE(&h, STATUS_OBJECT_PATH_SYNTAX_BAD) }\r
+ pRtlFreeUnicodeString(&str);\r
+ pNtClose(dir);\r
+\r
+ todo_wine{ DIR_TEST_CREATE_OPEN_FAILURE(&h, "BaseNamedObjects", STATUS_OBJECT_PATH_SYNTAX_BAD) }\r
+ todo_wine{ DIR_TEST_CREATE_OPEN_FAILURE(&h, "\\BaseNamedObjects\\", STATUS_OBJECT_NAME_INVALID) }\r
+ todo_wine{ DIR_TEST_CREATE_OPEN_FAILURE(&h, "\\\\BaseNamedObjects", STATUS_OBJECT_NAME_INVALID) }\r
+ todo_wine{ DIR_TEST_CREATE_OPEN_FAILURE(&h, "\\BaseNamedObjects\\\\om.c-test", STATUS_OBJECT_NAME_INVALID) }\r
+ todo_wine{ DIR_TEST_CREATE_OPEN_FAILURE(&h, "\\BaseNamedObjects\\om.c-test\\", STATUS_OBJECT_PATH_NOT_FOUND) }\r
+\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "\\BaseNamedObjects\\om.c-test");\r
+ DIR_TEST_CREATE_SUCCESS(&h)\r
+ DIR_TEST_OPEN_SUCCESS(&dir1)\r
+ pRtlFreeUnicodeString(&str);\r
+ pNtClose(h);\r
+ pNtClose(dir1);\r
+\r
+\r
+ /* Use of root directory */\r
+\r
+ /* Can't use symlinks as a directory */\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "\\BaseNamedObjects\\Local");\r
+ InitializeObjectAttributes(&attr, &str, 0, 0, NULL);\r
+ status = pNtOpenSymbolicLinkObject(&dir, SYMBOLIC_LINK_QUERY, &attr);\\r
+ todo_wine ok(status == STATUS_SUCCESS, "Failed to open SymbolicLink(%08lx)\n", status);\r
+ pRtlFreeUnicodeString(&str);\r
+ InitializeObjectAttributes(&attr, &str, 0, dir, NULL);\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "one more level");\r
+ todo_wine{ DIR_TEST_CREATE_FAILURE(&h, STATUS_OBJECT_TYPE_MISMATCH) }\r
+ pRtlFreeUnicodeString(&str);\r
+ pNtClose(h);\r
+ pNtClose(dir);\r
+\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "\\BaseNamedObjects");\r
+ InitializeObjectAttributes(&attr, &str, 0, 0, NULL);\r
+ DIR_TEST_OPEN_SUCCESS(&dir)\r
+ pRtlFreeUnicodeString(&str);\r
+\r
+ InitializeObjectAttributes(&attr, NULL, 0, dir, NULL);\r
+ todo_wine{ DIR_TEST_OPEN_FAILURE(&h, STATUS_OBJECT_NAME_INVALID) }\r
+\r
+ InitializeObjectAttributes(&attr, &str, 0, dir, NULL);\r
+ DIR_TEST_CREATE_OPEN_SUCCESS(&h, "")\r
+ todo_wine{ DIR_TEST_CREATE_OPEN_FAILURE(&h, "\\", STATUS_OBJECT_PATH_SYNTAX_BAD) }\r
+ todo_wine{ DIR_TEST_CREATE_OPEN_FAILURE(&h, "\\om.c-test", STATUS_OBJECT_PATH_SYNTAX_BAD) }\r
+ todo_wine{ DIR_TEST_CREATE_OPEN_FAILURE(&h, "\\om.c-test\\", STATUS_OBJECT_PATH_SYNTAX_BAD) }\r
+ todo_wine{ DIR_TEST_CREATE_OPEN_FAILURE(&h, "om.c-test\\", STATUS_OBJECT_PATH_NOT_FOUND) }\r
+\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "om.c-test");\r
+ DIR_TEST_CREATE_SUCCESS(&dir1)\r
+ DIR_TEST_OPEN_SUCCESS(&h)\r
+ pRtlFreeUnicodeString(&str);\r
+\r
+ pNtClose(h);\r
+ pNtClose(dir1);\r
+ pNtClose(dir);\r
+\r
+ /* Nested directories */\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "\\");\r
+ InitializeObjectAttributes(&attr, &str, 0, 0, NULL);\r
+ DIR_TEST_OPEN_SUCCESS(&dir)\r
+ InitializeObjectAttributes(&attr, &str, 0, dir, NULL);\r
+ todo_wine{ DIR_TEST_OPEN_FAILURE(&h, STATUS_OBJECT_PATH_SYNTAX_BAD) }\r
+ pRtlFreeUnicodeString(&str);\r
+ pNtClose(dir);\r
+\r
+ InitializeObjectAttributes(&attr, &str, 0, 0, NULL);\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "\\BaseNamedObjects\\om.c-test");\r
+ DIR_TEST_CREATE_SUCCESS(&dir)\r
+ pRtlFreeUnicodeString(&str);\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "\\BaseNamedObjects\\om.c-test\\one more level");\r
+ DIR_TEST_CREATE_SUCCESS(&h)\r
+ pRtlFreeUnicodeString(&str);\r
+ pNtClose(h);\r
+ InitializeObjectAttributes(&attr, &str, 0, dir, NULL);\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "one more level");\r
+ DIR_TEST_CREATE_SUCCESS(&h)\r
+ pRtlFreeUnicodeString(&str);\r
+ pNtClose(h);\r
+\r
+ pNtClose(dir);\r
+\r
+ InitializeObjectAttributes(&attr, &str, 0, 0, NULL);\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "\\BaseNamedObjects\\Global\\om.c-test");\r
+ DIR_TEST_CREATE_SUCCESS(&dir)\r
+ pRtlFreeUnicodeString(&str);\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "\\BaseNamedObjects\\Local\\om.c-test\\one more level");\r
+ DIR_TEST_CREATE_SUCCESS(&h)\r
+ pRtlFreeUnicodeString(&str);\r
+ pNtClose(h);\r
+ InitializeObjectAttributes(&attr, &str, 0, dir, NULL);\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "one more level");\r
+ DIR_TEST_CREATE_SUCCESS(&dir)\r
+ pRtlFreeUnicodeString(&str);\r
+ pNtClose(h);\r
+\r
+ pNtClose(dir);\r
+\r
+\r
+ /* Create other objects using RootDirectory */\r
+\r
+ InitializeObjectAttributes(&attr, &str, 0, 0, NULL);\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "\\BaseNamedObjects");\r
+ DIR_TEST_OPEN_SUCCESS(&dir)\r
+ pRtlFreeUnicodeString(&str);\r
+ InitializeObjectAttributes(&attr, &str, 0, dir, NULL);\r
+\r
+ /* Test inavalid paths */\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "\\om.c-mutant");\r
+ status = pNtCreateMutant(&h, GENERIC_ALL, &attr, FALSE);\r
+ todo_wine ok(status == STATUS_OBJECT_PATH_SYNTAX_BAD,\r
+ "NtCreateMutant should have failed with STATUS_OBJECT_PATH_SYNTAX_BAD got(%08lx)\n", status);\r
+ pRtlFreeUnicodeString(&str);\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "\\om.c-mutant\\");\r
+ status = pNtCreateMutant(&h, GENERIC_ALL, &attr, FALSE);\r
+ todo_wine ok(status == STATUS_OBJECT_PATH_SYNTAX_BAD,\r
+ "NtCreateMutant should have failed with STATUS_OBJECT_PATH_SYNTAX_BAD got(%08lx)\n", status);\r
+ pRtlFreeUnicodeString(&str);\r
+\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "om.c\\-mutant");\r
+ status = pNtCreateMutant(&h, GENERIC_ALL, &attr, FALSE);\r
+ todo_wine ok(status == STATUS_OBJECT_PATH_NOT_FOUND,\r
+ "NtCreateMutant should have failed with STATUS_OBJECT_PATH_NOT_FOUND got(%08lx)\n", status);\r
+ pRtlFreeUnicodeString(&str);\r
+\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "om.c-mutant");\r
+ status = pNtCreateMutant(&h, GENERIC_ALL, &attr, FALSE);\r
+ ok(status == STATUS_SUCCESS, "Failed to create Mutant(%08lx)\n", status);\r
+ pRtlFreeUnicodeString(&str);\r
+ pNtClose(h);\r
+\r
+ pNtClose(dir);\r
+}\r
+\r
+#define SYMLNK_TEST_CREATE_FAILURE(h,e) \\r
+ status = pNtCreateSymbolicLinkObject(h, SYMBOLIC_LINK_QUERY, &attr, &target);\\r
+ ok(status == e,"NtCreateSymbolicLinkObject should have failed with %s got(%08lx)\n", #e, status);\r
+#define SYMLNK_TEST_OPEN_FAILURE(h,e) \\r
+ status = pNtOpenSymbolicLinkObject(h, SYMBOLIC_LINK_QUERY, &attr);\\r
+ ok(status == e,"NtOpenSymbolicLinkObject should have failed with %s got(%08lx)\n", #e, status);\r
+#define SYMLNK_TEST_CREATE_OPEN_FAILURE(h,n,t,e) \\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, n);\\r
+ pRtlCreateUnicodeStringFromAsciiz(&target, t);\\r
+ SYMLNK_TEST_CREATE_FAILURE(h,e)\\r
+ SYMLNK_TEST_OPEN_FAILURE(h,e)\\r
+ pRtlFreeUnicodeString(&target);\\r
+ pRtlFreeUnicodeString(&str);\r
+\r
+#define SYMLNK_TEST_CREATE_SUCCESS(h) \\r
+ status = pNtCreateSymbolicLinkObject(h, SYMBOLIC_LINK_QUERY, &attr, &target); \\r
+ ok(status == STATUS_SUCCESS, "Failed to create SymbolicLink(%08lx)\n", status);\r
+#define SYMLNK_TEST_OPEN_SUCCESS(h) \\r
+ status = pNtOpenSymbolicLinkObject(h, SYMBOLIC_LINK_QUERY, &attr); \\r
+ ok(status == STATUS_SUCCESS, "Failed to open SymbolicLink(%08lx)\n", status);\r
+\r
+void test_symboliclink(void)\r
+{\r
+ NTSTATUS status;\r
+ UNICODE_STRING str, target;\r
+ OBJECT_ATTRIBUTES attr;\r
+ HANDLE dir, link, h;\r
+ IO_STATUS_BLOCK iosb;\r
+\r
+ /* No name and/or no attributes */\r
+ todo_wine{ SYMLNK_TEST_CREATE_OPEN_FAILURE(NULL, "", "", STATUS_ACCESS_VIOLATION) }\r
+\r
+ status = pNtCreateSymbolicLinkObject(&h, SYMBOLIC_LINK_QUERY, NULL, NULL);\r
+ todo_wine ok(status == STATUS_ACCESS_VIOLATION,\r
+ "NtCreateSymbolicLinkObject should have failed with STATUS_ACCESS_VIOLATION got(%08lx)\n", status);\r
+ status = pNtOpenSymbolicLinkObject(&h, SYMBOLIC_LINK_QUERY, NULL);\r
+ todo_wine ok(status == STATUS_INVALID_PARAMETER,\r
+ "NtOpenSymbolicLinkObject should have failed with STATUS_INVALID_PARAMETER got(%08lx)\n", status);\r
+\r
+ InitializeObjectAttributes(&attr, NULL, 0, 0, NULL);\r
+ todo_wine{ SYMLNK_TEST_CREATE_FAILURE(&link, STATUS_INVALID_PARAMETER) }\r
+ todo_wine{ SYMLNK_TEST_OPEN_FAILURE(&h, STATUS_OBJECT_PATH_SYNTAX_BAD) }\r
+\r
+ /* Bad name */\r
+ pRtlCreateUnicodeStringFromAsciiz(&target, "anywhere");\r
+ InitializeObjectAttributes(&attr, &str, 0, 0, NULL);\r
+\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "");\r
+ SYMLNK_TEST_CREATE_SUCCESS(&link)\r
+ todo_wine{ SYMLNK_TEST_OPEN_FAILURE(&h, STATUS_OBJECT_PATH_SYNTAX_BAD) }\r
+ pNtClose(link);\r
+ pRtlFreeUnicodeString(&str);\r
+\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "\\");\r
+ todo_wine {SYMLNK_TEST_CREATE_FAILURE(&h, STATUS_OBJECT_TYPE_MISMATCH)}\r
+ pRtlFreeUnicodeString(&str);\r
+ pRtlFreeUnicodeString(&target);\r
+\r
+ todo_wine{ SYMLNK_TEST_CREATE_OPEN_FAILURE(&h, "BaseNamedObjects", "->Somewhere", STATUS_OBJECT_PATH_SYNTAX_BAD) }\r
+ todo_wine{ SYMLNK_TEST_CREATE_OPEN_FAILURE(&h, "\\BaseNamedObjects\\", "->Somewhere", STATUS_OBJECT_NAME_INVALID) }\r
+ todo_wine{ SYMLNK_TEST_CREATE_OPEN_FAILURE(&h, "\\\\BaseNamedObjects", "->Somewhere", STATUS_OBJECT_NAME_INVALID) }\r
+ todo_wine{ SYMLNK_TEST_CREATE_OPEN_FAILURE(&h, "\\BaseNamedObjects\\\\om.c-test", "->Somewhere", STATUS_OBJECT_NAME_INVALID) }\r
+ todo_wine{ SYMLNK_TEST_CREATE_OPEN_FAILURE(&h, "\\BaseNamedObjects\\om.c-test\\", "->Somewhere", STATUS_OBJECT_NAME_INVALID) }\r
+\r
+\r
+ /* Compaund test */\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "\\BaseNamedObjects");\r
+ DIR_TEST_OPEN_SUCCESS(&dir)\r
+ pRtlFreeUnicodeString(&str);\r
+\r
+ InitializeObjectAttributes(&attr, &str, 0, dir, NULL);\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "Local\\test-link");\r
+ pRtlCreateUnicodeStringFromAsciiz(&target, "\\DosDevices");\r
+ SYMLNK_TEST_CREATE_SUCCESS(&link)\r
+ pRtlFreeUnicodeString(&str);\r
+ pRtlFreeUnicodeString(&target);\r
+\r
+ pRtlCreateUnicodeStringFromAsciiz(&str, "Local\\test-link\\PIPE");\r
+ status = pNtOpenFile(&h, GENERIC_READ, &attr, &iosb, FILE_SHARE_READ|FILE_SHARE_WRITE, FILE_OPEN);\r
+ todo_wine ok(status == STATUS_SUCCESS, "Failed to open NamedPipe(%08lx)\n", status);\r
+ pRtlFreeUnicodeString(&str);\r
+\r
+ pNtClose(h);\r
+ pNtClose(link);\r
+ pNtClose(dir);\r
+}\r
+\r
+START_TEST(om)\r
+{\r
+ HMODULE hntdll = GetModuleHandleA("ntdll.dll");\r
+ if (hntdll)\r
+ {\r
+ pRtlCreateUnicodeStringFromAsciiz = (void *)GetProcAddress(hntdll, "RtlCreateUnicodeStringFromAsciiz");\r
+ pRtlFreeUnicodeString = (void *)GetProcAddress(hntdll, "RtlFreeUnicodeString");\r
+ pNtCreateEvent = (void *)GetProcAddress(hntdll, "NtCreateEvent");\r
+ pNtCreateMutant = (void *)GetProcAddress(hntdll, "NtCreateMutant");\r
+ pNtOpenMutant = (void *)GetProcAddress(hntdll, "NtOpenMutant");\r
+ pNtOpenFile = (void *)GetProcAddress(hntdll, "NtOpenFile");\r
+ pNtClose = (void *)GetProcAddress(hntdll, "NtClose");\r
+ pRtlInitUnicodeString = (void *)GetProcAddress(hntdll, "RtlInitUnicodeString");\r
+ pNtCreateNamedPipeFile = (void *)GetProcAddress(hntdll, "NtCreateNamedPipeFile");\r
+ pNtOpenDirectoryObject = (void *)GetProcAddress(hntdll, "NtOpenDirectoryObject");\r
+ pNtCreateDirectoryObject= (void *)GetProcAddress(hntdll, "NtCreateDirectoryObject");\r
+ pNtOpenSymbolicLinkObject = (void *)GetProcAddress(hntdll, "NtOpenSymbolicLinkObject");\r
+ pNtCreateSymbolicLinkObject = (void *)GetProcAddress(hntdll, "NtCreateSymbolicLinkObject");\r
+ pNtCreateSemaphore = (void *)GetProcAddress(hntdll, "NtCreateSemaphore");\r
+ pNtCreateTimer = (void *)GetProcAddress(hntdll, "NtCreateTimer");\r
+ pNtCreateSection = (void *)GetProcAddress(hntdll, "NtCreateSection");\r
+\r
+ test_case_sensitive();\r
+ test_namespace_pipe();\r
+ test_name_collisions();\r
+ test_directory();\r
+ test_symboliclink();\r
+ }\r
+}\r