Alexandre Julliard : ntdll/tests: Create the server port before starting the client thread.
Alexandre Julliard
julliard at winehq.org
Fri Mar 6 09:49:31 CST 2009
Module: wine
Branch: master
Commit: 44d2277acded8f1f14c3fe47da4894910ef58519
URL: http://source.winehq.org/git/wine.git/?a=commit;h=44d2277acded8f1f14c3fe47da4894910ef58519
Author: Alexandre Julliard <julliard at winehq.org>
Date: Thu Mar 5 22:09:44 2009 +0100
ntdll/tests: Create the server port before starting the client thread.
Print status values in hex.
---
dlls/ntdll/tests/port.c | 69 +++++++++++++++++++---------------------------
1 files changed, 29 insertions(+), 40 deletions(-)
diff --git a/dlls/ntdll/tests/port.c b/dlls/ntdll/tests/port.c
index c63820a..51707e3 100644
--- a/dlls/ntdll/tests/port.c
+++ b/dlls/ntdll/tests/port.c
@@ -90,10 +90,7 @@ static const WCHAR PORTNAME[] = {'\\','M','y','P','o','r','t',0};
#define MAX_MESSAGE_LEN 30
-UNICODE_STRING port;
-static char selfname[MAX_PATH];
-static int myARGC;
-static char** myARGV;
+static UNICODE_STRING port;
/* Function pointers for ntdll calls */
static HMODULE hntdll = 0;
@@ -155,10 +152,10 @@ static void ProcessConnectionRequest(PLPC_MESSAGE LpcMessage, PHANDLE pAcceptPor
ok(!*LpcMessage->Data, "Expected empty string!\n");
status = pNtAcceptConnectPort(pAcceptPortHandle, 0, LpcMessage, 1, 0, NULL);
- ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %d\n", status);
+ ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %x\n", status);
status = pNtCompleteConnectPort(*pAcceptPortHandle);
- ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %d\n", status);
+ ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %x\n", status);
}
static void ProcessLpcRequest(HANDLE PortHandle, PLPC_MESSAGE LpcMessage)
@@ -173,7 +170,7 @@ static void ProcessLpcRequest(HANDLE PortHandle, PLPC_MESSAGE LpcMessage)
lstrcpy((LPSTR)LpcMessage->Data, REPLY);
status = pNtReplyPort(PortHandle, LpcMessage);
- ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %d\n", status);
+ ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %x\n", status);
ok(LpcMessage->MessageType == LPC_REQUEST,
"Expected LPC_REQUEST, got %d\n", LpcMessage->MessageType);
ok(!lstrcmp((LPSTR)LpcMessage->Data, REPLY),
@@ -194,11 +191,11 @@ static DWORD WINAPI test_ports_client(LPVOID arg)
sqos.EffectiveOnly = TRUE;
status = pNtConnectPort(&PortHandle, &port, &sqos, 0, 0, &len, NULL, NULL);
- todo_wine ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %d\n", status);
+ todo_wine ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %x\n", status);
if (status != STATUS_SUCCESS) return 1;
status = pNtRegisterThreadTerminatePort(PortHandle);
- ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %d\n", status);
+ ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %x\n", status);
size = FIELD_OFFSET(LPC_MESSAGE, Data) + MAX_MESSAGE_LEN;
LpcMessage = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, size);
@@ -209,7 +206,7 @@ static DWORD WINAPI test_ports_client(LPVOID arg)
lstrcpy((LPSTR)LpcMessage->Data, REQUEST1);
status = pNtRequestPort(PortHandle, LpcMessage);
- ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %d\n", status);
+ ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %x\n", status);
ok(LpcMessage->MessageType == 0, "Expected 0, got %d\n", LpcMessage->MessageType);
ok(!lstrcmp((LPSTR)LpcMessage->Data, REQUEST1),
"Expected %s, got %s\n", REQUEST1, LpcMessage->Data);
@@ -222,7 +219,7 @@ static DWORD WINAPI test_ports_client(LPVOID arg)
/* Send the message and wait for the reply */
status = pNtRequestWaitReplyPort(PortHandle, LpcMessage, out);
- ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %d\n", status);
+ ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %x\n", status);
ok(!lstrcmp((LPSTR)out->Data, REPLY), "Expected %s, got %s\n", REPLY, out->Data);
ok(out->MessageType == LPC_REPLY, "Expected LPC_REPLY, got %d\n", out->MessageType);
@@ -232,34 +229,14 @@ static DWORD WINAPI test_ports_client(LPVOID arg)
return 0;
}
-static void test_ports_server(void)
+static void test_ports_server( HANDLE PortHandle )
{
- OBJECT_ATTRIBUTES obj;
- HANDLE PortHandle;
HANDLE AcceptPortHandle;
PLPC_MESSAGE LpcMessage;
ULONG size;
NTSTATUS status;
BOOL done = FALSE;
- pRtlInitUnicodeString(&port, PORTNAME);
-
- memset(&obj, 0, sizeof(OBJECT_ATTRIBUTES));
- obj.Length = sizeof(OBJECT_ATTRIBUTES);
- obj.ObjectName = &port;
-
- status = pNtCreatePort(&PortHandle, &obj, 100, 100, 0);
- if (status == STATUS_ACCESS_DENIED)
- {
- skip("Not enough rights\n");
- return;
- }
- todo_wine
- {
- ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %d\n", status);
- }
- if (status != STATUS_SUCCESS) return;
-
size = FIELD_OFFSET(LPC_MESSAGE, Data) + MAX_MESSAGE_LEN;
LpcMessage = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, size);
@@ -308,20 +285,32 @@ static void test_ports_server(void)
START_TEST(port)
{
- HANDLE thread;
- DWORD id;
+ OBJECT_ATTRIBUTES obj;
+ HANDLE port_handle;
+ NTSTATUS status;
if (!init_function_ptrs())
return;
- myARGC = winetest_get_mainargs(&myARGV);
- strcpy(selfname, myARGV[0]);
+ pRtlInitUnicodeString(&port, PORTNAME);
- thread = CreateThread(NULL, 0, test_ports_client, NULL, 0, &id);
- ok(thread != NULL, "Expected non-NULL thread handle!\n");
+ memset(&obj, 0, sizeof(OBJECT_ATTRIBUTES));
+ obj.Length = sizeof(OBJECT_ATTRIBUTES);
+ obj.ObjectName = &port;
- test_ports_server();
- CloseHandle(thread);
+ status = pNtCreatePort(&port_handle, &obj, 100, 100, 0);
+ if (status == STATUS_ACCESS_DENIED) skip("Not enough rights\n");
+ else todo_wine ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %d\n", status);
+ if (status == STATUS_SUCCESS)
+ {
+ DWORD id;
+ HANDLE thread = CreateThread(NULL, 0, test_ports_client, NULL, 0, &id);
+ ok(thread != NULL, "Expected non-NULL thread handle!\n");
+
+ test_ports_server( port_handle );
+ ok( WaitForSingleObject( thread, 10000 ) == 0, "thread didn't exit\n" );
+ CloseHandle(thread);
+ }
FreeLibrary(hntdll);
}
More information about the wine-cvs
mailing list