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
886b778a
Commit
886b778a
authored
Nov 24, 2023
by
Esme Povirk
Committed by
Alexandre Julliard
Nov 27, 2023
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
user32/tests: Remove test_SendMessage_other_thread(2).
Wine-Bug:
https://bugs.winehq.org/show_bug.cgi?id=54037
parent
9587214b
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
6 additions
and
42 deletions
+6
-42
msg.c
dlls/user32/tests/msg.c
+6
-42
No files found.
dlls/user32/tests/msg.c
View file @
886b778a
...
...
@@ -19732,37 +19732,7 @@ static DWORD WINAPI SendMessage_thread_1(void *param)
return
0
;
}
static
DWORD
WINAPI
SendMessage_thread_2
(
void
*
param
)
{
struct
wnd_event
*
wnd_event
=
param
;
DWORD
ret
;
if
(
winetest_debug
>
1
)
trace
(
"thread: starting
\n
"
);
WaitForSingleObject
(
wnd_event
->
start_event
,
INFINITE
);
if
(
winetest_debug
>
1
)
trace
(
"thread: call PostMessage
\n
"
);
PostMessageA
(
wnd_event
->
hwnd
,
WM_USER
,
0
,
0
);
if
(
winetest_debug
>
1
)
trace
(
"thread: call PostMessage
\n
"
);
PostMessageA
(
wnd_event
->
hwnd
,
WM_USER
+
1
,
0
,
0
);
/* this leads to sending an internal message under Wine */
if
(
winetest_debug
>
1
)
trace
(
"thread: call SetParent
\n
"
);
SetParent
(
wnd_event
->
hwnd
,
wnd_event
->
hwnd
);
if
(
winetest_debug
>
1
)
trace
(
"thread: call SendMessage
\n
"
);
SendMessageA
(
wnd_event
->
hwnd
,
WM_USER
+
2
,
0
,
0
);
SetEvent
(
wnd_event
->
stop_event
);
ret
=
WaitForSingleObject
(
wnd_event
->
getmessage_complete
,
100
);
ok
(
ret
==
WAIT_OBJECT_0
,
"WaitForSingleObject failed, ret:%lx
\n
"
,
ret
);
if
(
winetest_debug
>
1
)
trace
(
"thread: call SendMessage
\n
"
);
SendMessageA
(
wnd_event
->
hwnd
,
WM_USER
+
3
,
0
,
0
);
return
0
;
}
static
void
test_SendMessage_other_thread
(
int
thread_n
)
static
void
test_SendMessage_other_thread
(
void
)
{
DWORD
qs_all_input
=
QS_ALLINPUT
&
~
QS_RAWINPUT
;
HANDLE
hthread
;
...
...
@@ -19770,8 +19740,6 @@ static void test_SendMessage_other_thread(int thread_n)
DWORD
tid
,
ret
;
MSG
msg
;
winetest_push_context
(
"thread_%i"
,
thread_n
);
wnd_event
.
start_event
=
CreateEventA
(
NULL
,
0
,
0
,
NULL
);
wnd_event
.
stop_event
=
CreateEventA
(
NULL
,
0
,
0
,
NULL
);
wnd_event
.
getmessage_complete
=
CreateEventA
(
NULL
,
0
,
0
,
NULL
);
...
...
@@ -19780,7 +19748,7 @@ static void test_SendMessage_other_thread(int thread_n)
100
,
100
,
200
,
200
,
0
,
0
,
0
,
NULL
);
ok
(
wnd_event
.
hwnd
!=
0
,
"CreateWindowEx failed
\n
"
);
hthread
=
CreateThread
(
NULL
,
0
,
thread_n
==
1
?
SendMessage_thread_1
:
SendMessage_thread_2
,
&
wnd_event
,
0
,
&
tid
);
hthread
=
CreateThread
(
NULL
,
0
,
SendMessage_thread_1
,
&
wnd_event
,
0
,
&
tid
);
ok
(
hthread
!=
NULL
,
"CreateThread failed, error %ld
\n
"
,
GetLastError
());
CloseHandle
(
hthread
);
...
...
@@ -19807,12 +19775,11 @@ static void test_SendMessage_other_thread(int thread_n)
GetMessageA
(
&
msg
,
0
,
0
,
0
);
ok
(
msg
.
message
==
WM_USER
,
"expected WM_USER, got %04x
\n
"
,
msg
.
message
);
DispatchMessageA
(
&
msg
);
ok_sequence
(
send_message_1
,
"SendMessage from other thread 1"
,
thread_n
==
2
);
ok_sequence
(
send_message_1
,
"SendMessage from other thread 1"
,
FALSE
);
SetEvent
(
wnd_event
.
getmessage_complete
);
ret
=
WaitForSingleObject
(
wnd_event
.
stop_event
,
100
);
todo_wine_if
(
thread_n
==
2
)
ok
(
ret
==
WAIT_OBJECT_0
,
"WaitForSingleObject failed, ret:%lx
\n
"
,
ret
);
/* intentionally yield */
...
...
@@ -19829,7 +19796,7 @@ static void test_SendMessage_other_thread(int thread_n)
ok
(
PeekMessageA
(
&
msg
,
0
,
0
,
0
,
PM_REMOVE
),
"PeekMessage should not fail
\n
"
);
ok
(
msg
.
message
==
WM_USER
+
1
,
"expected WM_USER+1, got %04x
\n
"
,
msg
.
message
);
DispatchMessageA
(
&
msg
);
ok_sequence
(
send_message_3
,
"SendMessage from other thread 3"
,
thread_n
==
2
);
ok_sequence
(
send_message_3
,
"SendMessage from other thread 3"
,
FALSE
);
/* intentionally yield */
MsgWaitForMultipleObjects
(
0
,
NULL
,
FALSE
,
100
,
qs_all_input
);
...
...
@@ -19838,7 +19805,7 @@ static void test_SendMessage_other_thread(int thread_n)
while
(
PeekMessageA
(
&
msg
,
0
,
0
,
0
,
PM_REMOVE
))
{
ok
(
ignore_message
(
msg
.
message
),
"got unexpected message %04x from PeekMessageA
\n
"
,
msg
.
message
);
}
ok_sequence
(
send_message_5
,
"SendMessage from other thread 5"
,
thread_n
==
2
);
ok_sequence
(
send_message_5
,
"SendMessage from other thread 5"
,
FALSE
);
ret
=
GetQueueStatus
(
QS_SENDMESSAGE
|
QS_POSTMESSAGE
);
ok
(
ret
==
0
,
"wrong status %08lx
\n
"
,
ret
);
...
...
@@ -19849,8 +19816,6 @@ static void test_SendMessage_other_thread(int thread_n)
flush_events
();
flush_sequence
();
winetest_pop_context
();
CloseHandle
(
wnd_event
.
start_event
);
CloseHandle
(
wnd_event
.
stop_event
);
CloseHandle
(
wnd_event
.
getmessage_complete
);
...
...
@@ -20295,8 +20260,7 @@ START_TEST(msg)
if
(
!
hCBT_hook
)
win_skip
(
"cannot set global hook, will skip hook tests
\n
"
);
test_winevents
();
test_SendMessage_other_thread
(
1
);
test_SendMessage_other_thread
(
2
);
test_SendMessage_other_thread
();
test_setparent_status
();
test_InSendMessage
();
test_SetFocus
();
...
...
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