Commit e72c71d2 authored by Francois Gouget's avatar Francois Gouget Committed by Alexandre Julliard

ntdll/tests: Improve the RtlWaitOnAddress() timeout checks.

GetTickCount()'s granularity represents 15% of the time we want to mesure, making it hard to not get failures. So use NtQuerySystemTime() instead since we already depend on it. Narrow down the acceptable range again. Signed-off-by: 's avatarFrancois Gouget <fgouget@codeweavers.com> Signed-off-by: 's avatarAlexandre Julliard <julliard@winehq.org>
parent 4e911804
...@@ -2266,10 +2266,10 @@ static void test_semaphore(void) ...@@ -2266,10 +2266,10 @@ static void test_semaphore(void)
static void test_wait_on_address(void) static void test_wait_on_address(void)
{ {
DWORD ticks;
SIZE_T size; SIZE_T size;
NTSTATUS status; NTSTATUS status;
LARGE_INTEGER timeout; LARGE_INTEGER start, end, timeout;
DWORD elapsed;
LONG64 address, compare; LONG64 address, compare;
if (!pRtlWaitOnAddress) if (!pRtlWaitOnAddress)
...@@ -2298,13 +2298,13 @@ static void test_wait_on_address(void) ...@@ -2298,13 +2298,13 @@ static void test_wait_on_address(void)
/* values match */ /* values match */
address = 0; address = 0;
compare = 0; compare = 0;
pNtQuerySystemTime(&timeout); pNtQuerySystemTime(&start);
timeout.QuadPart += 100*10000; timeout.QuadPart = start.QuadPart + 100 * 10000;
ticks = GetTickCount();
status = pRtlWaitOnAddress(&address, &compare, 8, &timeout); status = pRtlWaitOnAddress(&address, &compare, 8, &timeout);
ticks = GetTickCount() - ticks; pNtQuerySystemTime(&end);
ok(status == STATUS_TIMEOUT, "got 0x%08x\n", status); ok(status == STATUS_TIMEOUT, "got 0x%08x\n", status);
ok(ticks >= 80 && ticks <= 1000, "got %u\n", ticks); elapsed = (end.QuadPart - start.QuadPart) / 10000;
ok(90 <= elapsed && elapsed <= 900, "timed out in %u ms\n", elapsed);
ok(address == 0, "got %s\n", wine_dbgstr_longlong(address)); ok(address == 0, "got %s\n", wine_dbgstr_longlong(address));
ok(compare == 0, "got %s\n", wine_dbgstr_longlong(compare)); ok(compare == 0, "got %s\n", wine_dbgstr_longlong(compare));
...@@ -2314,12 +2314,13 @@ static void test_wait_on_address(void) ...@@ -2314,12 +2314,13 @@ static void test_wait_on_address(void)
compare = ~0; compare = ~0;
compare <<= size * 8; compare <<= size * 8;
pNtQuerySystemTime(&start);
timeout.QuadPart = -100 * 10000; timeout.QuadPart = -100 * 10000;
ticks = GetTickCount();
status = pRtlWaitOnAddress(&address, &compare, size, &timeout); status = pRtlWaitOnAddress(&address, &compare, size, &timeout);
ticks = GetTickCount() - ticks; pNtQuerySystemTime(&end);
ok(status == STATUS_TIMEOUT, "got 0x%08x\n", status); ok(status == STATUS_TIMEOUT, "got 0x%08x\n", status);
ok(ticks >= 80 && ticks <= 1000, "got %u\n", ticks); elapsed = (end.QuadPart - start.QuadPart) / 10000;
ok(90 <= elapsed && elapsed <= 900, "timed out in %u ms\n", elapsed);
status = pRtlWaitOnAddress(&address, &compare, size << 1, &timeout); status = pRtlWaitOnAddress(&address, &compare, size << 1, &timeout);
ok(!status, "got 0x%08x\n", status); ok(!status, "got 0x%08x\n", status);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment