Commit fad9b692 authored by Alexandre Julliard's avatar Alexandre Julliard

user32/tests: Flush events during the mouse button tests.

parent 3e853277
...@@ -59,7 +59,7 @@ static DWORD our_pid; ...@@ -59,7 +59,7 @@ static DWORD our_pid;
#define COUNTOF(arr) (sizeof(arr)/sizeof(arr[0])) #define COUNTOF(arr) (sizeof(arr)/sizeof(arr[0]))
/* try to make sure pending X events have been processed before continuing */ /* try to make sure pending X events have been processed before continuing */
static void flush_events(void) static void flush_events( BOOL remove_messages )
{ {
MSG msg; MSG msg;
int diff = 200; int diff = 200;
...@@ -69,7 +69,8 @@ static void flush_events(void) ...@@ -69,7 +69,8 @@ static void flush_events(void)
while (diff > 0) while (diff > 0)
{ {
if (MsgWaitForMultipleObjects( 0, NULL, FALSE, min_timeout, QS_ALLINPUT ) == WAIT_TIMEOUT) break; if (MsgWaitForMultipleObjects( 0, NULL, FALSE, min_timeout, QS_ALLINPUT ) == WAIT_TIMEOUT) break;
while (PeekMessage( &msg, 0, 0, 0, PM_REMOVE )) DispatchMessage( &msg ); if (remove_messages)
while (PeekMessage( &msg, 0, 0, 0, PM_REMOVE )) DispatchMessage( &msg );
diff = time - GetTickCount(); diff = time - GetTickCount();
min_timeout = 10; min_timeout = 10;
} }
...@@ -631,7 +632,10 @@ static LRESULT WINAPI main_window_procA(HWND hwnd, UINT msg, WPARAM wparam, LPAR ...@@ -631,7 +632,10 @@ static LRESULT WINAPI main_window_procA(HWND hwnd, UINT msg, WPARAM wparam, LPAR
} }
case WM_COMMAND: case WM_COMMAND:
if (test_lbuttondown_flag) if (test_lbuttondown_flag)
{
ShowWindow((HWND)wparam, SW_SHOW); ShowWindow((HWND)wparam, SW_SHOW);
flush_events( FALSE );
}
break; break;
} }
...@@ -2546,14 +2550,14 @@ static void test_keyboard_input(HWND hwnd) ...@@ -2546,14 +2550,14 @@ static void test_keyboard_input(HWND hwnd)
ShowWindow(hwnd, SW_SHOW); ShowWindow(hwnd, SW_SHOW);
UpdateWindow(hwnd); UpdateWindow(hwnd);
flush_events(); flush_events( TRUE );
ok(GetActiveWindow() == hwnd, "wrong active window %p\n", GetActiveWindow()); ok(GetActiveWindow() == hwnd, "wrong active window %p\n", GetActiveWindow());
SetFocus(hwnd); SetFocus(hwnd);
ok(GetFocus() == hwnd, "wrong focus window %p\n", GetFocus()); ok(GetFocus() == hwnd, "wrong focus window %p\n", GetFocus());
flush_events(); flush_events( TRUE );
PostMessageA(hwnd, WM_KEYDOWN, 0, 0); PostMessageA(hwnd, WM_KEYDOWN, 0, 0);
ok(PeekMessageA(&msg, 0, 0, 0, PM_REMOVE), "no message available\n"); ok(PeekMessageA(&msg, 0, 0, 0, PM_REMOVE), "no message available\n");
...@@ -2580,7 +2584,7 @@ static void test_keyboard_input(HWND hwnd) ...@@ -2580,7 +2584,7 @@ static void test_keyboard_input(HWND hwnd)
SetFocus(0); SetFocus(0);
ok(GetFocus() == 0, "wrong focus window %p\n", GetFocus()); ok(GetFocus() == 0, "wrong focus window %p\n", GetFocus());
flush_events(); flush_events( TRUE );
PostMessageA(hwnd, WM_KEYDOWN, 0, 0); PostMessageA(hwnd, WM_KEYDOWN, 0, 0);
ok(PeekMessageA(&msg, 0, 0, 0, PM_REMOVE), "no message available\n"); ok(PeekMessageA(&msg, 0, 0, 0, PM_REMOVE), "no message available\n");
...@@ -2639,7 +2643,7 @@ static void test_mouse_input(HWND hwnd) ...@@ -2639,7 +2643,7 @@ static void test_mouse_input(HWND hwnd)
GetCursorPos(&pt); GetCursorPos(&pt);
ok(x == pt.x && y == pt.y, "wrong cursor pos (%d,%d), expected (%d,%d)\n", pt.x, pt.y, x, y); ok(x == pt.x && y == pt.y, "wrong cursor pos (%d,%d), expected (%d,%d)\n", pt.x, pt.y, x, y);
flush_events(); flush_events( TRUE );
/* Check that setting the same position will generate WM_MOUSEMOVE */ /* Check that setting the same position will generate WM_MOUSEMOVE */
SetCursorPos(x, y); SetCursorPos(x, y);
...@@ -2652,7 +2656,7 @@ static void test_mouse_input(HWND hwnd) ...@@ -2652,7 +2656,7 @@ static void test_mouse_input(HWND hwnd)
* otherwise it won't generate relative mouse movements below. * otherwise it won't generate relative mouse movements below.
*/ */
mouse_event(MOUSEEVENTF_MOVE, -1, -1, 0, 0); mouse_event(MOUSEEVENTF_MOVE, -1, -1, 0, 0);
flush_events(); flush_events( TRUE );
msg.message = 0; msg.message = 0;
mouse_event(MOUSEEVENTF_MOVE, 1, 1, 0, 0); mouse_event(MOUSEEVENTF_MOVE, 1, 1, 0, 0);
...@@ -2668,20 +2672,20 @@ static void test_mouse_input(HWND hwnd) ...@@ -2668,20 +2672,20 @@ static void test_mouse_input(HWND hwnd)
ShowWindow(popup, SW_HIDE); ShowWindow(popup, SW_HIDE);
ok(PeekMessageA(&msg, 0, 0, 0, PM_REMOVE), "no message available\n"); ok(PeekMessageA(&msg, 0, 0, 0, PM_REMOVE), "no message available\n");
ok(msg.hwnd == hwnd && msg.message == WM_MOUSEMOVE, "hwnd %p message %04x\n", msg.hwnd, msg.message); ok(msg.hwnd == hwnd && msg.message == WM_MOUSEMOVE, "hwnd %p message %04x\n", msg.hwnd, msg.message);
flush_events(); flush_events( TRUE );
mouse_event(MOUSEEVENTF_MOVE, 1, 1, 0, 0); mouse_event(MOUSEEVENTF_MOVE, 1, 1, 0, 0);
ShowWindow(hwnd, SW_HIDE); ShowWindow(hwnd, SW_HIDE);
ret = PeekMessageA(&msg, 0, 0, 0, PM_REMOVE); ret = PeekMessageA(&msg, 0, 0, 0, PM_REMOVE);
ok( !ret, "message %04x available\n", msg.message); ok( !ret, "message %04x available\n", msg.message);
flush_events(); flush_events( TRUE );
/* test mouse clicks */ /* test mouse clicks */
ShowWindow(hwnd, SW_SHOW); ShowWindow(hwnd, SW_SHOW);
flush_events(); flush_events( TRUE );
ShowWindow(popup, SW_SHOW); ShowWindow(popup, SW_SHOW);
flush_events(); flush_events( TRUE );
mouse_event(MOUSEEVENTF_LEFTDOWN, 0, 0, 0, 0); mouse_event(MOUSEEVENTF_LEFTDOWN, 0, 0, 0, 0);
mouse_event(MOUSEEVENTF_LEFTUP, 0, 0, 0, 0); mouse_event(MOUSEEVENTF_LEFTUP, 0, 0, 0, 0);
...@@ -2720,7 +2724,7 @@ static void test_mouse_input(HWND hwnd) ...@@ -2720,7 +2724,7 @@ static void test_mouse_input(HWND hwnd)
ok(!ret, "message %04x available\n", msg.message); ok(!ret, "message %04x available\n", msg.message);
ShowWindow(popup, SW_HIDE); ShowWindow(popup, SW_HIDE);
flush_events(); flush_events( TRUE );
mouse_event(MOUSEEVENTF_LEFTDOWN, 0, 0, 0, 0); mouse_event(MOUSEEVENTF_LEFTDOWN, 0, 0, 0, 0);
mouse_event(MOUSEEVENTF_LEFTUP, 0, 0, 0, 0); mouse_event(MOUSEEVENTF_LEFTUP, 0, 0, 0, 0);
...@@ -2777,7 +2781,7 @@ static void test_mouse_input(HWND hwnd) ...@@ -2777,7 +2781,7 @@ static void test_mouse_input(HWND hwnd)
TEST_MOUSEACTIVATE(HTHELP,MA_ACTIVATE); TEST_MOUSEACTIVATE(HTHELP,MA_ACTIVATE);
/* Clear any messages left behind by WM_MOUSEACTIVATE tests */ /* Clear any messages left behind by WM_MOUSEACTIVATE tests */
flush_events(); flush_events( TRUE );
DestroyWindow(popup); DestroyWindow(popup);
} }
...@@ -3031,7 +3035,7 @@ static void check_window_style(DWORD dwStyleIn, DWORD dwExStyleIn, DWORD dwStyle ...@@ -3031,7 +3035,7 @@ static void check_window_style(DWORD dwStyleIn, DWORD dwExStyleIn, DWORD dwStyle
dwStyleIn, 0, 0, 0, 0, hwndParent, NULL, NULL, &ss); dwStyleIn, 0, 0, 0, 0, hwndParent, NULL, NULL, &ss);
assert(hwnd); assert(hwnd);
flush_events(); flush_events( TRUE );
dwActualStyle = GetWindowLong(hwnd, GWL_STYLE); dwActualStyle = GetWindowLong(hwnd, GWL_STYLE);
dwActualExStyle = GetWindowLong(hwnd, GWL_EXSTYLE); dwActualExStyle = GetWindowLong(hwnd, GWL_EXSTYLE);
...@@ -3256,7 +3260,7 @@ static void test_scrolldc( HWND parent) ...@@ -3256,7 +3260,7 @@ static void test_scrolldc( HWND parent)
25, 50, 100, 100, parent, 0, 0, NULL); 25, 50, 100, 100, parent, 0, 0, NULL);
ShowWindow( parent, SW_SHOW); ShowWindow( parent, SW_SHOW);
UpdateWindow( parent); UpdateWindow( parent);
flush_events(); flush_events( TRUE );
GetClientRect( hwnd1, &rc); GetClientRect( hwnd1, &rc);
hdc = GetDC( hwnd1); hdc = GetDC( hwnd1);
/* paint the upper half of the window black */ /* paint the upper half of the window black */
...@@ -3691,47 +3695,47 @@ static void test_csparentdc(void) ...@@ -3691,47 +3695,47 @@ static void test_csparentdc(void)
ShowWindow(hwndMain, SW_SHOW); ShowWindow(hwndMain, SW_SHOW);
ShowWindow(hwnd1, SW_SHOW); ShowWindow(hwnd1, SW_SHOW);
ShowWindow(hwnd2, SW_SHOW); ShowWindow(hwnd2, SW_SHOW);
flush_events(); flush_events( TRUE );
zero_parentdc_test(&test_answer); zero_parentdc_test(&test_answer);
InvalidateRect(hwndMain, NULL, TRUE); InvalidateRect(hwndMain, NULL, TRUE);
flush_events(); flush_events( TRUE );
parentdc_ok(test1, test_answer); parentdc_ok(test1, test_answer);
zero_parentdc_test(&test_answer); zero_parentdc_test(&test_answer);
SetRect(&rc, 0, 0, 50, 50); SetRect(&rc, 0, 0, 50, 50);
InvalidateRect(hwndMain, &rc, TRUE); InvalidateRect(hwndMain, &rc, TRUE);
flush_events(); flush_events( TRUE );
parentdc_ok(test2, test_answer); parentdc_ok(test2, test_answer);
zero_parentdc_test(&test_answer); zero_parentdc_test(&test_answer);
SetRect(&rc, 0, 0, 10, 10); SetRect(&rc, 0, 0, 10, 10);
InvalidateRect(hwndMain, &rc, TRUE); InvalidateRect(hwndMain, &rc, TRUE);
flush_events(); flush_events( TRUE );
parentdc_ok(test3, test_answer); parentdc_ok(test3, test_answer);
zero_parentdc_test(&test_answer); zero_parentdc_test(&test_answer);
SetRect(&rc, 40, 40, 50, 50); SetRect(&rc, 40, 40, 50, 50);
InvalidateRect(hwndMain, &rc, TRUE); InvalidateRect(hwndMain, &rc, TRUE);
flush_events(); flush_events( TRUE );
parentdc_ok(test4, test_answer); parentdc_ok(test4, test_answer);
zero_parentdc_test(&test_answer); zero_parentdc_test(&test_answer);
SetRect(&rc, 20, 20, 60, 60); SetRect(&rc, 20, 20, 60, 60);
InvalidateRect(hwndMain, &rc, TRUE); InvalidateRect(hwndMain, &rc, TRUE);
flush_events(); flush_events( TRUE );
parentdc_ok(test5, test_answer); parentdc_ok(test5, test_answer);
zero_parentdc_test(&test_answer); zero_parentdc_test(&test_answer);
SetRect(&rc, 0, 0, 10, 10); SetRect(&rc, 0, 0, 10, 10);
InvalidateRect(hwnd1, &rc, TRUE); InvalidateRect(hwnd1, &rc, TRUE);
flush_events(); flush_events( TRUE );
parentdc_ok(test6, test_answer); parentdc_ok(test6, test_answer);
zero_parentdc_test(&test_answer); zero_parentdc_test(&test_answer);
SetRect(&rc, -5, -5, 65, 65); SetRect(&rc, -5, -5, 65, 65);
InvalidateRect(hwnd1, &rc, TRUE); InvalidateRect(hwnd1, &rc, TRUE);
flush_events(); flush_events( TRUE );
parentdc_ok(test7, test_answer); parentdc_ok(test7, test_answer);
DestroyWindow(hwndMain); DestroyWindow(hwndMain);
...@@ -4465,7 +4469,7 @@ static void test_GetUpdateRect(void) ...@@ -4465,7 +4469,7 @@ static void test_GetUpdateRect(void)
ShowWindow(hgrandparent, SW_SHOW); ShowWindow(hgrandparent, SW_SHOW);
UpdateWindow(hgrandparent); UpdateWindow(hgrandparent);
flush_events(); flush_events( TRUE );
ShowWindow(hchild, SW_HIDE); ShowWindow(hchild, SW_HIDE);
SetRect(&rc2, 0, 0, 0, 0); SetRect(&rc2, 0, 0, 0, 0);
...@@ -4525,7 +4529,7 @@ static void test_GetUpdateRect(void) ...@@ -4525,7 +4529,7 @@ static void test_GetUpdateRect(void)
ShowWindow(hgrandparent, SW_SHOW); ShowWindow(hgrandparent, SW_SHOW);
UpdateWindow(hgrandparent); UpdateWindow(hgrandparent);
flush_events(); flush_events( TRUE );
ret = GetUpdateRect(hgrandparent, &rc1, FALSE); ret = GetUpdateRect(hgrandparent, &rc1, FALSE);
ok(!ret, "GetUpdateRect returned not empty region\n"); ok(!ret, "GetUpdateRect returned not empty region\n");
......
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