Browse Source

Test: Update CPU test for new carry logic

master
Riyyi 2 years ago
parent
commit
b63f0d3b52
  1. 34
      test/testcpu.cpp

34
test/testcpu.cpp

@ -12,7 +12,15 @@
struct CPUTest { struct CPUTest {
CPU cpu { 0 }; CPU cpu { 0 };
bool isCarry(uint32_t lhs, uint32_t rhs, uint32_t limit_bit) { return cpu.isCarry(lhs, rhs, limit_bit); } bool isCarry(uint32_t limit_bit, uint32_t first, uint32_t second, uint32_t third = 0x0)
{
return cpu.isCarry(limit_bit, first, second, third);
}
bool isCarrySubtraction(uint32_t limit_bit, uint32_t lhs, uint32_t rhs, uint32_t rhs_extra = 0x0)
{
return cpu.isCarrySubtraction(limit_bit, lhs, rhs, rhs_extra);
}
}; };
// ----------------------------------------- // -----------------------------------------
@ -23,27 +31,27 @@ TEST_CASE(CPUIsCarry)
// 8-bit Half-carry false // 8-bit Half-carry false
EXPECT_EQ(test.isCarry(56, 17, 0x10), false); EXPECT(test.isCarry(0xf, 56, 17) == false);
EXPECT_EQ(test.isCarry(16, -1, 0x10), false); EXPECT(test.isCarrySubtraction(0xf, 136, 1) == false);
EXPECT_EQ(test.isCarry(32, -1, 0x10), false); EXPECT(test.isCarrySubtraction(0xf, 219, 20) == false);
EXPECT_EQ(test.isCarry(144, -1, 0x10), false); EXPECT(test.isCarrySubtraction(0xf, 250, 20) == false);
EXPECT_EQ(test.isCarry(211, -20, 0x10), false);
// 8-bit Half-carry true // 8-bit Half-carry true
EXPECT_EQ(test.isCarry(46, 34, 0x10), true); EXPECT(test.isCarry(0xf, 46, 34) == true);
EXPECT_EQ(test.isCarry(62, 34, 0x10), true); EXPECT(test.isCarry(0xf, 62, 34) == true);
EXPECT_EQ(test.isCarry(136, -1, 0x10), true); EXPECT(test.isCarrySubtraction(0xf, 16, 1) == true);
EXPECT_EQ(test.isCarry(219, -20, 0x10), true); EXPECT(test.isCarrySubtraction(0xf, 32, 1) == true);
EXPECT_EQ(test.isCarry(250, -20, 0x10), true); EXPECT(test.isCarrySubtraction(0xf, 144, 1) == true);
EXPECT(test.isCarrySubtraction(0xf, 211, 20) == true);
// 8-bit Full carry false // 8-bit Full carry false
EXPECT_EQ(test.isCarry(254, 1, 0x100), false); EXPECT(test.isCarry(0xff, 254, 1) == false);
// 8-bit Full carry true // 8-bit Full carry true
EXPECT_EQ(test.isCarry(254, 2, 0x100), true); EXPECT(test.isCarry(0xff, 254, 2) == true);
} }

Loading…
Cancel
Save