Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
88de9ef0
Commit
88de9ef0
authored
Oct 24, 2003
by
Dmitry Timoshkov
Committed by
Alexandre Julliard
Oct 24, 2003
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
More tests for window creation parameters.
parent
dfa1f6a8
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
183 additions
and
3 deletions
+183
-3
win.c
dlls/user/tests/win.c
+183
-3
No files found.
dlls/user/tests/win.c
View file @
88de9ef0
...
...
@@ -41,6 +41,7 @@
static
HWND
(
WINAPI
*
pGetAncestor
)(
HWND
,
UINT
);
static
HWND
hwndMain
,
hwndMain2
;
static
HHOOK
hhook
;
/* check the values returned by the various parent/owner functions on a given window */
static
void
check_parents
(
HWND
hwnd
,
HWND
ga_parent
,
HWND
gwl_parent
,
HWND
get_parent
,
...
...
@@ -112,6 +113,18 @@ static void test_parent_owner(void)
SetWindowLongA
(
test
,
GWL_STYLE
,
WS_CHILD
);
DestroyWindow
(
test
);
/* normal child window with WS_MAXIMIZE */
test
=
create_tool_window
(
WS_CHILD
|
WS_MAXIMIZE
,
hwndMain
);
DestroyWindow
(
test
);
/* normal child window with WS_THICKFRAME */
test
=
create_tool_window
(
WS_CHILD
|
WS_THICKFRAME
,
hwndMain
);
DestroyWindow
(
test
);
/* popup window with WS_THICKFRAME */
test
=
create_tool_window
(
WS_POPUP
|
WS_THICKFRAME
,
hwndMain
);
DestroyWindow
(
test
);
/* child of desktop */
test
=
create_tool_window
(
WS_CHILD
,
desktop
);
trace
(
"created child of desktop %p
\n
"
,
test
);
...
...
@@ -122,6 +135,14 @@ static void test_parent_owner(void)
check_parents
(
test
,
desktop
,
0
,
0
,
0
,
test
,
test
);
DestroyWindow
(
test
);
/* child of desktop with WS_MAXIMIZE */
test
=
create_tool_window
(
WS_CHILD
|
WS_MAXIMIZE
,
desktop
);
DestroyWindow
(
test
);
/* child of desktop with WS_MINIMIZE */
test
=
create_tool_window
(
WS_CHILD
|
WS_MINIMIZE
,
desktop
);
DestroyWindow
(
test
);
/* child of child */
test
=
create_tool_window
(
WS_CHILD
,
child
);
trace
(
"created child of child %p
\n
"
,
test
);
...
...
@@ -132,6 +153,14 @@ static void test_parent_owner(void)
check_parents
(
test
,
child
,
child
,
0
,
0
,
hwndMain
,
test
);
DestroyWindow
(
test
);
/* child of child with WS_MAXIMIZE */
test
=
create_tool_window
(
WS_CHILD
|
WS_MAXIMIZE
,
child
);
DestroyWindow
(
test
);
/* child of child with WS_MINIMIZE */
test
=
create_tool_window
(
WS_CHILD
|
WS_MINIMIZE
,
child
);
DestroyWindow
(
test
);
/* not owned top-level window */
test
=
create_tool_window
(
0
,
0
);
trace
(
"created top-level %p
\n
"
,
test
);
...
...
@@ -142,6 +171,10 @@ static void test_parent_owner(void)
check_parents
(
test
,
desktop
,
0
,
desktop
,
0
,
test
,
desktop
);
DestroyWindow
(
test
);
/* not owned top-level window with WS_MAXIMIZE */
test
=
create_tool_window
(
WS_MAXIMIZE
,
0
);
DestroyWindow
(
test
);
/* owned top-level window */
test
=
create_tool_window
(
0
,
hwndMain
);
trace
(
"created owned top-level %p
\n
"
,
test
);
...
...
@@ -152,6 +185,10 @@ static void test_parent_owner(void)
check_parents
(
test
,
desktop
,
hwndMain
,
desktop
,
hwndMain
,
test
,
desktop
);
DestroyWindow
(
test
);
/* owned top-level window with WS_MAXIMIZE */
test
=
create_tool_window
(
WS_MAXIMIZE
,
hwndMain
);
DestroyWindow
(
test
);
/* not owned popup */
test
=
create_tool_window
(
WS_POPUP
,
0
);
trace
(
"created popup %p
\n
"
,
test
);
...
...
@@ -162,6 +199,10 @@ static void test_parent_owner(void)
check_parents
(
test
,
desktop
,
0
,
0
,
0
,
test
,
test
);
DestroyWindow
(
test
);
/* not owned popup with WS_MAXIMIZE */
test
=
create_tool_window
(
WS_POPUP
|
WS_MAXIMIZE
,
0
);
DestroyWindow
(
test
);
/* owned popup */
test
=
create_tool_window
(
WS_POPUP
,
hwndMain
);
trace
(
"created owned popup %p
\n
"
,
test
);
...
...
@@ -172,47 +213,72 @@ static void test_parent_owner(void)
check_parents
(
test
,
desktop
,
hwndMain
,
0
,
hwndMain
,
test
,
test
);
DestroyWindow
(
test
);
/* owned popup with WS_MAXIMIZE */
test
=
create_tool_window
(
WS_POPUP
|
WS_MAXIMIZE
,
hwndMain
);
DestroyWindow
(
test
);
/* top-level window owned by child (same as owned by top-level) */
test
=
create_tool_window
(
0
,
child
);
trace
(
"created top-level owned by child %p
\n
"
,
test
);
check_parents
(
test
,
desktop
,
hwndMain
,
0
,
hwndMain
,
test
,
test
);
DestroyWindow
(
test
);
/* top-level window owned by child (same as owned by top-level) with WS_MAXIMIZE */
test
=
create_tool_window
(
WS_MAXIMIZE
,
child
);
DestroyWindow
(
test
);
/* popup owned by desktop (same as not owned) */
test
=
create_tool_window
(
WS_POPUP
,
desktop
);
trace
(
"created popup owned by desktop %p
\n
"
,
test
);
check_parents
(
test
,
desktop
,
0
,
0
,
0
,
test
,
test
);
DestroyWindow
(
test
);
/* popup owned by desktop (same as not owned) with WS_MAXIMIZE */
test
=
create_tool_window
(
WS_POPUP
|
WS_MAXIMIZE
,
desktop
);
DestroyWindow
(
test
);
/* popup owned by child (same as owned by top-level) */
test
=
create_tool_window
(
WS_POPUP
,
child
);
trace
(
"created popup owned by child %p
\n
"
,
test
);
check_parents
(
test
,
desktop
,
hwndMain
,
hwndMain
,
hwndMain
,
test
,
hwndMain
);
DestroyWindow
(
test
);
/* popup owned by child (same as owned by top-level) with WS_MAXIMIZE */
test
=
create_tool_window
(
WS_POPUP
|
WS_MAXIMIZE
,
child
);
DestroyWindow
(
test
);
/* not owned popup with WS_CHILD (same as WS_POPUP only) */
test
=
create_tool_window
(
WS_POPUP
|
WS_CHILD
,
0
);
trace
(
"created WS_CHILD popup %p
\n
"
,
test
);
check_parents
(
test
,
desktop
,
0
,
0
,
0
,
test
,
test
);
DestroyWindow
(
test
);
/* not owned popup with WS_CHILD | WS_MAXIMIZE (same as WS_POPUP only) */
test
=
create_tool_window
(
WS_POPUP
|
WS_CHILD
|
WS_MAXIMIZE
,
0
);
DestroyWindow
(
test
);
/* owned popup with WS_CHILD (same as WS_POPUP only) */
test
=
create_tool_window
(
WS_POPUP
|
WS_CHILD
,
hwndMain
);
trace
(
"created owned WS_CHILD popup %p
\n
"
,
test
);
check_parents
(
test
,
desktop
,
hwndMain
,
hwndMain
,
hwndMain
,
test
,
hwndMain
);
DestroyWindow
(
test
);
/* owned popup with WS_CHILD (same as WS_POPUP only) with WS_MAXIMIZE */
test
=
create_tool_window
(
WS_POPUP
|
WS_CHILD
|
WS_MAXIMIZE
,
hwndMain
);
DestroyWindow
(
test
);
/******************** parent changes *************************/
trace
(
"testing parent changes
\n
"
);
/* desktop window */
check_parents
(
desktop
,
0
,
0
,
0
,
0
,
0
,
0
);
#if 0 /* this test succeeds on NT but crashes on win9x systems */
ret = (HWND)SetWindowLongA( test, GWL_HWNDPARENT, (LONG_PTR)hwndMain2 );
ok( !ret, "Set GWL_HWNDPARENT succeeded on desktop" );
check_parents( desktop, 0, 0, 0, 0, 0, 0 );
ok( !SetParent( desktop, hwndMain ), "SetParent succeeded on desktop" );
check_parents( desktop, 0, 0, 0, 0, 0, 0 );
#endif
/* normal child window */
test
=
create_tool_window
(
WS_CHILD
,
hwndMain
);
trace
(
"created child %p
\n
"
,
test
);
...
...
@@ -354,12 +420,90 @@ static void test_parent_owner(void)
}
static
LRESULT
WINAPI
main_window_procA
(
HWND
hwnd
,
UINT
msg
,
WPARAM
wparam
,
LPARAM
lparam
)
{
switch
(
msg
)
{
case
WM_GETMINMAXINFO
:
{
MINMAXINFO
*
minmax
=
(
MINMAXINFO
*
)
lparam
;
trace
(
"hwnd %p, WM_GETMINMAXINFO, %08x, %08lx
\n
"
,
hwnd
,
wparam
,
lparam
);
trace
(
"ptReserved (%ld,%ld), ptMaxSize (%ld,%ld), ptMaxPosition (%ld,%ld)
\n
"
" ptMinTrackSize (%ld,%ld), ptMaxTrackSize (%ld,%ld)
\n
"
,
minmax
->
ptReserved
.
x
,
minmax
->
ptReserved
.
y
,
minmax
->
ptMaxSize
.
x
,
minmax
->
ptMaxSize
.
y
,
minmax
->
ptMaxPosition
.
x
,
minmax
->
ptMaxPosition
.
y
,
minmax
->
ptMinTrackSize
.
x
,
minmax
->
ptMinTrackSize
.
y
,
minmax
->
ptMaxTrackSize
.
x
,
minmax
->
ptMaxTrackSize
.
y
);
SetWindowLongA
(
hwnd
,
GWL_USERDATA
,
0x20031021
);
break
;
}
case
WM_NCCREATE
:
{
BOOL
got_getminmaxinfo
=
GetWindowLongA
(
hwnd
,
GWL_USERDATA
)
==
0x20031021
;
CREATESTRUCTA
*
cs
=
(
CREATESTRUCTA
*
)
lparam
;
trace
(
"WM_NCCREATE: hwnd %p, parent %p, style %08lx
\n
"
,
hwnd
,
cs
->
hwndParent
,
cs
->
style
);
if
(
got_getminmaxinfo
)
trace
(
"%p got WM_GETMINMAXINFO
\n
"
,
hwnd
);
if
((
cs
->
style
&
WS_THICKFRAME
)
||
!
(
cs
->
style
&
(
WS_POPUP
|
WS_CHILD
)))
ok
(
got_getminmaxinfo
,
"main: WM_GETMINMAXINFO should have been received before WM_NCCREATE
\n
"
);
else
ok
(
!
got_getminmaxinfo
,
"main: WM_GETMINMAXINFO should NOT have been received before WM_NCCREATE
\n
"
);
break
;
}
}
return
DefWindowProcA
(
hwnd
,
msg
,
wparam
,
lparam
);
}
static
LRESULT
WINAPI
tool_window_procA
(
HWND
hwnd
,
UINT
msg
,
WPARAM
wparam
,
LPARAM
lparam
)
{
switch
(
msg
)
{
case
WM_GETMINMAXINFO
:
{
MINMAXINFO
*
minmax
=
(
MINMAXINFO
*
)
lparam
;
trace
(
"hwnd %p, WM_GETMINMAXINFO, %08x, %08lx
\n
"
,
hwnd
,
wparam
,
lparam
);
trace
(
"ptReserved (%ld,%ld), ptMaxSize (%ld,%ld), ptMaxPosition (%ld,%ld)
\n
"
" ptMinTrackSize (%ld,%ld), ptMaxTrackSize (%ld,%ld)
\n
"
,
minmax
->
ptReserved
.
x
,
minmax
->
ptReserved
.
y
,
minmax
->
ptMaxSize
.
x
,
minmax
->
ptMaxSize
.
y
,
minmax
->
ptMaxPosition
.
x
,
minmax
->
ptMaxPosition
.
y
,
minmax
->
ptMinTrackSize
.
x
,
minmax
->
ptMinTrackSize
.
y
,
minmax
->
ptMaxTrackSize
.
x
,
minmax
->
ptMaxTrackSize
.
y
);
SetWindowLongA
(
hwnd
,
GWL_USERDATA
,
0x20031021
);
break
;
}
case
WM_NCCREATE
:
{
BOOL
got_getminmaxinfo
=
GetWindowLongA
(
hwnd
,
GWL_USERDATA
)
==
0x20031021
;
CREATESTRUCTA
*
cs
=
(
CREATESTRUCTA
*
)
lparam
;
trace
(
"WM_NCCREATE: hwnd %p, parent %p, style %08lx
\n
"
,
hwnd
,
cs
->
hwndParent
,
cs
->
style
);
if
(
got_getminmaxinfo
)
trace
(
"%p got WM_GETMINMAXINFO
\n
"
,
hwnd
);
if
((
cs
->
style
&
WS_THICKFRAME
)
||
!
(
cs
->
style
&
(
WS_POPUP
|
WS_CHILD
)))
ok
(
got_getminmaxinfo
,
"tool: WM_GETMINMAXINFO should have been received before WM_NCCREATE
\n
"
);
else
ok
(
!
got_getminmaxinfo
,
"tool: WM_GETMINMAXINFO should NOT have been received before WM_NCCREATE
\n
"
);
break
;
}
}
return
DefWindowProcA
(
hwnd
,
msg
,
wparam
,
lparam
);
}
static
BOOL
RegisterWindowClasses
(
void
)
{
WNDCLASSA
cls
;
cls
.
style
=
0
;
cls
.
lpfnWndProc
=
DefWindowP
rocA
;
cls
.
lpfnWndProc
=
main_window_p
rocA
;
cls
.
cbClsExtra
=
0
;
cls
.
cbWndExtra
=
0
;
cls
.
hInstance
=
GetModuleHandleA
(
0
);
...
...
@@ -372,7 +516,7 @@ static BOOL RegisterWindowClasses(void)
if
(
!
RegisterClassA
(
&
cls
))
return
FALSE
;
cls
.
style
=
0
;
cls
.
lpfnWndProc
=
DefWindowP
rocA
;
cls
.
lpfnWndProc
=
tool_window_p
rocA
;
cls
.
cbClsExtra
=
0
;
cls
.
cbWndExtra
=
0
;
cls
.
hInstance
=
GetModuleHandleA
(
0
);
...
...
@@ -387,6 +531,37 @@ static BOOL RegisterWindowClasses(void)
return
TRUE
;
}
static
LRESULT
CALLBACK
cbt_hook_proc
(
int
nCode
,
WPARAM
wParam
,
LPARAM
lParam
)
{
static
const
char
*
CBT_code_name
[
10
]
=
{
"HCBT_MOVESIZE"
,
"HCBT_MINMAX"
,
"HCBT_QS"
,
"HCBT_CREATEWND"
,
"HCBT_DESTROYWND"
,
"HCBT_ACTIVATE"
,
"HCBT_CLICKSKIPPED"
,
"HCBT_KEYSKIPPED"
,
"HCBT_SYSCOMMAND"
,
"HCBT_SETFOCUS"
};
const
char
*
code_name
=
(
nCode
>=
0
&&
nCode
<=
HCBT_SETFOCUS
)
?
CBT_code_name
[
nCode
]
:
"Unknown"
;
trace
(
"CBT: %d (%s), %08x, %08lx
\n
"
,
nCode
,
code_name
,
wParam
,
lParam
);
switch
(
nCode
)
{
case
HCBT_CREATEWND
:
{
CBT_CREATEWNDA
*
createwnd
=
(
CBT_CREATEWNDA
*
)
lParam
;
trace
(
"HCBT_CREATEWND: hwnd %p, parent %p, style %08lx
\n
"
,
(
HWND
)
wParam
,
createwnd
->
lpcs
->
hwndParent
,
createwnd
->
lpcs
->
style
);
ok
(
createwnd
->
hwndInsertAfter
==
HWND_TOP
,
"hwndInsertAfter should be always HWND_TOP
\n
"
);
break
;
}
}
return
CallNextHookEx
(
hhook
,
nCode
,
wParam
,
lParam
);
}
START_TEST
(
win
)
{
...
...
@@ -394,6 +569,9 @@ START_TEST(win)
if
(
!
RegisterWindowClasses
())
assert
(
0
);
hhook
=
SetWindowsHookExA
(
WH_CBT
,
cbt_hook_proc
,
0
,
GetCurrentThreadId
());
assert
(
hhook
);
hwndMain
=
CreateWindowExA
(
/*WS_EX_TOOLWINDOW*/
0
,
"MainWindowClass"
,
"Main window"
,
WS_CAPTION
|
WS_SYSMENU
|
WS_MINIMIZEBOX
|
WS_MAXIMIZEBOX
|
WS_POPUP
,
...
...
@@ -408,4 +586,6 @@ START_TEST(win)
assert
(
hwndMain2
);
test_parent_owner
();
UnhookWindowsHookEx
(
hhook
);
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment