delta tests and service
This commit is contained in:
165
test/rom_test.cc
165
test/rom_test.cc
@@ -21,7 +21,6 @@ using ::testing::TypedEq;
|
||||
namespace {
|
||||
|
||||
Bytes ExpectCompressOk(ROM& rom, uchar* in, int in_size) {
|
||||
Bytes result;
|
||||
auto load_status = rom.LoadFromPointer(in, in_size);
|
||||
EXPECT_TRUE(load_status.ok());
|
||||
auto compression_status = rom.Compress(0, in_size);
|
||||
@@ -30,6 +29,15 @@ Bytes ExpectCompressOk(ROM& rom, uchar* in, int in_size) {
|
||||
return compressed_bytes;
|
||||
}
|
||||
|
||||
Bytes ExpectDecompressBytesOk(ROM& rom, Bytes& in) {
|
||||
auto load_status = rom.LoadFromBytes(in);
|
||||
EXPECT_TRUE(load_status.ok());
|
||||
auto decompression_status = rom.Decompress(0, in.size());
|
||||
EXPECT_TRUE(decompression_status.ok());
|
||||
auto decompressed_bytes = std::move(*decompression_status);
|
||||
return decompressed_bytes;
|
||||
}
|
||||
|
||||
Bytes ExpectDecompressOk(ROM& rom, uchar* in, int in_size) {
|
||||
auto load_status = rom.LoadFromPointer(in, in_size);
|
||||
EXPECT_TRUE(load_status.ok());
|
||||
@@ -74,10 +82,9 @@ TEST(ROMTest, NewDecompressionPieceOk) {
|
||||
|
||||
TEST(ROMTest, DecompressionValidCommand) {
|
||||
ROM rom;
|
||||
std::array<uchar, 4> simple_copy_input = {BUILD_HEADER(0x00, 0x02), 0x2A,
|
||||
0x45, 0xFF};
|
||||
Bytes simple_copy_input = {BUILD_HEADER(0x00, 0x02), 0x2A, 0x45, 0xFF};
|
||||
uchar simple_copy_output[2] = {0x2A, 0x45};
|
||||
auto decomp_result = ExpectDecompressOk(rom, simple_copy_input.data(), 4);
|
||||
auto decomp_result = ExpectDecompressBytesOk(rom, simple_copy_input);
|
||||
EXPECT_THAT(simple_copy_output, ElementsAreArray(decomp_result.data(), 2));
|
||||
}
|
||||
|
||||
@@ -99,34 +106,6 @@ TEST(ROMTest, DecompressionMixingCommand) {
|
||||
EXPECT_THAT(random1_o, ElementsAreArray(decomp_result.data(), 9));
|
||||
}
|
||||
|
||||
/* Extended Header Command is currently unimplemented
|
||||
TEST(ROMTest, ExtendedHeaderDecompress) {
|
||||
ROM rom;
|
||||
uchar extendedcmd_i[4] = {0b11100100, 0x8F, 0x2A, 0xFF};
|
||||
uchar extendedcmd_o[50];
|
||||
for (int i = 0; i < 50; ++i) {
|
||||
extendedcmd_o[i] = 0x2A;
|
||||
}
|
||||
|
||||
auto decomp_result = ExpectDecompressOk(rom, extendedcmd_i, 4);
|
||||
ASSERT_THAT(extendedcmd_o, ElementsAreArray(decomp_result.data(), 50));
|
||||
}
|
||||
|
||||
TEST(ROMTest, ExtendedHeaderDecompress2) {
|
||||
ROM rom;
|
||||
uchar extendedcmd_i[4] = {0b11100101, 0x8F, 0x2A, 0xFF};
|
||||
uchar extendedcmd_o[50];
|
||||
for (int i = 0; i < 50; i++) {
|
||||
extendedcmd_o[i] = 0x2A;
|
||||
}
|
||||
|
||||
auto data = ExpectDecompressOk(rom, extendedcmd_i, 4);
|
||||
for (int i = 0; i < 50; i++) {
|
||||
ASSERT_EQ(extendedcmd_o[i], data[i]);
|
||||
}
|
||||
}
|
||||
*/
|
||||
|
||||
TEST(ROMTest, CompressionSingleSet) {
|
||||
ROM rom;
|
||||
uchar single_set[5] = {0x2A, 0x2A, 0x2A, 0x2A, 0x2A};
|
||||
@@ -162,7 +141,6 @@ TEST(ROMTest, CompressionSingleCopy) {
|
||||
EXPECT_THAT(single_copy_expected, ElementsAreArray(comp_result.data(), 6));
|
||||
}
|
||||
|
||||
/* Hiding tests until I figure out a better PR to address the bug
|
||||
TEST(ROMTest, CompressionSingleCopyRepeat) {
|
||||
ROM rom;
|
||||
uchar single_copy_repeat[8] = {0x03, 0x0A, 0x07, 0x14, 0x03, 10, 0x07, 0x14};
|
||||
@@ -171,9 +149,10 @@ TEST(ROMTest, CompressionSingleCopyRepeat) {
|
||||
BUILD_HEADER(0x04, 0x04), 0x00, 0x00, 0xFF};
|
||||
auto comp_result = ExpectCompressOk(rom, single_copy_repeat, 8);
|
||||
EXPECT_THAT(single_copy_repeat_expected,
|
||||
ElementsAreArray(comp_result.data(), 8));
|
||||
ElementsAreArray(comp_result.data(), 9));
|
||||
}
|
||||
|
||||
/* Hiding tests until I figure out a better PR to address the bug
|
||||
TEST(ROMTest, CompressionSingleOverflowIncrement) {
|
||||
ROM rom;
|
||||
uchar overflow_inc[4] = {0xFE, 0xFF, 0x00, 0x01};
|
||||
@@ -201,26 +180,14 @@ TEST(ROMTest, CompressionMixedRepeatIncrement) {
|
||||
EXPECT_THAT(repeat_and_inc_copy_expected,
|
||||
ElementsAreArray(comp_result.data(), 7));
|
||||
}
|
||||
*/
|
||||
|
||||
TEST(ROMTest, SimpleMixCompression) {
|
||||
TEST(ROMTest, CompressionMixedIncrementIntraCopyOffset) {
|
||||
ROM rom;
|
||||
uchar to_compress_string[] = {0x05, 0x05, 0x05, 0x05, 0x06, 0x07, 0x08,
|
||||
0x09, 0x0A, 0x0B, 0x05, 0x02, 0x05, 0x02,
|
||||
0x05, 0x02, 0x0A, 0x0B, 0x05, 0x02, 0x05,
|
||||
0x02, 0x05, 0x02, 0x08, 0x0A, 0x00, 0x05};
|
||||
uchar repeat_and_inc_copy_expected[] = {BUILD_HEADER(0x01, 0x04),
|
||||
0x05,
|
||||
BUILD_HEADER(0x03, 0x06),
|
||||
0x06,
|
||||
BUILD_HEADER(0x00, 0x01),
|
||||
0x05,
|
||||
0xFF};
|
||||
// Mixing, repeat, inc, trailing copy
|
||||
auto data = ExpectCompressOk(rom, to_compress_string, 7);
|
||||
for (int i = 0; i < 7; ++i) {
|
||||
EXPECT_EQ(repeat_and_inc_copy_expected[i], data[i]);
|
||||
}
|
||||
|
||||
uchar inc_word_intra_copy_expected[] = {BUILD_HEADER(0x03, 0x07),
|
||||
0x05,
|
||||
BUILD_HEADER(0x02, 0x06),
|
||||
@@ -230,10 +197,21 @@ TEST(ROMTest, SimpleMixCompression) {
|
||||
0x05,
|
||||
0x00,
|
||||
0xFF};
|
||||
// CuAssertDataEquals_Msg(
|
||||
// tc, "Mixing, inc, alternate, intra copy", inc_word_intra_copy_expected,
|
||||
// 9, alttp_compress_gfx(to_compress_string, 3, 21, &compress_size));
|
||||
|
||||
// "Mixing, inc, alternate, intra copy"
|
||||
// compress start: 3, length: 21
|
||||
// compressed length: 9
|
||||
auto comp_result = ExpectCompressOk(rom, to_compress_string + 3, 21);
|
||||
EXPECT_THAT(inc_word_intra_copy_expected,
|
||||
ElementsAreArray(comp_result.data(), 9));
|
||||
}
|
||||
|
||||
TEST(ROMTest, CompressionMixedIncrementIntraCopySource) {
|
||||
ROM rom;
|
||||
uchar to_compress_string[] = {0x05, 0x05, 0x05, 0x05, 0x06, 0x07, 0x08,
|
||||
0x09, 0x0A, 0x0B, 0x05, 0x02, 0x05, 0x02,
|
||||
0x05, 0x02, 0x0A, 0x0B, 0x05, 0x02, 0x05,
|
||||
0x02, 0x05, 0x02, 0x08, 0x0A, 0x00, 0x05};
|
||||
uchar all_expected[] = {BUILD_HEADER(0x01, 0x04),
|
||||
0x05,
|
||||
BUILD_HEADER(0x03, 0x06),
|
||||
@@ -250,15 +228,16 @@ TEST(ROMTest, SimpleMixCompression) {
|
||||
0x00,
|
||||
0x05,
|
||||
0xFF};
|
||||
// CuAssertDataEquals_Msg(
|
||||
// tc, "Mixing, inc, alternate, intra copy", all_expected, 16,
|
||||
// alttp_compress_gfx(to_compress_string, 0, 28, &compress_size));
|
||||
// "Mixing, inc, alternate, intra copy"
|
||||
// 0, 28
|
||||
// 16
|
||||
auto comp_result = ExpectCompressOk(rom, to_compress_string, 28);
|
||||
EXPECT_THAT(all_expected, ElementsAreArray(comp_result.data(), 16));
|
||||
}
|
||||
*/
|
||||
|
||||
TEST(ROMTest, LengthBorderCompression) {
|
||||
char buffer[3000];
|
||||
unsigned int compress_size;
|
||||
ROM rom;
|
||||
uchar buffer[3000];
|
||||
|
||||
for (unsigned int i = 0; i < 3000; i++) buffer[i] = 0x05;
|
||||
uchar extended_lenght_expected_42[] = {0b11100100, 0x29, 0x05, 0xFF};
|
||||
@@ -268,31 +247,69 @@ TEST(ROMTest, LengthBorderCompression) {
|
||||
uchar extended_lenght_expected_2050[] = {
|
||||
0b11100111, 0xFF, 0x05, 0b11100111, 0xFF, 0x05, BUILD_HEADER(0x01, 0x02),
|
||||
0x05, 0xFF};
|
||||
// CuAssertDataEquals_Msg(tc, "Extended lenght, 42 repeat of 5",
|
||||
// extended_lenght_expected_42, 4,
|
||||
// alttp_compress_gfx(buffer, 0, 42, &compress_size));
|
||||
// CuAssertDataEquals_Msg(tc, "Extended lenght, 400 repeat of 5",
|
||||
// extended_lenght_expected_400, 4,
|
||||
// alttp_compress_gfx(buffer, 0, 400, &compress_size));
|
||||
// CuAssertDataEquals_Msg(tc, "Extended lenght, 1050 repeat of 5",
|
||||
// extended_lenght_expected_1050, 6,
|
||||
// alttp_compress_gfx(buffer, 0, 1050,
|
||||
// &compress_size));
|
||||
// CuAssertDataEquals_Msg(tc, "Extended lenght, 2050 repeat of 5",
|
||||
// extended_lenght_expected_2050, 9,
|
||||
// alttp_compress_gfx(buffer, 0, 2050,
|
||||
// &compress_size));
|
||||
|
||||
// "Extended lenght, 42 repeat of 5"
|
||||
auto comp_result = ExpectCompressOk(rom, buffer, 42);
|
||||
EXPECT_THAT(extended_lenght_expected_42,
|
||||
ElementsAreArray(comp_result.data(), 4));
|
||||
|
||||
// "Extended lenght, 400 repeat of 5"
|
||||
comp_result = ExpectCompressOk(rom, buffer, 400);
|
||||
EXPECT_THAT(extended_lenght_expected_400,
|
||||
ElementsAreArray(comp_result.data(), 4));
|
||||
|
||||
// "Extended lenght, 1050 repeat of 5"
|
||||
comp_result = ExpectCompressOk(rom, buffer, 1050);
|
||||
EXPECT_THAT(extended_lenght_expected_1050,
|
||||
ElementsAreArray(comp_result.data(), 6));
|
||||
|
||||
// "Extended lenght, 2050 repeat of 5"
|
||||
comp_result = ExpectCompressOk(rom, buffer, 2050);
|
||||
EXPECT_THAT(extended_lenght_expected_2050,
|
||||
ElementsAreArray(comp_result.data(), 9));
|
||||
}
|
||||
|
||||
TEST(ROMTest, CompressionExtendedWordCopy) {
|
||||
ROM rom;
|
||||
uchar buffer[3000];
|
||||
for (unsigned int i = 0; i < 3000; i += 2) {
|
||||
buffer[i] = 0x05;
|
||||
buffer[i + 1] = 0x06;
|
||||
}
|
||||
uchar hightlenght_word_1050[] = {
|
||||
0b11101011, 0xFF, 0x05, 0x06, BUILD_HEADER(0x02, 0x1A), 0x05, 0x06, 0xFF};
|
||||
// CuAssertDataEquals_Msg(tc, "Extended word copy", hightlenght_word_1050, 8,
|
||||
// alttp_compress_gfx(buffer, 0, 1050,
|
||||
// &compress_size));
|
||||
|
||||
// "Extended word copy"
|
||||
auto comp_result = ExpectCompressOk(rom, buffer, 1050);
|
||||
EXPECT_THAT(hightlenght_word_1050, ElementsAreArray(comp_result.data(), 8));
|
||||
}
|
||||
|
||||
/* Extended Header Command is currently unimplemented
|
||||
TEST(ROMTest, ExtendedHeaderDecompress) {
|
||||
ROM rom;
|
||||
Bytes extendedcmd_i = {0b11100100, 0x8F, 0x2A, 0xFF};
|
||||
uchar extendedcmd_o[50];
|
||||
for (int i = 0; i < 50; ++i) {
|
||||
extendedcmd_o[i] = 0x2A;
|
||||
}
|
||||
|
||||
auto decomp_result = ExpectDecompressBytesOk(rom, extendedcmd_i);
|
||||
ASSERT_THAT(extendedcmd_o, ElementsAreArray(decomp_result.data(), 50));
|
||||
}
|
||||
|
||||
TEST(ROMTest, ExtendedHeaderDecompress2) {
|
||||
ROM rom;
|
||||
Bytes extendedcmd_i = {0b11100101, 0x8F, 0x2A, 0xFF};
|
||||
uchar extendedcmd_o[50];
|
||||
for (int i = 0; i < 50; i++) {
|
||||
extendedcmd_o[i] = 0x2A;
|
||||
}
|
||||
|
||||
auto data = ExpectDecompressBytesOk(rom, extendedcmd_i);
|
||||
for (int i = 0; i < 50; i++) {
|
||||
ASSERT_EQ(extendedcmd_o[i], data[i]);
|
||||
}
|
||||
}
|
||||
*/
|
||||
} // namespace rom_test
|
||||
} // namespace yaze_test
|
||||
Reference in New Issue
Block a user