From b53f87865c580a006ead4003c84d1280db71703d Mon Sep 17 00:00:00 2001 From: Dmitry Timoshkov Date: Thu, 8 Apr 2004 19:07:06 +0000 Subject: [PATCH] Add WM_SETREDRAW test. --- dlls/user/tests/msg.c | 50 +++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 49 insertions(+), 1 deletion(-) diff --git a/dlls/user/tests/msg.c b/dlls/user/tests/msg.c index 40ee8fb8ffd..f6bd19b0503 100644 --- a/dlls/user/tests/msg.c +++ b/dlls/user/tests/msg.c @@ -401,6 +401,18 @@ static const struct message WmSetMenuVisibleNoSizeChangeSeq[] = { { 0 } }; +static const struct message WmSetRedrawFalseSeq[] = +{ + { WM_SETREDRAW, sent|wparam, 0 }, + { 0 } +}; + +static const struct message WmSetRedrawTrueSeq[] = +{ + { WM_SETREDRAW, sent|wparam, 1 }, + { 0 } +}; + static int sequence_cnt, sequence_size; static struct message* sequence; @@ -492,6 +504,31 @@ static void ok_sequence(const struct message *expected, const char *context) flush_sequence(); } +static void test_WM_SETREDRAW(HWND hwnd) +{ + DWORD style = GetWindowLongA(hwnd, GWL_STYLE); + + flush_sequence(); + + SendMessageA(hwnd, WM_SETREDRAW, FALSE, 0); + ok_sequence(WmSetRedrawFalseSeq, "SetRedraw:FALSE"); + + ok(!(GetWindowLongA(hwnd, GWL_STYLE) & WS_VISIBLE), "WS_VISIBLE should NOT be set\n"); + ok(!IsWindowVisible(hwnd), "IsWindowVisible() should return FALSE\n"); + + flush_sequence(); + SendMessageA(hwnd, WM_SETREDRAW, TRUE, 0); + ok_sequence(WmSetRedrawTrueSeq, "SetRedraw:TRUE"); + + ok(GetWindowLongA(hwnd, GWL_STYLE) & WS_VISIBLE, "WS_VISIBLE should be set\n"); + ok(IsWindowVisible(hwnd), "IsWindowVisible() should return TRUE"); + + /* restore original WS_VISIBLE state */ + SetWindowLongA(hwnd, GWL_STYLE, style); + + flush_sequence(); +} + /* test if we receive the right sequence of messages */ static void test_messages(void) { @@ -503,10 +540,16 @@ static void test_messages(void) 100, 100, 200, 200, 0, 0, 0, NULL); ok (hwnd != 0, "Failed to create overlapped window\n"); ok_sequence(WmCreateOverlappedSeq, "CreateWindow:overlapped"); + + /* test WM_SETREDRAW on a not visible top level window */ + test_WM_SETREDRAW(hwnd); ShowWindow(hwnd, SW_SHOW); ok_sequence(WmShowOverlappedSeq, "ShowWindow:overlapped"); + /* test WM_SETREDRAW on a visible top level window */ + test_WM_SETREDRAW(hwnd); + DestroyWindow(hwnd); ok_sequence(WmDestroyOverlappedSeq, "DestroyWindow:overlapped"); @@ -528,11 +571,16 @@ static void test_messages(void) hbutton = CreateWindowExA(0, "TestWindowClass", "Test button", WS_CHILDWINDOW, 0, 100, 50, 50, hchild, 0, 0, NULL); ok (hbutton != 0, "Failed to create button window\n"); - flush_sequence(); + + /* test WM_SETREDRAW on a not visible child window */ + test_WM_SETREDRAW(hchild); ShowWindow(hchild, SW_SHOW); ok_sequence(WmShowChildSeq, "ShowWindow:child"); + /* test WM_SETREDRAW on a visible child window */ + test_WM_SETREDRAW(hchild); + SetFocus(hchild); flush_sequence(); -- 2.11.4.GIT