coreboot-kgpe-d16/tests/lib/b64_decode-test.c
Jakub Czapiga c91b55a201 tests: update CMocka to stable-1.1
CMocka stable-1.1 has some convenience bugfixes like vprint buffer
increase or leftover values log fix (funtion names display correctly
now.

Signed-off-by: Jakub Czapiga <jacz@semihalf.com>
Change-Id: I20ebd15324a21c17cccd2976ae9c3f86b040426d
Reviewed-on: https://review.coreboot.org/c/coreboot/+/63636
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Arthur Heymans <arthur@aheymans.xyz>
2022-04-19 13:00:36 +00:00

61 lines
1.2 KiB
C

/* SPDX-License-Identifier: GPL-2.0-only */
#include <stddef.h>
#include <stdint.h>
#include <stdlib.h>
#include <string.h>
#include <b64_decode.h>
#include <tests/test.h>
struct messages_t {
const char *enc;
const char *dec;
} messages[] = {
{"QQ==", "A"},
{"Q\r\nUI=", "AB"},
{"QUJD", "ABC"},
{"\nQUJDRA==", "ABCD"},
{"SGVsbG8\r=", "Hello"},
{"SGVsbG8h", "Hello!"}
};
const char *invalid[] = {
"QQ=-=",
"SGVsbG-8="
};
static void test_b64_decode(void **state)
{
uint8_t *decoded;
size_t res;
for (int i = 0; i < ARRAY_SIZE(messages); i++) {
decoded = malloc(strlen(messages[i].enc) * sizeof(char));
res = b64_decode((uint8_t *)messages[i].enc, strlen(messages[i].enc), decoded);
assert_int_equal(res, (strlen(messages[i].dec)));
assert_string_equal((const char *)decoded, messages[i].dec);
free(decoded);
}
for (int i = 0; i < ARRAY_SIZE(invalid); i++) {
decoded = malloc(strlen(invalid[i]) * sizeof(char));
res = b64_decode((uint8_t *)invalid[i], strlen(invalid[i]), decoded);
assert_int_equal(res, 0);
free(decoded);
}
}
int main(void)
{
const struct CMUnitTest tests[] = {
cmocka_unit_test(test_b64_decode),
};
return cb_run_group_tests(tests, NULL, NULL);
}