FreeRDP/winpr/libwinpr/utils/test/TestMessagePipe.c

108 lines
1.9 KiB
C
Raw Normal View History

#include <winpr/crt.h>
#include <winpr/thread.h>
#include <winpr/collections.h>
static DWORD WINAPI message_echo_pipe_client_thread(LPVOID arg)
{
2017-03-28 17:18:00 +03:00
int index = 0;
2019-11-06 17:24:51 +03:00
wMessagePipe* pipe = (wMessagePipe*)arg;
while (index < 100)
{
2017-03-28 17:18:00 +03:00
wMessage message;
int count;
2019-11-06 17:24:51 +03:00
if (!MessageQueue_Post(pipe->In, NULL, 0, (void*)(size_t)index, NULL))
2015-05-23 23:47:18 +03:00
break;
if (!MessageQueue_Wait(pipe->Out))
break;
if (!MessageQueue_Peek(pipe->Out, &message, TRUE))
break;
if (message.id == WMQ_QUIT)
break;
2019-11-06 17:24:51 +03:00
count = (int)(size_t)message.wParam;
if (count != index)
printf("Echo count mismatch: Actual: %d, Expected: %d\n", count, index);
index++;
}
MessageQueue_PostQuit(pipe->In, 0);
return 0;
}
static DWORD WINAPI message_echo_pipe_server_thread(LPVOID arg)
{
wMessage message;
wMessagePipe* pipe;
2019-11-06 17:24:51 +03:00
pipe = (wMessagePipe*)arg;
while (MessageQueue_Wait(pipe->In))
{
if (MessageQueue_Peek(pipe->In, &message, TRUE))
{
if (message.id == WMQ_QUIT)
break;
2015-05-23 23:47:18 +03:00
if (!MessageQueue_Dispatch(pipe->Out, &message))
break;
}
}
return 0;
}
int TestMessagePipe(int argc, char* argv[])
{
HANDLE ClientThread = NULL;
HANDLE ServerThread = NULL;
wMessagePipe* EchoPipe = NULL;
int ret = 1;
2021-07-29 11:18:52 +03:00
WINPR_UNUSED(argc);
WINPR_UNUSED(argv);
if (!(EchoPipe = MessagePipe_New()))
{
printf("failed to create message pipe\n");
goto out;
}
2019-11-06 17:24:51 +03:00
if (!(ClientThread =
CreateThread(NULL, 0, message_echo_pipe_client_thread, (void*)EchoPipe, 0, NULL)))
{
printf("failed to create client thread\n");
goto out;
}
2019-11-06 17:24:51 +03:00
if (!(ServerThread =
CreateThread(NULL, 0, message_echo_pipe_server_thread, (void*)EchoPipe, 0, NULL)))
{
printf("failed to create server thread\n");
goto out;
}
WaitForSingleObject(ClientThread, INFINITE);
WaitForSingleObject(ServerThread, INFINITE);
ret = 0;
out:
if (EchoPipe)
MessagePipe_Free(EchoPipe);
if (ClientThread)
CloseHandle(ClientThread);
if (ServerThread)
CloseHandle(ServerThread);
return ret;
}