Commit 3c68ba1b authored by Alexandre Julliard's avatar Alexandre Julliard

winmm/tests: Don't test upper bound on sound duration, it's not guaranteed.

Also avoid infinite waits.
parent b03175e1
...@@ -603,7 +603,7 @@ static void wave_out_test_deviceOut(int device, double duration, ...@@ -603,7 +603,7 @@ static void wave_out_test_deviceOut(int device, double duration,
DWORD nSamplesPerSec = pwfx->nSamplesPerSec; DWORD nSamplesPerSec = pwfx->nSamplesPerSec;
BOOL has_volume = pcaps->dwSupport & WAVECAPS_VOLUME ? TRUE : FALSE; BOOL has_volume = pcaps->dwSupport & WAVECAPS_VOLUME ? TRUE : FALSE;
double paused = 0.0; double paused = 0.0;
double actual; DWORD actual;
DWORD_PTR callback = 0; DWORD_PTR callback = 0;
DWORD_PTR callback_instance = 0; DWORD_PTR callback_instance = 0;
HANDLE thread = 0; HANDLE thread = 0;
...@@ -628,7 +628,7 @@ static void wave_out_test_deviceOut(int device, double duration, ...@@ -628,7 +628,7 @@ static void wave_out_test_deviceOut(int device, double duration,
thread = CreateThread(NULL, 0, callback_thread, hevent, 0, &thread_id); thread = CreateThread(NULL, 0, callback_thread, hevent, 0, &thread_id);
if (thread) { if (thread) {
/* make sure thread is running */ /* make sure thread is running */
WaitForSingleObject(hevent,INFINITE); WaitForSingleObject(hevent,10000);
callback = thread_id; callback = thread_id;
callback_instance = 0; callback_instance = 0;
} else { } else {
...@@ -680,7 +680,7 @@ static void wave_out_test_deviceOut(int device, double duration, ...@@ -680,7 +680,7 @@ static void wave_out_test_deviceOut(int device, double duration,
if (rc!=MMSYSERR_NOERROR) if (rc!=MMSYSERR_NOERROR)
goto EXIT; goto EXIT;
WaitForSingleObject(hevent,INFINITE); WaitForSingleObject(hevent,10000);
ok(pwfx->nChannels==nChannels && ok(pwfx->nChannels==nChannels &&
pwfx->wBitsPerSample==wBitsPerSample && pwfx->wBitsPerSample==wBitsPerSample &&
...@@ -785,19 +785,17 @@ static void wave_out_test_deviceOut(int device, double duration, ...@@ -785,19 +785,17 @@ static void wave_out_test_deviceOut(int device, double duration,
ok(rc==MMSYSERR_NOERROR,"waveOutWrite(%s, header[%d]): rc=%s\n", ok(rc==MMSYSERR_NOERROR,"waveOutWrite(%s, header[%d]): rc=%s\n",
dev_name(device),(i+1)%headers,wave_out_error(rc)); dev_name(device),(i+1)%headers,wave_out_error(rc));
} }
WaitForSingleObject(hevent,INFINITE); WaitForSingleObject(hevent,10000);
} }
} }
/* Check the sound duration was between -10% and +35% of the expected value */ /* Check the sound duration was at least 90% of the expected value */
end=GetTickCount(); end=GetTickCount();
actual = (end - start) / 1000.0; actual = end - start;
if (winetest_debug > 1) trace("sound duration=%u ms\n",actual);
trace("sound duration=%g ms\n",1000*actual); ok(actual > 900 * (duration+paused),
ok((actual > (0.9 * (duration+paused))) && "The sound played for %u ms instead of %g ms\n",
(actual < (1.35 * (duration+paused))), actual,1000*(duration+paused));
"The sound played for %g ms instead of %g ms\n",
1000*actual,1000*(duration+paused));
for (i = 0; i < headers; i++) { for (i = 0; i < headers; i++) {
ok(frags[i].dwFlags=(WHDR_DONE|WHDR_PREPARED), ok(frags[i].dwFlags=(WHDR_DONE|WHDR_PREPARED),
"WHDR_DONE WHDR_PREPARED expected, got %s\n", "WHDR_DONE WHDR_PREPARED expected, got %s\n",
...@@ -817,11 +815,11 @@ static void wave_out_test_deviceOut(int device, double duration, ...@@ -817,11 +815,11 @@ static void wave_out_test_deviceOut(int device, double duration,
rc=waveOutClose(wout); rc=waveOutClose(wout);
ok(rc==MMSYSERR_NOERROR,"waveOutClose(%s): rc=%s\n",dev_name(device), ok(rc==MMSYSERR_NOERROR,"waveOutClose(%s): rc=%s\n",dev_name(device),
wave_out_error(rc)); wave_out_error(rc));
WaitForSingleObject(hevent,INFINITE); WaitForSingleObject(hevent,10000);
EXIT: EXIT:
if ((flags & CALLBACK_TYPEMASK) == CALLBACK_THREAD) { if ((flags & CALLBACK_TYPEMASK) == CALLBACK_THREAD) {
PostThreadMessage(thread_id, WM_APP, 0, 0); PostThreadMessage(thread_id, WM_APP, 0, 0);
WaitForSingleObject(hevent,INFINITE); WaitForSingleObject(hevent,10000);
} }
CloseHandle(hevent); CloseHandle(hevent);
HeapFree(GetProcessHeap(), 0, frags); HeapFree(GetProcessHeap(), 0, frags);
......
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