add recent winehq object manager tests
authorSteven Edwards <winehacker@gmail.com>
Tue, 22 Nov 2005 07:18:44 +0000 (07:18 +0000)
committerSteven Edwards <winehacker@gmail.com>
Tue, 22 Nov 2005 07:18:44 +0000 (07:18 +0000)
svn path=/trunk/; revision=19454

reactos/regtests/winetests/ntdll/ntdll.xml
reactos/regtests/winetests/ntdll/om.c [new file with mode: 0644]
reactos/regtests/winetests/ntdll/testlist.c

index 470dcbe..214a948 100644 (file)
@@ -7,6 +7,7 @@
     <file>error.c</file>
     <file>info.c</file>
     <file>large_int.c</file>
+    <file>om.c</file>
     <file>path.c</file>
     <file>reg.c</file>
     <file>rtlbitmap.c</file>
diff --git a/reactos/regtests/winetests/ntdll/om.c b/reactos/regtests/winetests/ntdll/om.c
new file mode 100644 (file)
index 0000000..8e96162
--- /dev/null
@@ -0,0 +1,564 @@
+/*\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
index 92b6271..87d6080 100644 (file)
@@ -12,6 +12,7 @@ extern void func_env(void);
 extern void func_error(void);
 extern void func_info(void);
 extern void func_large_int(void);
+extern void func_om(void);
 extern void func_path(void);
 extern void func_reg(void);
 extern void func_rtl(void);
@@ -34,6 +35,7 @@ const struct test winetest_testlist[] =
     { "error", func_error },
     { "info", func_info },
     { "large_int", func_large_int },
+    { "om", func_om },
     { "path", func_path },
     { "reg", func_reg },
     { "rtl", func_rtl },