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
c86bd676
Commit
c86bd676
authored
Sep 29, 2014
by
Piotr Caban
Committed by
Alexandre Julliard
Sep 29, 2014
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
user32/tests: Add cross-process WindowFromPoint tests.
parent
d137a95f
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
96 additions
and
2 deletions
+96
-2
win.c
dlls/user32/tests/win.c
+96
-2
No files found.
dlls/user32/tests/win.c
View file @
c86bd676
...
@@ -103,6 +103,22 @@ static void flush_events( BOOL remove_messages )
...
@@ -103,6 +103,22 @@ static void flush_events( BOOL remove_messages )
}
}
}
}
static
BOOL
wait_for_event
(
HANDLE
event
,
int
timeout
)
{
DWORD
end_time
=
GetTickCount
()
+
timeout
;
MSG
msg
;
do
{
if
(
MsgWaitForMultipleObjects
(
1
,
&
event
,
FALSE
,
timeout
,
QS_ALLINPUT
)
==
WAIT_OBJECT_0
)
return
TRUE
;
while
(
PeekMessageA
(
&
msg
,
0
,
0
,
0
,
PM_REMOVE
))
DispatchMessageA
(
&
msg
);
timeout
=
end_time
-
GetTickCount
();
}
while
(
timeout
>
0
);
return
FALSE
;
}
/* check the values returned by the various parent/owner functions on a given window */
/* 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
,
static
void
check_parents
(
HWND
hwnd
,
HWND
ga_parent
,
HWND
gwl_parent
,
HWND
get_parent
,
HWND
gw_owner
,
HWND
ga_root
,
HWND
ga_root_owner
)
HWND
gw_owner
,
HWND
ga_root
,
HWND
ga_root_owner
)
...
@@ -7200,10 +7216,49 @@ todo_wine
...
@@ -7200,10 +7216,49 @@ todo_wine
ok
(
ret
,
"UnregisterClass(my_window) failed
\n
"
);
ok
(
ret
,
"UnregisterClass(my_window) failed
\n
"
);
}
}
static
void
test_window_from_point
(
void
)
static
void
window_from_point_proc
(
HWND
parent
)
{
HANDLE
start_event
,
end_event
;
HANDLE
win
,
child_static
,
child_button
;
DWORD
ret
;
POINT
pt
;
start_event
=
OpenEventA
(
EVENT_ALL_ACCESS
,
FALSE
,
"test_wfp_start"
);
ok
(
start_event
!=
0
,
"OpenEvent failed
\n
"
);
end_event
=
OpenEventA
(
EVENT_ALL_ACCESS
,
FALSE
,
"test_wfp_end"
);
ok
(
end_event
!=
0
,
"OpenEvent failed
\n
"
);
child_static
=
CreateWindowExA
(
0
,
"static"
,
"static"
,
WS_CHILD
|
WS_VISIBLE
,
0
,
0
,
100
,
100
,
parent
,
0
,
NULL
,
NULL
);
ok
(
child_static
!=
0
,
"CreateWindowEx failed
\n
"
);
pt
.
x
=
pt
.
y
=
150
;
win
=
WindowFromPoint
(
pt
);
ok
(
win
==
parent
,
"WindowFromPoint returned %p, expected %p
\n
"
,
win
,
parent
);
child_button
=
CreateWindowExA
(
0
,
"button"
,
"button"
,
WS_CHILD
|
WS_VISIBLE
,
100
,
0
,
100
,
100
,
parent
,
0
,
NULL
,
NULL
);
ok
(
child_button
!=
0
,
"CreateWindowEx failed
\n
"
);
pt
.
x
=
250
;
win
=
WindowFromPoint
(
pt
);
ok
(
win
==
child_button
,
"WindowFromPoint returned %p, expected %p
\n
"
,
win
,
child_button
);
SetEvent
(
start_event
);
ret
=
WaitForSingleObject
(
end_event
,
5000
);
ok
(
ret
==
WAIT_OBJECT_0
,
"WaitForSingleObject returned %x
\n
"
,
ret
);
CloseHandle
(
start_event
);
CloseHandle
(
end_event
);
}
static
void
test_window_from_point
(
const
char
*
argv0
)
{
{
HWND
hwnd
,
child
,
win
;
HWND
hwnd
,
child
,
win
;
POINT
pt
;
POINT
pt
;
PROCESS_INFORMATION
info
;
STARTUPINFOA
startup
;
char
cmd
[
MAX_PATH
];
HANDLE
start_event
,
end_event
;
hwnd
=
CreateWindowExA
(
0
,
"MainWindowClass"
,
NULL
,
WS_POPUP
|
WS_VISIBLE
,
hwnd
=
CreateWindowExA
(
0
,
"MainWindowClass"
,
NULL
,
WS_POPUP
|
WS_VISIBLE
,
100
,
100
,
200
,
100
,
0
,
0
,
NULL
,
NULL
);
100
,
100
,
200
,
100
,
0
,
0
,
NULL
,
NULL
);
...
@@ -7235,6 +7290,34 @@ static void test_window_from_point(void)
...
@@ -7235,6 +7290,34 @@ static void test_window_from_point(void)
ok
(
win
==
child
,
"WindowFromPoint returned %p, expected %p
\n
"
,
win
,
child
);
ok
(
win
==
child
,
"WindowFromPoint returned %p, expected %p
\n
"
,
win
,
child
);
DestroyWindow
(
child
);
DestroyWindow
(
child
);
start_event
=
CreateEventA
(
NULL
,
FALSE
,
FALSE
,
"test_wfp_start"
);
ok
(
start_event
!=
0
,
"CreateEvent failed
\n
"
);
end_event
=
CreateEventA
(
NULL
,
FALSE
,
FALSE
,
"test_wfp_end"
);
ok
(
start_event
!=
0
,
"CreateEvent failed
\n
"
);
sprintf
(
cmd
,
"%s win create_children %p
\n
"
,
argv0
,
hwnd
);
memset
(
&
startup
,
0
,
sizeof
(
startup
));
startup
.
cb
=
sizeof
(
startup
);
ok
(
CreateProcessA
(
NULL
,
cmd
,
NULL
,
NULL
,
FALSE
,
0
,
NULL
,
NULL
,
&
startup
,
&
info
),
"CreateProcess failed.
\n
"
);
ok
(
wait_for_event
(
start_event
,
1000
),
"didn't get start_event
\n
"
);
child
=
GetWindow
(
hwnd
,
GW_CHILD
);
win
=
WindowFromPoint
(
pt
);
ok
(
win
==
child
,
"WindowFromPoint returned %p, expected %p
\n
"
,
win
,
child
);
child
=
GetWindow
(
child
,
GW_HWNDNEXT
);
pt
.
x
=
250
;
win
=
WindowFromPoint
(
pt
);
ok
(
win
==
child
,
"WindowFromPoint returned %p, expected %p
\n
"
,
win
,
child
);
SetEvent
(
end_event
);
winetest_wait_child_process
(
info
.
hProcess
);
CloseHandle
(
start_event
);
CloseHandle
(
end_event
);
CloseHandle
(
info
.
hProcess
);
CloseHandle
(
info
.
hThread
);
DestroyWindow
(
hwnd
);
DestroyWindow
(
hwnd
);
}
}
...
@@ -7713,6 +7796,8 @@ static void test_smresult(void)
...
@@ -7713,6 +7796,8 @@ static void test_smresult(void)
START_TEST
(
win
)
START_TEST
(
win
)
{
{
char
**
argv
;
int
argc
=
winetest_get_mainargs
(
&
argv
);
HMODULE
user32
=
GetModuleHandleA
(
"user32.dll"
);
HMODULE
user32
=
GetModuleHandleA
(
"user32.dll"
);
HMODULE
gdi32
=
GetModuleHandleA
(
"gdi32.dll"
);
HMODULE
gdi32
=
GetModuleHandleA
(
"gdi32.dll"
);
pGetAncestor
=
(
void
*
)
GetProcAddress
(
user32
,
"GetAncestor"
);
pGetAncestor
=
(
void
*
)
GetProcAddress
(
user32
,
"GetAncestor"
);
...
@@ -7733,6 +7818,15 @@ START_TEST(win)
...
@@ -7733,6 +7818,15 @@ START_TEST(win)
pSetLayout
=
(
void
*
)
GetProcAddress
(
gdi32
,
"SetLayout"
);
pSetLayout
=
(
void
*
)
GetProcAddress
(
gdi32
,
"SetLayout"
);
pMirrorRgn
=
(
void
*
)
GetProcAddress
(
gdi32
,
"MirrorRgn"
);
pMirrorRgn
=
(
void
*
)
GetProcAddress
(
gdi32
,
"MirrorRgn"
);
if
(
argc
==
4
&&
!
strcmp
(
argv
[
2
],
"create_children"
))
{
HWND
hwnd
;
sscanf
(
argv
[
3
],
"%p"
,
&
hwnd
);
window_from_point_proc
(
hwnd
);
return
;
}
if
(
!
RegisterWindowClasses
())
assert
(
0
);
if
(
!
RegisterWindowClasses
())
assert
(
0
);
hwndMain
=
CreateWindowExA
(
/*WS_EX_TOOLWINDOW*/
0
,
"MainWindowClass"
,
"Main window"
,
hwndMain
=
CreateWindowExA
(
/*WS_EX_TOOLWINDOW*/
0
,
"MainWindowClass"
,
"Main window"
,
...
@@ -7783,7 +7877,7 @@ START_TEST(win)
...
@@ -7783,7 +7877,7 @@ START_TEST(win)
/* Add the tests below this line */
/* Add the tests below this line */
test_child_window_from_point
();
test_child_window_from_point
();
test_window_from_point
();
test_window_from_point
(
argv
[
0
]
);
test_thick_child_size
(
hwndMain
);
test_thick_child_size
(
hwndMain
);
test_fullscreen
();
test_fullscreen
();
test_hwnd_message
();
test_hwnd_message
();
...
...
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