More tests on data formatter

This commit is contained in:
Leonetienne 2022-05-27 16:08:24 +02:00
parent cf22f8c569
commit 186fea1383
No known key found for this signature in database
GPG Key ID: C33879CD92E9708C

View File

@ -5,9 +5,9 @@
using namespace Leonetienne::GCrypt;
// Tests that recoding iobase format works
// Tests that recoding iobase formats works for individual blocks, with random data
TEMPLATE_TEST_CASE_SIG(
__FILE__"Data formats can be converted, without changing in value",
__FILE__"Data formats can be converted, without changing in value, with indivudual blocks, with random data",
"[ModuleDataFormatter]",
((Configuration::IOBASE_FORMAT formatUnderTest), formatUnderTest),
Configuration::IOBASE_FORMAT::BASE_BYTES,
@ -26,12 +26,11 @@ TEMPLATE_TEST_CASE_SIG(
GPrng prng(Key::Random());
// Let's try 50 different random blocks per test
for (std::size_t i = 0; i < 50; i++) {
// Let's try 10 different random blocks per test
for (std::size_t i = 0; i < 10; i++) {
// Setup
Block b_initial;
b_initial = prng.GetBlock();
const Block b_initial = prng.GetBlock();
// Exercise
// Convert to a custom base
@ -52,3 +51,40 @@ TEMPLATE_TEST_CASE_SIG(
}
}
// Tests that recoding iobase format works
TEMPLATE_TEST_CASE_SIG(
__FILE__"Data formats can be converted, without changing in value, with indivudual blocks, with very little data (lots of nullbytes)",
"[ModuleDataFormatter]",
((Configuration::IOBASE_FORMAT formatUnderTest), formatUnderTest),
Configuration::IOBASE_FORMAT::BASE_BYTES,
Configuration::IOBASE_FORMAT::BASE_2,
Configuration::IOBASE_FORMAT::BASE_8,
Configuration::IOBASE_FORMAT::BASE_10,
Configuration::IOBASE_FORMAT::BASE_16,
Configuration::IOBASE_FORMAT::BASE_64,
Configuration::IOBASE_FORMAT::BASE_UWU,
Configuration::IOBASE_FORMAT::BASE_UGH
) {
// Setup
Block b_initial;
b_initial.FromTextString("Heyu");
// Exercise
// Convert to a custom base
const std::string b_format = ModuleDataFormatter::FormatBlock(
b_initial,
formatUnderTest
);
// Convert back to a block
const Block b_retrieved = ModuleDataFormatter::DecodeFormat(
b_format,
formatUnderTest
);
// Verify
// Do b_initial and b_retrieved match?
REQUIRE(b_initial == b_retrieved);
}