dplayx/tests: Add DirectPlayEnumerate[A|W] tests
Bruno Jesus
00cpxxx at gmail.com
Tue Jan 13 20:41:15 CST 2015
Required for bug https://bugs.winehq.org/show_bug.cgi?id=37185
Manually tested in NT4 and 98.
Windows 8 fails and I believe it's in a dialog box asking to install
direct play, the same issue already found by Alistair Leslie-Hughes
and that he is trying to fix. As soon as he fixes it in dpnet we will
be able to copy over dplayx too.
-------------- next part --------------
diff --git a/dlls/dplayx/tests/dplayx.c b/dlls/dplayx/tests/dplayx.c
index fb6646d..3d1cb09 100644
--- a/dlls/dplayx/tests/dplayx.c
+++ b/dlls/dplayx/tests/dplayx.c
@@ -72,6 +72,13 @@ typedef struct tagCallbackData
UINT dpidSize;
} CallbackData, *lpCallbackData;
+struct provider_data
+{
+ int call_count;
+ GUID *guid_ptr[10];
+ GUID guid_data[10];
+ BOOL ret_value;
+};
static LPSTR get_temp_buffer(void)
{
@@ -749,6 +756,116 @@ static void test_DirectPlayCreate(void)
}
+static BOOL CALLBACK callback_providersA(GUID* guid, char *name, DWORD major, DWORD minor, void *arg)
+{
+ struct provider_data *prov = arg;
+
+ if (!prov) return TRUE;
+
+ if (prov->call_count < sizeof(prov->guid_data) / sizeof(prov->guid_data[0]))
+ {
+ prov->guid_ptr[prov->call_count] = guid;
+ prov->guid_data[prov->call_count] = *guid;
+
+ prov->call_count++;
+ }
+
+ if (prov->ret_value) /* Only trace when looping all providers */
+ trace("Provider #%d '%s' (%d.%d)\n", prov->call_count, name, major, minor);
+ return prov->ret_value;
+}
+
+static BOOL CALLBACK callback_providersW(GUID* guid, WCHAR *name, DWORD major, DWORD minor, void *arg)
+{
+ struct provider_data *prov = arg;
+
+ if (!prov) return TRUE;
+
+ if (prov->call_count < sizeof(prov->guid_data) / sizeof(prov->guid_data[0]))
+ {
+ prov->guid_ptr[prov->call_count] = guid;
+ prov->guid_data[prov->call_count] = *guid;
+
+ prov->call_count++;
+ }
+
+ return prov->ret_value;
+}
+
+static void test_EnumerateProviders(void)
+{
+ HRESULT hr;
+ int i;
+ struct provider_data arg;
+
+ memset(&arg, 0, sizeof(arg));
+ arg.ret_value = TRUE;
+
+ hr = DirectPlayEnumerateA(callback_providersA, NULL);
+ ok(SUCCEEDED(hr), "DirectPlayEnumerateA failed\n");
+
+ SetLastError(0xdeadbeef);
+ hr = DirectPlayEnumerateA(NULL, &arg);
+ ok(FAILED(hr), "DirectPlayEnumerateA expected to fail\n");
+ ok(GetLastError() == 0xdeadbeef, "Expected 0xdeadbeef, got 0x%x\n", GetLastError());
+
+ SetLastError(0xdeadbeef);
+ hr = DirectPlayEnumerateA(NULL, NULL);
+ ok(FAILED(hr), "DirectPlayEnumerateA expected to fail\n");
+ ok(GetLastError() == 0xdeadbeef, "Expected 0xdeadbeef, got 0x%x\n", GetLastError());
+
+ hr = DirectPlayEnumerateA(callback_providersA, &arg);
+ ok(SUCCEEDED(hr), "DirectPlayEnumerateA failed\n");
+ ok(arg.call_count > 0, "Expected at least one valid provider\n");
+ trace("Found %d providers\n", arg.call_count);
+
+ /* The returned GUID values must have persisted after enumeration (bug 37185) */
+ for(i = 0; i < arg.call_count; i++)
+ {
+ todo_wine
+ ok(IsEqualGUID(arg.guid_ptr[i], &arg.guid_data[i]), "Expected equal GUID values\n");
+ }
+
+ memset(&arg, 0, sizeof(arg));
+ arg.ret_value = FALSE;
+ hr = DirectPlayEnumerateA(callback_providersA, &arg);
+ ok(SUCCEEDED(hr), "DirectPlayEnumerateA failed\n");
+ ok(arg.call_count == 1, "Expected 1, got %d\n", arg.call_count);
+
+ hr = DirectPlayEnumerateW(callback_providersW, NULL);
+ ok(SUCCEEDED(hr), "DirectPlayEnumerateW failed\n");
+
+ SetLastError(0xdeadbeef);
+ hr = DirectPlayEnumerateW(NULL, &arg);
+ ok(FAILED(hr), "DirectPlayEnumerateW expected to fail\n");
+ ok(GetLastError() == 0xdeadbeef, "Expected 0xdeadbeef, got 0x%x\n", GetLastError());
+
+ SetLastError(0xdeadbeef);
+ hr = DirectPlayEnumerateW(NULL, NULL);
+ ok(FAILED(hr), "DirectPlayEnumerateW expected to fail\n");
+ ok(GetLastError() == 0xdeadbeef, "Expected 0xdeadbeef, got 0x%x\n", GetLastError());
+
+ memset(&arg, 0, sizeof(arg));
+ arg.ret_value = TRUE;
+ hr = DirectPlayEnumerateW(callback_providersW, &arg);
+ ok(SUCCEEDED(hr), "DirectPlayEnumerateW failed\n");
+ ok(arg.call_count > 0, "Expected at least one valid provider\n");
+
+ /* The returned GUID values must have persisted after enumeration (bug 37185) */
+ for(i = 0; i < arg.call_count; i++)
+ {
+ todo_wine
+ ok(IsEqualGUID(arg.guid_ptr[i], &arg.guid_data[i]), "Expected equal GUID values\n");
+ }
+
+ memset(&arg, 0, sizeof(arg));
+ arg.ret_value = FALSE;
+ hr = DirectPlayEnumerateW(callback_providersW, &arg);
+ ok(SUCCEEDED(hr), "DirectPlayEnumerateW failed\n");
+ ok(arg.call_count == 1, "Expected 1, got %d\n", arg.call_count);
+
+}
+
/* EnumConnections */
static BOOL CALLBACK EnumAddress_cb2( REFGUID guidDataType,
@@ -6544,6 +6661,7 @@ START_TEST(dplayx)
test_COM();
test_COM_dplobby();
+ test_EnumerateProviders();
if (!winetest_interactive)
{
More information about the wine-patches
mailing list