Files
FreeRDP/winpr/libwinpr/thread/test/TestThreadExitThread.c

54 lines
1.3 KiB
C
Raw Permalink Normal View History

// Copyright © 2015 Hewlett-Packard Development Company, L.P.
#include <winpr/file.h>
#include <winpr/synch.h>
#include <winpr/thread.h>
static DWORD WINAPI thread_func(LPVOID arg)
{
2021-06-02 15:46:27 +02:00
WINPR_UNUSED(arg);
/* exists of the thread the quickest as possible */
ExitThread(0);
return 0;
}
int TestThreadExitThread(int argc, char* argv[])
{
2026-02-26 14:32:50 +01:00
HANDLE thread = nullptr;
DWORD waitResult = 0;
2021-06-02 15:46:27 +02:00
WINPR_UNUSED(argc);
WINPR_UNUSED(argv);
/* FIXME: create some noise to better guaranty the test validity and
2019-11-06 15:24:51 +01:00
* decrease the number of loops */
for (int i = 0; i < 100; i++)
{
2026-02-26 14:32:50 +01:00
thread = CreateThread(nullptr, 0, thread_func, nullptr, 0, nullptr);
if (thread == INVALID_HANDLE_VALUE)
{
(void)fprintf(stderr, "Got an invalid thread!\n");
return -1;
}
waitResult = WaitForSingleObject(thread, 300);
if (waitResult != WAIT_OBJECT_0)
{
/* When the thread exits before the internal thread_list
* was updated, ExitThread() is not able to retrieve the
* related WINPR_THREAD object and is not able to signal
* the end of the thread. Therefore WaitForSingleObject
* never get the signal.
*/
(void)fprintf(
stderr, "300ms should have been enough for the thread to be in a signaled state\n");
return -1;
}
2024-09-16 04:58:36 +02:00
(void)CloseHandle(thread);
}
return 0;
}