[PATCH 7/7] ntoskrnl.exe/tests: Add some HidP_GetData tests.
Rémi Bernon
rbernon at codeweavers.com
Fri Jun 11 05:43:59 CDT 2021
Signed-off-by: Rémi Bernon <rbernon at codeweavers.com>
---
dlls/ntoskrnl.exe/tests/ntoskrnl.c | 43 ++++++++++++++++++++++++++++++
1 file changed, 43 insertions(+)
diff --git a/dlls/ntoskrnl.exe/tests/ntoskrnl.c b/dlls/ntoskrnl.exe/tests/ntoskrnl.c
index 9b17e36c0ea..64b7205debd 100644
--- a/dlls/ntoskrnl.exe/tests/ntoskrnl.c
+++ b/dlls/ntoskrnl.exe/tests/ntoskrnl.c
@@ -1814,6 +1814,18 @@ static void test_hidp(HANDLE file, int report_id)
.CollectionType = 2,
},
};
+ static const HIDP_DATA expect_data[] =
+ {
+ { .DataIndex = 0, },
+ { .DataIndex = 1, },
+ { .DataIndex = 5, .RawValue = 1, },
+ { .DataIndex = 7, .RawValue = 1, },
+ { .DataIndex = 30, },
+ { .DataIndex = 31, },
+ { .DataIndex = 32, .RawValue = 0xfeedcafe, },
+ { .DataIndex = 37, .RawValue = 1, },
+ { .DataIndex = 39, .RawValue = 1, },
+ };
HIDP_LINK_COLLECTION_NODE collections[16];
PHIDP_PREPARSED_DATA preparsed_data;
@@ -1823,6 +1835,7 @@ static void test_hidp(HANDLE file, int report_id)
char buffer[200], report[200];
DWORD collection_count;
DWORD waveform_list;
+ HIDP_DATA data[32];
USAGE usages[16];
NTSTATUS status;
HIDP_CAPS caps;
@@ -2436,6 +2449,36 @@ static void test_hidp(HANDLE file, int report_id)
ok(usage_and_pages[3].Usage == 4, "got usage_and_pages[3] Usage %x, expected %x\n",
usage_and_pages[3].Usage, 4);
+ value = HidP_MaxDataListLength(HidP_Feature + 1, preparsed_data);
+ ok(value == 0, "HidP_MaxDataListLength(HidP_Feature + 1) returned %d, expected %d\n", value, 0);
+ value = HidP_MaxDataListLength(HidP_Input, preparsed_data);
+ todo_wine
+ ok(value == 50, "HidP_MaxDataListLength(HidP_Input) returned %d, expected %d\n", value, 50);
+ value = HidP_MaxDataListLength(HidP_Output, preparsed_data);
+ ok(value == 0, "HidP_MaxDataListLength(HidP_Output) returned %d, expected %d\n", value, 0);
+ value = HidP_MaxDataListLength(HidP_Feature, preparsed_data);
+ ok(value == 13, "HidP_MaxDataListLength(HidP_Feature) returned %d, expected %d\n", value, 13);
+
+ value = 1;
+ status = HidP_GetData(HidP_Input, data, &value, preparsed_data, report, caps.InputReportByteLength);
+ todo_wine_if(report_id)
+ ok(status == HIDP_STATUS_BUFFER_TOO_SMALL, "HidP_GetData returned %#x\n", status);
+ todo_wine
+ ok(value == 9, "got data count %d, expected %d\n", value, 9);
+ memset(data, 0, sizeof(data));
+ status = HidP_GetData(HidP_Input, data, &value, preparsed_data, report, caps.InputReportByteLength);
+ todo_wine_if(report_id)
+ ok(status == HIDP_STATUS_SUCCESS, "HidP_GetData returned %#x\n", status);
+ if (status == HIDP_STATUS_SUCCESS) for (i = 0; i < ARRAY_SIZE(expect_data); ++i)
+ {
+ winetest_push_context("data[%d]", i);
+ todo_wine_if(i >= 4)
+ check_member(data[i], expect_data[i], "%d", DataIndex);
+ todo_wine_if(i == 6 || i == 7 || i == 8)
+ check_member(data[i], expect_data[i], "%d", RawValue);
+ winetest_pop_context();
+ }
+
memset(report, 0xcd, sizeof(report));
status = HidP_InitializeReportForID(HidP_Feature, 3, preparsed_data, report, caps.FeatureReportByteLength);
todo_wine_if(!report_id)
--
2.31.0
More information about the wine-devel
mailing list