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
73d6140d
Commit
73d6140d
authored
Dec 19, 2022
by
Rémi Bernon
Committed by
Alexandre Julliard
Dec 19, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
user32/tests: Test EnableMouseInPointer behavior.
parent
eefc7a86
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
55 additions
and
0 deletions
+55
-0
input.c
dlls/user32/tests/input.c
+55
-0
No files found.
dlls/user32/tests/input.c
View file @
73d6140d
...
@@ -81,6 +81,7 @@ static struct {
...
@@ -81,6 +81,7 @@ static struct {
BOOL
sendinput_broken
;
BOOL
sendinput_broken
;
}
key_status
;
}
key_status
;
static
BOOL
(
WINAPI
*
pEnableMouseInPointer
)(
BOOL
);
static
BOOL
(
WINAPI
*
pGetCurrentInputMessageSource
)(
INPUT_MESSAGE_SOURCE
*
source
);
static
BOOL
(
WINAPI
*
pGetCurrentInputMessageSource
)(
INPUT_MESSAGE_SOURCE
*
source
);
static
BOOL
(
WINAPI
*
pGetPointerType
)(
UINT32
,
POINTER_INPUT_TYPE
*
);
static
BOOL
(
WINAPI
*
pGetPointerType
)(
UINT32
,
POINTER_INPUT_TYPE
*
);
static
BOOL
(
WINAPI
*
pGetPointerInfo
)(
UINT32
,
POINTER_INFO
*
);
static
BOOL
(
WINAPI
*
pGetPointerInfo
)(
UINT32
,
POINTER_INFO
*
);
...
@@ -149,6 +150,7 @@ static void init_function_pointers(void)
...
@@ -149,6 +150,7 @@ static void init_function_pointers(void)
if (!(p ## func = (void*)GetProcAddress(hdll, #func))) \
if (!(p ## func = (void*)GetProcAddress(hdll, #func))) \
trace("GetProcAddress(%s) failed\n", #func)
trace("GetProcAddress(%s) failed\n", #func)
GET_PROC
(
EnableMouseInPointer
);
GET_PROC
(
GetCurrentInputMessageSource
);
GET_PROC
(
GetCurrentInputMessageSource
);
GET_PROC
(
GetMouseMovePointsEx
);
GET_PROC
(
GetMouseMovePointsEx
);
GET_PROC
(
GetPointerInfo
);
GET_PROC
(
GetPointerInfo
);
...
@@ -4590,6 +4592,43 @@ static void test_SendInput(void)
...
@@ -4590,6 +4592,43 @@ static void test_SendInput(void)
DestroyWindow
(
hwnd
);
DestroyWindow
(
hwnd
);
}
}
static
void
test_EnableMouseInPointer_process
(
const
char
*
arg
)
{
DWORD
enable
=
strtoul
(
arg
,
0
,
10
);
BOOL
ret
;
ret
=
pEnableMouseInPointer
(
enable
);
todo_wine
ok
(
ret
,
"EnableMouseInPointer failed, error %lu
\n
"
,
GetLastError
()
);
SetLastError
(
0xdeadbeef
);
ret
=
pEnableMouseInPointer
(
!
enable
);
ok
(
!
ret
,
"EnableMouseInPointer succeeded
\n
"
);
todo_wine
ok
(
GetLastError
()
==
ERROR_ACCESS_DENIED
,
"got error %lu
\n
"
,
GetLastError
()
);
ret
=
pEnableMouseInPointer
(
enable
);
todo_wine
ok
(
ret
,
"EnableMouseInPointer failed, error %lu
\n
"
,
GetLastError
()
);
}
static
void
test_EnableMouseInPointer
(
char
**
argv
,
BOOL
enable
)
{
STARTUPINFOA
startup
=
{.
cb
=
sizeof
(
STARTUPINFOA
)};
PROCESS_INFORMATION
info
=
{
0
};
char
cmdline
[
MAX_PATH
*
2
];
BOOL
ret
;
sprintf
(
cmdline
,
"%s %s EnableMouseInPointer %u"
,
argv
[
0
],
argv
[
1
],
enable
);
ret
=
CreateProcessA
(
NULL
,
cmdline
,
NULL
,
NULL
,
FALSE
,
0
,
NULL
,
NULL
,
&
startup
,
&
info
);
ok
(
ret
,
"CreateProcessA failed, error %lu
\n
"
,
GetLastError
()
);
if
(
!
ret
)
return
;
wait_child_process
(
info
.
hProcess
);
CloseHandle
(
info
.
hThread
);
CloseHandle
(
info
.
hProcess
);
}
START_TEST
(
input
)
START_TEST
(
input
)
{
{
char
**
argv
;
char
**
argv
;
...
@@ -4612,6 +4651,14 @@ START_TEST(input)
...
@@ -4612,6 +4651,14 @@ START_TEST(input)
return
;
return
;
}
}
if
(
argc
>=
4
&&
strcmp
(
argv
[
2
],
"EnableMouseInPointer"
)
==
0
)
{
winetest_push_context
(
"enable %s"
,
argv
[
3
]
);
test_EnableMouseInPointer_process
(
argv
[
3
]
);
winetest_pop_context
();
return
;
}
test_SendInput
();
test_SendInput
();
test_Input_blackbox
();
test_Input_blackbox
();
test_Input_whitebox
();
test_Input_whitebox
();
...
@@ -4657,4 +4704,12 @@ START_TEST(input)
...
@@ -4657,4 +4704,12 @@ START_TEST(input)
win_skip
(
"GetPointerType is not available
\n
"
);
win_skip
(
"GetPointerType is not available
\n
"
);
test_UnregisterDeviceNotification
();
test_UnregisterDeviceNotification
();
if
(
!
pEnableMouseInPointer
)
win_skip
(
"EnableMouseInPointer not found, skipping tests
\n
"
);
else
{
test_EnableMouseInPointer
(
argv
,
FALSE
);
test_EnableMouseInPointer
(
argv
,
TRUE
);
}
}
}
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