=?UTF-8?Q?Rico=20Sch=C3=BCller=20?=: d3dx9/tests: Add effect parameter value SetInt() test.

Alexandre Julliard julliard at winehq.org
Tue Jan 24 14:25:29 CST 2012


Module: wine
Branch: master
Commit: 51b96991348018cfd4df774a0b45c7e9820019db
URL:    http://source.winehq.org/git/wine.git/?a=commit;h=51b96991348018cfd4df774a0b45c7e9820019db

Author: Rico Schüller <kgbricola at web.de>
Date:   Tue Jan 24 09:48:41 2012 +0100

d3dx9/tests: Add effect parameter value SetInt() test.

---

 dlls/d3dx9_36/tests/effect.c |   35 +++++++++++++++++++++++++++++++++++
 1 files changed, 35 insertions(+), 0 deletions(-)

diff --git a/dlls/d3dx9_36/tests/effect.c b/dlls/d3dx9_36/tests/effect.c
index ed08485..3af1d14 100644
--- a/dlls/d3dx9_36/tests/effect.c
+++ b/dlls/d3dx9_36/tests/effect.c
@@ -888,6 +888,7 @@ test_effect_parameter_value_data[] =
 #define EFFECT_PARAMETER_VALUE_ARRAY_SIZE 48
 /* Constants for special INT/FLOAT conversation */
 #define INT_FLOAT_MULTI 255.0f
+#define INT_FLOAT_MULTI_INVERSE (1/INT_FLOAT_MULTI)
 
 static void test_effect_parameter_value_GetValue(const struct test_effect_parameter_value_result *res,
         ID3DXEffect *effect, const DWORD *res_value, D3DXHANDLE parameter, UINT i)
@@ -1635,6 +1636,7 @@ static void test_effect_parameter_value(IDirect3DDevice9 *device)
             D3DXHANDLE parameter;
             D3DXPARAMETER_DESC pdesc;
             BOOL bvalue;
+            INT ivalue;
             DWORD input_value[EFFECT_PARAMETER_VALUE_ARRAY_SIZE];
             DWORD expected_value[EFFECT_PARAMETER_VALUE_ARRAY_SIZE];
             UINT l;
@@ -1721,6 +1723,39 @@ static void test_effect_parameter_value(IDirect3DDevice9 *device)
             }
             test_effect_parameter_value_GetTestGroup(&res[k], effect, expected_value, parameter, i);
             test_effect_parameter_value_ResetValue(&res[k], effect, &blob[res_value_offset], parameter, i);
+
+            /* SetInt */
+            ivalue = 0x1fbf02ff;
+            memcpy(expected_value, &blob[res_value_offset], res_desc->Bytes);
+            hr = effect->lpVtbl->SetInt(effect, parameter, ivalue);
+            if (!res_desc->Elements && res_desc->Rows == 1 && res_desc->Columns == 1)
+            {
+                set_number(expected_value, res_desc->Type, &ivalue, D3DXPT_INT);
+                ok(hr == D3D_OK, "%u - %s: SetInt failed, got %#x, expected %#x\n", i, res_full_name, hr, D3D_OK);
+            }
+            else if(!res_desc->Elements && res_desc->Type == D3DXPT_FLOAT &&
+                    ((res_desc->Class == D3DXPC_VECTOR && res_desc->Columns != 2) ||
+                    (res_desc->Class == D3DXPC_MATRIX_ROWS && res_desc->Rows != 2 && res_desc->Columns == 1)))
+            {
+                FLOAT tmp = ((ivalue & 0xff0000) >> 16) * INT_FLOAT_MULTI_INVERSE;
+                set_number(expected_value, res_desc->Type, &tmp, D3DXPT_FLOAT);
+                tmp = ((ivalue & 0xff00) >> 8) * INT_FLOAT_MULTI_INVERSE;
+                set_number(expected_value + 1, res_desc->Type, &tmp, D3DXPT_FLOAT);
+                tmp = (ivalue & 0xff) * INT_FLOAT_MULTI_INVERSE;
+                set_number(expected_value + 2, res_desc->Type, &tmp, D3DXPT_FLOAT);
+                tmp = ((ivalue & 0xff000000) >> 24) * INT_FLOAT_MULTI_INVERSE;
+                set_number(expected_value + 3, res_desc->Type, &tmp, D3DXPT_FLOAT);
+
+                ok(hr == D3D_OK, "%u - %s: SetInt failed, got %#x, expected %#x\n",
+                        i, res_full_name, hr, D3D_OK);
+            }
+            else
+            {
+                ok(hr == D3DERR_INVALIDCALL, "%u - %s: SetInt failed, got %#x, expected %#x\n",
+                        i, res_full_name, hr, D3DERR_INVALIDCALL);
+            }
+            test_effect_parameter_value_GetTestGroup(&res[k], effect, expected_value, parameter, i);
+            test_effect_parameter_value_ResetValue(&res[k], effect, &blob[res_value_offset], parameter, i);
         }
 
         count = effect->lpVtbl->Release(effect);




More information about the wine-cvs mailing list