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

This commit is contained in:
Rico Schüller 2012-01-26 11:40:57 +01:00 committed by Alexandre Julliard
parent 52e1409111
commit 3efd2f9a1b
1 changed files with 41 additions and 0 deletions

View File

@ -1931,6 +1931,47 @@ 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);
/* SetMatrixArray */
for (element = 0; element < res_desc->Elements + 1; ++element)
{
fvalue = 1.33;
for (l = 0; l < element * 16; ++l)
{
*(input_value + l) = *(DWORD *)&fvalue;
fvalue += 1.12;
}
memcpy(expected_value, &blob[res_value_offset], res_desc->Bytes);
hr = effect->lpVtbl->SetMatrixArray(effect, parameter, (D3DXMATRIX *)input_value, element);
if (res_desc->Class == D3DXPC_MATRIX_ROWS && element <= res_desc->Elements)
{
UINT n;
for (n = 0; n < element; ++n)
{
for (l = 0; l < 4; ++l)
{
UINT m;
for (m = 0; m < 4; ++m)
{
if (m < res_desc->Rows && l < res_desc->Columns)
set_number(expected_value + l + m * res_desc->Columns + n * res_desc->Columns * res_desc->Rows,
res_desc->Type, input_value + l + m * 4 + n * 16, D3DXPT_FLOAT);
}
}
}
ok(hr == D3D_OK, "%u - %s: SetMatrixArray failed, got %#x, expected %#x\n", i, res_full_name, hr, D3D_OK);
}
else
{
ok(hr == D3DERR_INVALIDCALL, "%u - %s: SetMatrixArray 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);