[PATCH 06/11] dxgi/tests: Add test for IDXGISwapChain_GetContainingOutput().
Józef Kucia
jkucia at codeweavers.com
Tue Apr 12 05:29:41 CDT 2016
Signed-off-by: Józef Kucia <jkucia at codeweavers.com>
---
dlls/dxgi/tests/device.c | 115 +++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 115 insertions(+)
diff --git a/dlls/dxgi/tests/device.c b/dlls/dxgi/tests/device.c
index 837618a..d8b1dd6 100644
--- a/dlls/dxgi/tests/device.c
+++ b/dlls/dxgi/tests/device.c
@@ -560,6 +560,120 @@ static void test_create_swapchain(void)
DestroyWindow(creation_desc.OutputWindow);
}
+static void test_get_containing_output(void)
+{
+ DXGI_OUTPUT_DESC output_desc, output_desc2;
+ DXGI_SWAP_CHAIN_DESC swapchain_desc;
+ IDXGIOutput *output, *output2;
+ unsigned int output_count;
+ IDXGISwapChain *swapchain;
+ IDXGIFactory *factory;
+ IDXGIAdapter *adapter;
+ IDXGIDevice *device;
+ ULONG refcount;
+ HRESULT hr;
+
+ if (!(device = create_device()))
+ {
+ skip("Failed to create device.\n");
+ return;
+ }
+
+ hr = IDXGIDevice_GetAdapter(device, &adapter);
+ ok(SUCCEEDED(hr), "GetAdapter failed, hr %#x.\n", hr);
+
+ hr = IDXGIAdapter_GetParent(adapter, &IID_IDXGIFactory, (void **)&factory);
+ ok(SUCCEEDED(hr), "GetParent failed, hr %#x.\n", hr);
+
+ swapchain_desc.BufferDesc.Width = 800;
+ swapchain_desc.BufferDesc.Height = 600;
+ swapchain_desc.BufferDesc.RefreshRate.Numerator = 60;
+ swapchain_desc.BufferDesc.RefreshRate.Denominator = 60;
+ swapchain_desc.BufferDesc.Format = DXGI_FORMAT_R8G8B8A8_UNORM;
+ swapchain_desc.BufferDesc.ScanlineOrdering = DXGI_MODE_SCANLINE_ORDER_UNSPECIFIED;
+ swapchain_desc.BufferDesc.Scaling = DXGI_MODE_SCALING_UNSPECIFIED;
+ swapchain_desc.SampleDesc.Count = 1;
+ swapchain_desc.SampleDesc.Quality = 0;
+ swapchain_desc.BufferUsage = DXGI_USAGE_RENDER_TARGET_OUTPUT;
+ swapchain_desc.BufferCount = 1;
+ swapchain_desc.OutputWindow = CreateWindowA("static", "dxgi_test", 0, 0, 0, 0, 0, 0, 0, 0, 0);
+ swapchain_desc.Windowed = TRUE;
+ swapchain_desc.SwapEffect = DXGI_SWAP_EFFECT_DISCARD;
+ swapchain_desc.Flags = 0;
+
+ output_count = 0;
+ while (IDXGIAdapter_EnumOutputs(adapter, output_count, &output) != DXGI_ERROR_NOT_FOUND)
+ {
+ ok(SUCCEEDED(hr), "Failed to enumarate output %u, hr %#x.\n", output_count, hr);
+ IDXGIOutput_Release(output);
+ ++output_count;
+ }
+
+ if (output_count != 1)
+ {
+ skip("Adapter has %u outputs.\n", output_count);
+ goto done;
+ }
+
+ hr = IDXGIAdapter_EnumOutputs(adapter, 0, &output);
+ ok(SUCCEEDED(hr), "EnumOutputs failed, hr %#x.\n", hr);
+
+ refcount = get_refcount((IUnknown *)output);
+ todo_wine ok(refcount == 1, "Got unexpected refcount %u.\n", refcount);
+
+ hr = IDXGIFactory_CreateSwapChain(factory, (IUnknown *)device, &swapchain_desc, &swapchain);
+ ok(SUCCEEDED(hr), "CreateSwapChain failed, hr %#x.\n", hr);
+
+ hr = IDXGISwapChain_GetContainingOutput(swapchain, &output2);
+ ok(SUCCEEDED(hr) || broken(hr == DXGI_ERROR_UNSUPPORTED) /* Win 7 testbot */,
+ "GetContainingOutput failed, hr %#x.\n", hr);
+ if (hr == DXGI_ERROR_UNSUPPORTED)
+ {
+ IDXGISwapChain_Release(swapchain);
+ IDXGIOutput_Release(output);
+ goto done;
+ }
+
+ refcount = get_refcount((IUnknown *)output);
+ todo_wine ok(refcount == 1, "Got unexpected refcount %u.\n", refcount);
+ refcount = get_refcount((IUnknown *)output2);
+ todo_wine ok(refcount == 1, "Got unexpected refcount %u.\n", refcount);
+
+ hr = IDXGIOutput_GetDesc(output, &output_desc);
+ ok(SUCCEEDED(hr), "GetDesc failed, hr %#x.\n", hr);
+ hr = IDXGIOutput_GetDesc(output2, &output_desc2);
+ ok(SUCCEEDED(hr), "GetDesc failed, hr %#x.\n", hr);
+
+ ok(!lstrcmpW(output_desc.DeviceName, output_desc2.DeviceName),
+ "Got unexpected device name %s, expected %s.\n",
+ wine_dbgstr_w(output_desc.DeviceName), wine_dbgstr_w(output_desc2.DeviceName));
+ ok(!memcmp(&output_desc.DesktopCoordinates, &output_desc2.DesktopCoordinates,
+ sizeof(output_desc.DesktopCoordinates)),
+ "Got unexpected desktop coordinates {%d, %d, %d, %d}, expected {%d, %d, %d, %d}.\n",
+ output_desc.DesktopCoordinates.left, output_desc.DesktopCoordinates.top,
+ output_desc.DesktopCoordinates.right, output_desc.DesktopCoordinates.bottom,
+ output_desc2.DesktopCoordinates.left, output_desc2.DesktopCoordinates.top,
+ output_desc2.DesktopCoordinates.right, output_desc2.DesktopCoordinates.bottom);
+
+ refcount = IDXGIOutput_Release(output2);
+ todo_wine ok(!refcount, "IDXGIOuput has %u references left.\n", refcount);
+
+ refcount = IDXGISwapChain_Release(swapchain);
+ ok(!refcount, "IDXGISwapChain has %u references left.\n", refcount);
+
+ refcount = IDXGIOutput_Release(output);
+ todo_wine ok(!refcount, "IDXGIOuput has %u references left.\n", refcount);
+
+done:
+ refcount = IDXGIDevice_Release(device);
+ ok(!refcount, "Device has %u references left.\n", refcount);
+ refcount = IDXGIAdapter_Release(adapter);
+ todo_wine ok(!refcount, "Adapter has %u references left.\n", refcount);
+ refcount = IDXGIFactory_Release(factory);
+ ok(!refcount, "Factory has %u references left.\n", refcount);
+ DestroyWindow(swapchain_desc.OutputWindow);
+}
+
static void test_create_factory(void)
{
IDXGIFactory1 *factory;
@@ -1412,6 +1526,7 @@ START_TEST(device)
test_parents();
test_output();
test_create_swapchain();
+ test_get_containing_output();
test_create_factory();
test_private_data();
test_swapchain_resize();
--
2.4.10
More information about the wine-patches
mailing list