1 /* Unit test suite for static controls.
2  *
3  * Copyright 2007 Google (Mikolaj Zalewski)
4  *
5  * This library is free software; you can redistribute it and/or
6  * modify it under the terms of the GNU Lesser General Public
7  * License as published by the Free Software Foundation; either
8  * version 2.1 of the License, or (at your option) any later version.
9  *
10  * This library is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13  * Lesser General Public License for more details.
14  *
15  * You should have received a copy of the GNU Lesser General Public
16  * License along with this library; if not, write to the Free Software
17  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
18  */
19 
20 #include <stdarg.h>
21 #include <stdio.h>
22 
23 #ifndef __REACTOS__
24 #define STRICT
25 #endif
26 #define WIN32_LEAN_AND_MEAN
27 #include <windows.h>
28 #include "commctrl.h"
29 
30 #include "wine/test.h"
31 
32 #include "v6util.h"
33 
34 #define TODO_COUNT 1
35 
36 #define CTRL_ID 1995
37 
38 static HWND hMainWnd;
39 static int g_nReceivedColorStatic;
40 
41 /* try to make sure pending X events have been processed before continuing */
flush_events(void)42 static void flush_events(void)
43 {
44     MSG msg;
45     int diff = 200;
46     int min_timeout = 100;
47     DWORD time = GetTickCount() + diff;
48 
49     while (diff > 0)
50     {
51         if (MsgWaitForMultipleObjects( 0, NULL, FALSE, min_timeout, QS_ALLINPUT ) == WAIT_TIMEOUT) break;
52         while (PeekMessageA( &msg, 0, 0, 0, PM_REMOVE )) DispatchMessageA( &msg );
53         diff = time - GetTickCount();
54     }
55 }
56 
create_static(DWORD style)57 static HWND create_static(DWORD style)
58 {
59     return CreateWindowA(WC_STATICA, "Test", WS_VISIBLE|WS_CHILD|style, 5, 5, 100, 100, hMainWnd, (HMENU)CTRL_ID, NULL, 0);
60 }
61 
WndProc(HWND hwnd,UINT msg,WPARAM wparam,LPARAM lparam)62 static LRESULT CALLBACK WndProc(HWND hwnd, UINT msg, WPARAM wparam, LPARAM lparam)
63 {
64     switch (msg)
65     {
66     case WM_CTLCOLORSTATIC:
67         {
68             HDC hdc = (HDC)wparam;
69             HRGN hrgn = CreateRectRgn(0, 0, 1, 1);
70             ok(GetClipRgn(hdc, hrgn) == 1, "Static controls during a WM_CTLCOLORSTATIC must have a clipping region\n");
71             DeleteObject(hrgn);
72             g_nReceivedColorStatic++;
73             return (LRESULT) GetStockObject(BLACK_BRUSH);
74         }
75         break;
76     }
77 
78     return DefWindowProcA(hwnd, msg, wparam, lparam);
79 }
80 
test_updates(int style,int flags)81 static void test_updates(int style, int flags)
82 {
83     HWND hStatic = create_static(style);
84     RECT r1 = {20, 20, 30, 30};
85     int exp;
86 
87     flush_events();
88     g_nReceivedColorStatic = 0;
89     /* during each update parent WndProc will test the WM_CTLCOLORSTATIC message */
90     InvalidateRect(hMainWnd, NULL, FALSE);
91     UpdateWindow(hMainWnd);
92     InvalidateRect(hMainWnd, &r1, FALSE);
93     UpdateWindow(hMainWnd);
94     InvalidateRect(hStatic, &r1, FALSE);
95     UpdateWindow(hStatic);
96     InvalidateRect(hStatic, NULL, FALSE);
97     UpdateWindow(hStatic);
98 
99     if ((style & SS_TYPEMASK) == SS_BITMAP)
100     {
101         HDC hdc = GetDC(hStatic);
102         COLORREF colour = GetPixel(hdc, 10, 10);
103     todo_wine
104         ok(colour == 0, "Unexpected pixel color.\n");
105         ReleaseDC(hStatic, hdc);
106     }
107 
108     if (style != SS_ETCHEDHORZ && style != SS_ETCHEDVERT)
109         exp = 4;
110     else
111         exp = 1; /* SS_ETCHED* seems to send WM_CTLCOLORSTATIC only sometimes */
112 
113     if (flags & TODO_COUNT)
114     todo_wine
115         ok(g_nReceivedColorStatic == exp, "Unexpected WM_CTLCOLORSTATIC value %d\n", g_nReceivedColorStatic);
116     else if ((style & SS_TYPEMASK) == SS_ICON || (style & SS_TYPEMASK) == SS_BITMAP)
117         ok(g_nReceivedColorStatic == exp, "Unexpected %u got %u\n", exp, g_nReceivedColorStatic);
118     else
119         ok(g_nReceivedColorStatic == exp, "Unexpected WM_CTLCOLORSTATIC value %d\n", g_nReceivedColorStatic);
120     DestroyWindow(hStatic);
121 }
122 
test_set_text(void)123 static void test_set_text(void)
124 {
125     HWND hStatic = create_static(SS_SIMPLE);
126     char buffA[10];
127 
128     GetWindowTextA(hStatic, buffA, sizeof(buffA));
129     ok(!strcmp(buffA, "Test"), "got wrong text %s\n", buffA);
130 
131     SetWindowTextA(hStatic, NULL);
132     GetWindowTextA(hStatic, buffA, sizeof(buffA));
133     ok(buffA[0] == 0, "got wrong text %s\n", buffA);
134 
135     DestroyWindow(hStatic);
136 }
137 
START_TEST(static)138 START_TEST(static)
139 {
140     static const char classname[] = "testclass";
141     WNDCLASSEXA wndclass;
142     ULONG_PTR ctx_cookie;
143     HANDLE hCtx;
144 
145     if (!load_v6_module(&ctx_cookie, &hCtx))
146         return;
147 
148     wndclass.cbSize         = sizeof(wndclass);
149     wndclass.style          = CS_HREDRAW | CS_VREDRAW;
150     wndclass.lpfnWndProc    = WndProc;
151     wndclass.cbClsExtra     = 0;
152     wndclass.cbWndExtra     = 0;
153     wndclass.hInstance      = GetModuleHandleA(NULL);
154     wndclass.hIcon          = LoadIconA(NULL, (LPCSTR)IDI_APPLICATION);
155     wndclass.hIconSm        = LoadIconA(NULL, (LPCSTR)IDI_APPLICATION);
156     wndclass.hCursor        = LoadCursorA(NULL, (LPCSTR)IDC_ARROW);
157     wndclass.hbrBackground  = GetStockObject(WHITE_BRUSH);
158     wndclass.lpszClassName  = classname;
159     wndclass.lpszMenuName   = NULL;
160     RegisterClassExA(&wndclass);
161 
162     hMainWnd = CreateWindowA(classname, "Test", WS_OVERLAPPEDWINDOW, 0, 0, 500, 500, NULL, NULL,
163         GetModuleHandleA(NULL), NULL);
164     ShowWindow(hMainWnd, SW_SHOW);
165 
166     test_updates(0, 0);
167     test_updates(SS_SIMPLE, 0);
168     test_updates(SS_ICON, 0);
169     test_updates(SS_BITMAP, 0);
170     test_updates(SS_BITMAP | SS_CENTERIMAGE, 0);
171     test_updates(SS_BLACKRECT, TODO_COUNT);
172     test_updates(SS_WHITERECT, TODO_COUNT);
173     test_updates(SS_ETCHEDHORZ, TODO_COUNT);
174     test_updates(SS_ETCHEDVERT, TODO_COUNT);
175     test_set_text();
176 
177     DestroyWindow(hMainWnd);
178 
179     unload_v6_module(ctx_cookie, hCtx);
180 }
181