[PATCH 3/8] d3d10core/tests: Add more tests for texture data initialization.

Józef Kucia jkucia at codeweavers.com
Fri Apr 8 06:26:36 CDT 2016


Signed-off-by: Józef Kucia <jkucia at codeweavers.com>
---
 dlls/d3d10core/tests/device.c | 72 ++++++++++++++++++++++++++++++++++---------
 1 file changed, 58 insertions(+), 14 deletions(-)

diff --git a/dlls/d3d10core/tests/device.c b/dlls/d3d10core/tests/device.c
index 3783da5..13df12b 100644
--- a/dlls/d3d10core/tests/device.c
+++ b/dlls/d3d10core/tests/device.c
@@ -5330,12 +5330,12 @@ static void test_copy_subresource_region(void)
     release_test_context(&test_context);
 }
 
-static void test_multisample_init(void)
+static void test_texture_data_init(void)
 {
     static const float white[] = {1.0f, 1.0f, 1.0f, 1.0f};
     struct d3d10core_test_context test_context;
     D3D10_TEXTURE2D_DESC desc;
-    ID3D10Texture2D *multi;
+    ID3D10Texture2D *texture;
     ID3D10Device *device;
     UINT count = 0;
     HRESULT hr;
@@ -5345,37 +5345,81 @@ static void test_multisample_init(void)
 
     device = test_context.device;
 
+    desc.Width = 640;
+    desc.Height = 480;
+    desc.MipLevels = 1;
+    desc.ArraySize = 1;
+    desc.SampleDesc.Count = 1;
+    desc.SampleDesc.Quality = 0;
+    desc.Usage = D3D10_USAGE_DEFAULT;
+    desc.BindFlags = 0;
+    desc.CPUAccessFlags = 0;
+    desc.MiscFlags = 0;
+
+    desc.Format = DXGI_FORMAT_R8G8B8A8_UNORM;
+    hr = ID3D10Device_CreateTexture2D(device, &desc, NULL, &texture);
+    ok(SUCCEEDED(hr), "Failed to create texture, hr %#x.\n", hr);
+    check_texture_color(texture, 0x00000000, 0);
+    ID3D10Texture2D_Release(texture);
+
+    desc.Format = DXGI_FORMAT_D24_UNORM_S8_UINT;
+    hr = ID3D10Device_CreateTexture2D(device, &desc, NULL, &texture);
+    ok(SUCCEEDED(hr), "Failed to create texture, hr %#x.\n", hr);
+    check_texture_color(texture, 0x00000000, 0);
+    ID3D10Texture2D_Release(texture);
+
+    desc.Format = DXGI_FORMAT_D32_FLOAT;
+    hr = ID3D10Device_CreateTexture2D(device, &desc, NULL, &texture);
+    ok(SUCCEEDED(hr), "Failed to create texture, hr %#x.\n", hr);
+    check_texture_float(texture, 0.0f, 0);
+    ID3D10Texture2D_Release(texture);
+
+    desc.ArraySize = 4;
+
+    desc.Format = DXGI_FORMAT_R8G8B8A8_UNORM;
+    hr = ID3D10Device_CreateTexture2D(device, &desc, NULL, &texture);
+    ok(SUCCEEDED(hr), "Failed to create texture, hr %#x.\n", hr);
+    check_texture_float(texture, 0.0f, 0);
+    ID3D10Texture2D_Release(texture);
+
+    desc.Format = DXGI_FORMAT_D24_UNORM_S8_UINT;
+    hr = ID3D10Device_CreateTexture2D(device, &desc, NULL, &texture);
+    ok(SUCCEEDED(hr), "Failed to create texture, hr %#x.\n", hr);
+    check_texture_color(texture, 0x00000000, 0);
+    ID3D10Texture2D_Release(texture);
+
+    desc.Format = DXGI_FORMAT_D32_FLOAT;
+    hr = ID3D10Device_CreateTexture2D(device, &desc, NULL, &texture);
+    ok(SUCCEEDED(hr), "Failed to create texture, hr %#x.\n", hr);
+    check_texture_float(texture, 0.0f, 0);
+    ID3D10Texture2D_Release(texture);
+
     hr = ID3D10Device_CheckMultisampleQualityLevels(device, DXGI_FORMAT_R8G8B8A8_UNORM, 2, &count);
     ok(SUCCEEDED(hr), "Failed to get quality levels, hr %#x.\n", hr);
     if (!count)
     {
         skip("Multisampling not supported for DXGI_FORMAT_R8G8B8A8_UNORM, skipping tests.\n");
-        goto done;
+        release_test_context(&test_context);
+        return;
     }
 
     ID3D10Device_ClearRenderTargetView(device, test_context.backbuffer_rtv, white);
 
-    desc.Width = 640;
-    desc.Height = 480;
-    desc.MipLevels = 1;
     desc.ArraySize = 1;
     desc.Format = DXGI_FORMAT_R8G8B8A8_UNORM;
     desc.SampleDesc.Count = 2;
     desc.SampleDesc.Quality = 0;
-    desc.Usage = D3D10_USAGE_DEFAULT;
     desc.BindFlags = D3D10_BIND_RENDER_TARGET;
-    desc.CPUAccessFlags = 0;
-    desc.MiscFlags = 0;
-    hr = ID3D10Device_CreateTexture2D(device, &desc, NULL, &multi);
+    hr = ID3D10Device_CreateTexture2D(device, &desc, NULL, &texture);
     ok(SUCCEEDED(hr), "Failed to create texture, hr %#x.\n", hr);
 
     ID3D10Device_ResolveSubresource(device, (ID3D10Resource *)test_context.backbuffer, 0,
-            (ID3D10Resource *)multi, 0, DXGI_FORMAT_R8G8B8A8_UNORM);
+            (ID3D10Resource *)texture, 0, DXGI_FORMAT_R8G8B8A8_UNORM);
 
     todo_wine check_texture_color(test_context.backbuffer, 0x00000000, 0);
 
-    ID3D10Texture2D_Release(multi);
-done:
+    ID3D10Texture2D_Release(texture);
+
     release_test_context(&test_context);
 }
 
@@ -6287,7 +6331,7 @@ START_TEST(device)
     test_fragment_coords();
     test_update_subresource();
     test_copy_subresource_region();
-    test_multisample_init();
+    test_texture_data_init();
     test_check_multisample_quality_levels();
     test_cb_relative_addressing();
     test_swapchain_flip();
-- 
2.4.10




More information about the wine-patches mailing list