UnitTests: Add tests for assembling DSP code to expected binary

We already have the data for this, so this seems like a useful thing to do.  However, neither of the new tests currently pass...
This commit is contained in:
Pokechu22 2022-06-13 19:52:40 -07:00
parent 41939eeaf9
commit d52528a6f0
1 changed files with 33 additions and 0 deletions

View File

@ -90,6 +90,29 @@ static bool SuperTrip(const char* asm_code)
return true; return true;
} }
// Assembles asm_code, and verifies that it matches code1.
static bool AssembleAndCompare(const char* asm_code, const std::vector<u16>& code1)
{
std::vector<u16> code2;
if (!DSP::Assemble(asm_code, code2))
{
fmt::print("AssembleAndCompare: Assembly failed\n");
return false;
}
fmt::print("AssembleAndCompare: Produced {} words; padding to {} words\n", code2.size(),
code1.size());
while (code2.size() < code1.size())
code2.push_back(0);
if (!DSP::Compare(code1, code2))
{
fmt::print("AssembleAndCompare: Assembled code does not match expected code\n");
return false;
}
return true;
}
// Let's start out easy - a trivial instruction.. // Let's start out easy - a trivial instruction..
TEST(DSPAssembly, TrivialInstruction) TEST(DSPAssembly, TrivialInstruction)
{ {
@ -148,6 +171,11 @@ TEST(DSPAssembly, HermesBinary)
ASSERT_TRUE(RoundTrip(s_hermes_bin)); ASSERT_TRUE(RoundTrip(s_hermes_bin));
} }
TEST(DSPAssembly, HermesAssemble)
{
ASSERT_TRUE(AssembleAndCompare(s_hermes_text, s_hermes_bin));
}
TEST(DSPAssembly, DSPTestText) TEST(DSPAssembly, DSPTestText)
{ {
ASSERT_TRUE(SuperTrip(s_dsp_test_text)); ASSERT_TRUE(SuperTrip(s_dsp_test_text));
@ -157,3 +185,8 @@ TEST(DSPAssembly, DSPTestBinary)
{ {
ASSERT_TRUE(RoundTrip(s_dsp_test_bin)); ASSERT_TRUE(RoundTrip(s_dsp_test_bin));
} }
TEST(DSPAssembly, DSPTestAssemble)
{
ASSERT_TRUE(AssembleAndCompare(s_dsp_test_text, s_dsp_test_bin));
}