/** @file
Unit tests for BaseLib's checksum capabilities.
Copyright (c) 2023 Pedro Falcato. All rights reserved
SPDX-License-Identifier: BSD-2-Clause-Patent
**/
#include
extern "C" {
#include
#include
}
// Precomputed crc32c and crc16-ansi for "hello" (without the null byte)
constexpr STATIC UINT32 mHelloCrc32c = 0x9A71BB4C;
constexpr STATIC UINT16 mHelloCrc16 = 0x34F6;
TEST (Crc32c, BasicCheck) {
// Note: The magic numbers below are precomputed checksums
// Check for basic operation on even and odd numbers of bytes
EXPECT_EQ (CalculateCrc32c ("hello", 5, 0), mHelloCrc32c);
EXPECT_EQ (
CalculateCrc32c ("longlonglonglonglong", sizeof ("longlonglonglonglong") - 1, 0),
0xC50F869D
);
EXPECT_EQ (CalculateCrc32c ("h", 1, 0), 0xB96298FC);
// Check if a checksum with no bytes correctly yields 0
EXPECT_EQ (CalculateCrc32c ("", 0, 0), 0U);
}
TEST (Crc32c, MultipartCheck) {
// Test multi-part crc32c calculation. So that given a string of bytes
// s[N], crc32c(s, N, 0) == crc32c(s[N - 1], 1, crc32c(s, N - 1, 0))
// and all other sorts of combinations one might imagine.
UINT32 val;
val = CalculateCrc32c ("hel", 3, 0);
EXPECT_EQ (CalculateCrc32c (&"hello"[3], 2, val), mHelloCrc32c);
}
TEST (Crc16, BasicCheck) {
// Note: The magic numbers below are precomputed checksums
// Check for basic operation on even and odd numbers of bytes
EXPECT_EQ (CalculateCrc16Ansi ("hello", 5, CRC16ANSI_INIT), mHelloCrc16);
EXPECT_EQ (
CalculateCrc16Ansi ("longlonglonglonglong", sizeof ("longlonglonglonglong") - 1, CRC16ANSI_INIT),
0xF723
);
EXPECT_EQ (CalculateCrc16Ansi ("h", 1, CRC16ANSI_INIT), 0xAEBE);
// Check if a checksum with no bytes correctly yields CRC16ANSI_INIT
EXPECT_EQ (CalculateCrc16Ansi ("", 0, CRC16ANSI_INIT), CRC16ANSI_INIT);
}
TEST (Crc16, MultipartCheck) {
// Test multi-part crc16 calculation. So that given a string of bytes
// s[N], crc16(s, N, 0) == crc16(s[N - 1], 1, crc16(s, N - 1, 0))
// and all other sorts of combinations one might imagine.
UINT16 val;
val = CalculateCrc16Ansi ("hel", 3, CRC16ANSI_INIT);
EXPECT_EQ (CalculateCrc16Ansi (&"hello"[3], 2, val), mHelloCrc16);
}