Commit bed1ecba authored by Rémi Bernon's avatar Rémi Bernon Committed by Alexandre Julliard

dinput/tests: Add some tests with keyboard action mapping.

parent a8c56b19
...@@ -34,6 +34,10 @@ ...@@ -34,6 +34,10 @@
#include "dinput_test.h" #include "dinput_test.h"
#include "initguid.h"
DEFINE_GUID(GUID_keyboard_action_mapping,0x00000001,0x0002,0x0003,0x04,0x05,0x06,0x07,0x08,0x09,0x0a,0x0b);
struct enum_data struct enum_data
{ {
DWORD version; DWORD version;
...@@ -1712,6 +1716,60 @@ static void test_dik_codes( IDirectInputDevice8W *device, HANDLE event, HWND hwn ...@@ -1712,6 +1716,60 @@ static void test_dik_codes( IDirectInputDevice8W *device, HANDLE event, HWND hwn
ok( hr == DI_OK, "Unacquire returned %#lx\n", hr ); ok( hr == DI_OK, "Unacquire returned %#lx\n", hr );
} }
#define check_member_str_( file, line, val, exp, member ) \
ok_(file, line)( !strcmp( (val).member, (exp).member ), "got " #member " %s\n", \
debugstr_a((val).member) )
#define check_member_str( val, exp, member ) \
check_member_str_( __FILE__, __LINE__, val, exp, member )
#define check_diactionA( a, b ) check_diactionA_( __LINE__, a, b )
static void check_diactionA_( int line, const DIACTIONA *actual, const DIACTIONA *expected )
{
check_member_( __FILE__, line, *actual, *expected, "%#Ix", uAppData );
check_member_( __FILE__, line, *actual, *expected, "%#lx", dwSemantic );
todo_wine_if( expected->dwSemantic == 0x810004c8 )
check_member_( __FILE__, line, *actual, *expected, "%#lx", dwFlags );
if (actual->lptszActionName && expected->lptszActionName)
check_member_str_( __FILE__, line, *actual, *expected, lptszActionName );
else
check_member_( __FILE__, line, *actual, *expected, "%p", lptszActionName );
todo_wine_if( expected->dwSemantic == 0x810004c8 )
check_member_guid_( __FILE__, line, *actual, *expected, guidInstance );
todo_wine_if( expected->dwSemantic == 0x810004c8 )
check_member_( __FILE__, line, *actual, *expected, "%#lx", dwObjID );
todo_wine_if( expected->dwSemantic == 0x810004c8 )
check_member_( __FILE__, line, *actual, *expected, "%#lx", dwHow );
}
#define check_diactionformatA( a, b ) check_diactionformatA_( __LINE__, a, b )
static void check_diactionformatA_( int line, const DIACTIONFORMATA *actual, const DIACTIONFORMATA *expected )
{
DWORD i;
check_member_( __FILE__, line, *actual, *expected, "%#lx", dwSize );
check_member_( __FILE__, line, *actual, *expected, "%#lx", dwActionSize );
check_member_( __FILE__, line, *actual, *expected, "%#lx", dwDataSize );
check_member_( __FILE__, line, *actual, *expected, "%#lx", dwNumActions );
for (i = 0; i < min( actual->dwNumActions, expected->dwNumActions ); ++i)
{
winetest_push_context( "action[%lu]", i );
check_diactionA_( line, actual->rgoAction + i, expected->rgoAction + i );
winetest_pop_context();
if (expected->dwActionSize != sizeof(DIACTIONA)) break;
if (actual->dwActionSize != sizeof(DIACTIONA)) break;
}
check_member_guid_( __FILE__, line, *actual, *expected, guidActionMap );
check_member_( __FILE__, line, *actual, *expected, "%#lx", dwGenre );
check_member_( __FILE__, line, *actual, *expected, "%#lx", dwBufferSize );
check_member_( __FILE__, line, *actual, *expected, "%+ld", lAxisMin );
check_member_( __FILE__, line, *actual, *expected, "%+ld", lAxisMax );
check_member_( __FILE__, line, *actual, *expected, "%p", hInstString );
check_member_( __FILE__, line, *actual, *expected, "%ld", ftTimeStamp.dwLowDateTime );
check_member_( __FILE__, line, *actual, *expected, "%ld", ftTimeStamp.dwHighDateTime );
todo_wine
check_member_( __FILE__, line, *actual, *expected, "%#lx", dwCRC );
check_member_str_( __FILE__, line, *actual, *expected, tszActionMap );
}
static void test_sys_keyboard( DWORD version ) static void test_sys_keyboard( DWORD version )
{ {
const DIDEVCAPS expect_caps = const DIDEVCAPS expect_caps =
...@@ -2213,6 +2271,64 @@ skip_key_tests: ...@@ -2213,6 +2271,64 @@ skip_key_tests:
localized = old_localized; localized = old_localized;
} }
static void test_sys_keyboard_action_format(void)
{
DIACTIONA actions[] =
{
{.uAppData = 0x1, .dwSemantic = 0x810004c8, .dwFlags = DIA_APPNOMAP},
{.uAppData = 0x1, .dwSemantic = 0x81000448, .dwFlags = 0},
};
const DIACTIONA expect_actions[ARRAY_SIZE(actions)] =
{
{.uAppData = 0x1, .dwSemantic = 0x810004c8, .dwFlags = 0, .guidInstance = GUID_SysKeyboard, .dwObjID = 0xc804, .dwHow = DIAH_DEFAULT},
{.uAppData = 0x1, .dwSemantic = 0x81000448, .dwFlags = 0, .guidInstance = GUID_SysKeyboard, .dwObjID = 0x4804, .dwHow = DIAH_DEFAULT},
};
DIACTIONFORMATA action_format =
{
.dwSize = sizeof(DIACTIONFORMATA),
.dwActionSize = sizeof(DIACTIONA),
.dwNumActions = ARRAY_SIZE(actions),
.dwDataSize = ARRAY_SIZE(actions) * 4,
.rgoAction = actions,
.dwGenre = 0x1000000,
.guidActionMap = GUID_keyboard_action_mapping,
};
const DIACTIONFORMATA expect_action_format =
{
.dwSize = sizeof(DIACTIONFORMATA),
.dwActionSize = sizeof(DIACTIONA),
.dwNumActions = ARRAY_SIZE(expect_actions),
.dwDataSize = ARRAY_SIZE(expect_actions) * 4,
.rgoAction = (DIACTIONA *)expect_actions,
.dwGenre = 0x1000000,
.guidActionMap = GUID_keyboard_action_mapping,
.dwCRC = 0x68e7e227,
};
IDirectInputDevice8A *device;
IDirectInput8A *dinput;
HRESULT hr;
LONG ref;
hr = DirectInput8Create( instance, 0x800, &IID_IDirectInput8A, (void **)&dinput, NULL );
ok( hr == DI_OK, "CreateDevice returned %#lx\n", hr );
hr = IDirectInput_CreateDevice( dinput, &GUID_SysKeyboard, &device, NULL );
ok( hr == DI_OK, "CreateDevice returned %#lx\n", hr );
ref = IDirectInput_Release( dinput );
ok( ref == 0, "Release returned %ld\n", ref );
hr = IDirectInputDevice8_BuildActionMap( device, &action_format, NULL, 2 );
ok( hr == DI_OK, "BuildActionMap returned %#lx\n", hr );
check_diactionformatA(&action_format, &expect_action_format);
hr = IDirectInputDevice8_SetActionMap( device, &action_format, NULL, 2 );
ok( hr == DI_SETTINGSNOTSAVED, "SetActionMap returned %#lx\n", hr );
hr = IDirectInputDevice8_SetActionMap( device, &action_format, NULL, 0 );
ok( hr == DI_OK, "SetActionMap returned %#lx\n", hr );
ref = IDirectInputDevice8_Release( device );
ok( ref == 0, "Release returned %ld\n", ref );
}
START_TEST(device8) START_TEST(device8)
{ {
dinput_test_init(); dinput_test_init();
...@@ -2233,6 +2349,8 @@ START_TEST(device8) ...@@ -2233,6 +2349,8 @@ START_TEST(device8)
test_sys_keyboard( 0x700 ); test_sys_keyboard( 0x700 );
test_sys_keyboard( 0x800 ); test_sys_keyboard( 0x800 );
test_sys_keyboard_action_format();
test_mouse_keyboard(); test_mouse_keyboard();
test_keyboard_events(); test_keyboard_events();
test_appdata_property(); test_appdata_property();
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment