UnitTests: fix VertexLoaderTest

This commit is contained in:
degasus 2014-11-29 13:02:48 +01:00
parent 3fc7e55cc4
commit e88e63adb3
1 changed files with 25 additions and 9 deletions

View File

@ -74,12 +74,14 @@ protected:
void ResetPointers() void ResetPointers()
{ {
g_video_buffer_read_ptr = &input_memory[0];
VertexManager::s_pCurBufferPointer = &output_memory[0];
m_input_pos = m_output_pos = 0; m_input_pos = m_output_pos = 0;
src = DataReader(input_memory, input_memory+sizeof(input_memory));
dst = DataReader(output_memory, output_memory+sizeof(output_memory));
} }
u32 m_input_pos, m_output_pos; u32 m_input_pos, m_output_pos;
DataReader src;
DataReader dst;
TVtxDesc m_vtx_desc; TVtxDesc m_vtx_desc;
VAT m_vtx_attr; VAT m_vtx_attr;
@ -103,7 +105,9 @@ TEST_F(VertexLoaderTest, PositionDirectFloatXYZ)
Input(0.0f); Input(0.0f); Input(1.0f); Input(0.0f); Input(0.0f); Input(1.0f);
// Convert 4 points. "7" -> primitive are points. // Convert 4 points. "7" -> primitive are points.
loader.RunVertices(m_vtx_attr, 7, 4); int count = loader.RunVertices(m_vtx_attr, 7, 4, src, dst);
src.Skip(4 * loader.GetVertexSize());
dst.Skip(count * loader.GetNativeVertexDeclaration().stride);
ExpectOut(0.0f); ExpectOut(0.0f); ExpectOut(0.0f); ExpectOut(0.0f); ExpectOut(0.0f); ExpectOut(0.0f);
ExpectOut(1.0f); ExpectOut(0.0f); ExpectOut(0.0f); ExpectOut(1.0f); ExpectOut(0.0f); ExpectOut(0.0f);
@ -113,7 +117,9 @@ TEST_F(VertexLoaderTest, PositionDirectFloatXYZ)
// Test that scale does nothing for floating point inputs. // Test that scale does nothing for floating point inputs.
Input(1.0f); Input(2.0f); Input(4.0f); Input(1.0f); Input(2.0f); Input(4.0f);
m_vtx_attr.g0.PosFrac = 1; m_vtx_attr.g0.PosFrac = 1;
loader.RunVertices(m_vtx_attr, 7, 1); count = loader.RunVertices(m_vtx_attr, 7, 1, src, dst);
src.Skip(1 * loader.GetVertexSize());
dst.Skip(count * loader.GetNativeVertexDeclaration().stride);
ExpectOut(1.0f); ExpectOut(2.0f); ExpectOut(4.0f); ExpectOut(1.0f); ExpectOut(2.0f); ExpectOut(4.0f);
} }
@ -136,7 +142,9 @@ TEST_F(VertexLoaderTest, PositionDirectU16XY)
Input<u16>(12345); Input<u16>(54321); Input<u16>(12345); Input<u16>(54321);
// Convert 5 points. "7" -> primitive are points. // Convert 5 points. "7" -> primitive are points.
loader.RunVertices(m_vtx_attr, 7, 5); int count = loader.RunVertices(m_vtx_attr, 7, 5, src, dst);
src.Skip(5 * loader.GetVertexSize());
dst.Skip(count * loader.GetNativeVertexDeclaration().stride);
ExpectOut(0.0f); ExpectOut(0.0f); ExpectOut(0.0f); ExpectOut(0.0f); ExpectOut(0.0f); ExpectOut(0.0f);
ExpectOut(1.0f); ExpectOut(2.0f); ExpectOut(0.0f); ExpectOut(1.0f); ExpectOut(2.0f); ExpectOut(0.0f);
@ -147,7 +155,9 @@ TEST_F(VertexLoaderTest, PositionDirectU16XY)
// Test that scale works on U16 inputs. // Test that scale works on U16 inputs.
Input<u16>(42); Input<u16>(24); Input<u16>(42); Input<u16>(24);
m_vtx_attr.g0.PosFrac = 1; m_vtx_attr.g0.PosFrac = 1;
loader.RunVertices(m_vtx_attr, 7, 1); count = loader.RunVertices(m_vtx_attr, 7, 1, src, dst);
src.Skip(1 * loader.GetVertexSize());
dst.Skip(count * loader.GetNativeVertexDeclaration().stride);
ExpectOut(21.0f); ExpectOut(12.0f); ExpectOut(0.0f); ExpectOut(21.0f); ExpectOut(12.0f); ExpectOut(0.0f);
} }
@ -165,7 +175,9 @@ TEST_F(VertexLoaderTest, PositionDirectFloatXYZSpeed)
for (int i = 0; i < 1000; ++i) for (int i = 0; i < 1000; ++i)
{ {
ResetPointers(); ResetPointers();
loader.RunVertices(m_vtx_attr, 7, 100000); int count = loader.RunVertices(m_vtx_attr, 7, 100000, src, dst);
src.Skip(100000 * loader.GetVertexSize());
dst.Skip(count * loader.GetNativeVertexDeclaration().stride);
} }
} }
@ -183,7 +195,9 @@ TEST_F(VertexLoaderTest, PositionDirectU16XYSpeed)
for (int i = 0; i < 1000; ++i) for (int i = 0; i < 1000; ++i)
{ {
ResetPointers(); ResetPointers();
loader.RunVertices(m_vtx_attr, 7, 100000); int count = loader.RunVertices(m_vtx_attr, 7, 100000, src, dst);
src.Skip(100000 * loader.GetVertexSize());
dst.Skip(count * loader.GetNativeVertexDeclaration().stride);
} }
} }
@ -244,6 +258,8 @@ TEST_F(VertexLoaderTest, LargeFloatVertexSpeed)
for (int i = 0; i < 100; ++i) for (int i = 0; i < 100; ++i)
{ {
ResetPointers(); ResetPointers();
loader.RunVertices(m_vtx_attr, 7, 100000); int count = loader.RunVertices(m_vtx_attr, 7, 100000, src, dst);
src.Skip(100000 * loader.GetVertexSize());
dst.Skip(count * loader.GetNativeVertexDeclaration().stride);
} }
} }