[PATCH 1/4] d3dx9/tests: Add test for GetPassDesc() function.

Paul Gofman gofmanp at gmail.com
Wed May 3 17:04:22 CDT 2017


Signed-off-by: Paul Gofman <gofmanp at gmail.com>
---
 dlls/d3dx9_36/tests/effect.c | 83 ++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 83 insertions(+)

diff --git a/dlls/d3dx9_36/tests/effect.c b/dlls/d3dx9_36/tests/effect.c
index 4dc62ec..6d3d237 100644
--- a/dlls/d3dx9_36/tests/effect.c
+++ b/dlls/d3dx9_36/tests/effect.c
@@ -6213,6 +6213,88 @@ static void test_effect_large_address_aware_flag(IDirect3DDevice9 *device)
     effect->lpVtbl->Release(effect);
 }
 
+static void test_effect_get_pass_desc(IDirect3DDevice9 *device)
+{
+    unsigned int passes_count;
+    ID3DXEffect *effect;
+    D3DXPASS_DESC desc;
+    D3DXVECTOR4 fvect;
+    D3DXHANDLE pass;
+    HRESULT hr;
+
+    hr = D3DXCreateEffect(device, test_effect_preshader_effect_blob, sizeof(test_effect_preshader_effect_blob),
+            NULL, NULL, 0, NULL, &effect, NULL);
+    ok(hr == D3D_OK, "Got result %#x.\n", hr);
+
+    pass = effect->lpVtbl->GetPass(effect, "tech0", 1);
+    ok(!!pass, "GetPass() failed.\n", hr);
+
+    hr = effect->lpVtbl->GetPassDesc(effect, pass, &desc);
+    ok(hr == D3D_OK, "Got result %#x.\n", hr);
+    test_effect_preshader_compare_shader_bytecode(desc.pVertexShaderFunction, 0, 2, TRUE);
+
+    fvect.x = fvect.y = fvect.w = 0.0f;
+    fvect.z = 0.0f;
+    hr = effect->lpVtbl->SetVector(effect, "g_iVect", &fvect);
+    ok(hr == D3D_OK, "Got result %#x.\n", hr);
+
+    hr = effect->lpVtbl->GetPassDesc(effect, pass, &desc);
+    ok(hr == D3D_OK, "Got result %#x.\n", hr);
+    ok(!desc.pPixelShaderFunction, "Unexpected non null desc.pPixelShaderFunction.\n");
+
+    test_effect_preshader_compare_shader_bytecode(desc.pVertexShaderFunction, 0, 0, TRUE);
+
+    fvect.z = 3.0f;
+    hr = effect->lpVtbl->SetVector(effect, "g_iVect", &fvect);
+    ok(hr == D3D_OK, "Got result %#x.\n", hr);
+
+    hr = effect->lpVtbl->GetPassDesc(effect, pass, &desc);
+    todo_wine
+    ok(hr == E_FAIL, "Got result %#x.\n", hr);
+    ok(!desc.pVertexShaderFunction, "Unexpected non null desc.pVertexShaderFunction.\n");
+
+    /* Repeating call to confirm GetPassDesc() returns same error on the second call,
+     * as it is not the case sometimes for BeginPass() with out of bound access. */
+    hr = effect->lpVtbl->GetPassDesc(effect, pass, &desc);
+    todo_wine
+    ok(hr == E_FAIL, "Got result %#x.\n", hr);
+    ok(!desc.pVertexShaderFunction, "Unexpected non null desc.pVertexShaderFunction.\n");
+
+    hr = effect->lpVtbl->Begin(effect, &passes_count, 0);
+    ok(hr == D3D_OK, "Got result %#x.\n", hr);
+
+    hr = effect->lpVtbl->BeginPass(effect, 1);
+    ok(hr == D3D_OK, "Got result %#x.\n", hr);
+
+    hr = effect->lpVtbl->GetPassDesc(effect, pass, &desc);
+    ok(hr == D3D_OK, "Got result %#x.\n", hr);
+
+    test_effect_preshader_compare_shader_bytecode(desc.pVertexShaderFunction, 0, 0, TRUE);
+
+    fvect.z = 2.0f;
+    hr = effect->lpVtbl->SetVector(effect, "g_iVect", &fvect);
+    hr = effect->lpVtbl->GetPassDesc(effect, pass, &desc);
+    ok(hr == D3D_OK, "Got result %#x.\n", hr);
+    test_effect_preshader_compare_shader_bytecode(desc.pVertexShaderFunction, 0, 2, TRUE);
+
+    effect->lpVtbl->Release(effect);
+
+    hr = D3DXCreateEffect(device, test_effect_preshader_effect_blob, sizeof(test_effect_preshader_effect_blob),
+            NULL, NULL, D3DXFX_NOT_CLONEABLE, NULL, &effect, NULL);
+    ok(hr == D3D_OK, "Got result %#x.\n", hr);
+
+    pass = effect->lpVtbl->GetPass(effect, "tech0", 1);
+    ok(!!pass, "GetPass() failed.\n", hr);
+
+    hr = effect->lpVtbl->GetPassDesc(effect, pass, &desc);
+    ok(hr == D3D_OK, "Got result %#x.\n", hr);
+
+    ok(!desc.pVertexShaderFunction, "Unexpected non null desc.pVertexShaderFunction.\n");
+    ok(!desc.pPixelShaderFunction, "Unexpected non null desc.pPixelShaderFunction.\n");
+
+    effect->lpVtbl->Release(effect);
+}
+
 START_TEST(effect)
 {
     HWND wnd;
@@ -6263,6 +6345,7 @@ START_TEST(effect)
     test_cross_effect_handle(device);
     test_effect_shared_parameters(device);
     test_effect_large_address_aware_flag(device);
+    test_effect_get_pass_desc(device);
 
     count = IDirect3DDevice9_Release(device);
     ok(count == 0, "The device was not properly freed: refcount %u\n", count);
-- 
2.9.3




More information about the wine-patches mailing list