/* * Copyright 2014-2022 The GmSSL Project. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the License); you may * not use this file except in compliance with the License. * * http://www.apache.org/licenses/LICENSE-2.0 */ #include #include #include #include #include static int test_base64(void) { uint8_t bin1[50]; uint8_t bin2[100]; uint8_t bin3[200]; uint8_t buf1[8000] = {0}; uint8_t buf2[8000] = {0}; BASE64_CTX ctx; uint8_t *p; int len; memset(bin1, 0x01, sizeof(bin1)); memset(bin2, 0xA5, sizeof(bin2)); memset(bin3, 0xff, sizeof(bin3)); p = buf1; base64_encode_init(&ctx); base64_encode_update(&ctx, bin1, sizeof(bin1), p, &len); p += len; base64_encode_update(&ctx, bin2, sizeof(bin2), p, &len); p += len; base64_encode_update(&ctx, bin3, sizeof(bin3), p, &len); p += len; base64_encode_finish(&ctx, p, &len); p += len; len = (int)(p - buf1); p = buf2; base64_decode_init(&ctx); base64_decode_update(&ctx, buf1, len, p, &len); p += len; base64_decode_finish(&ctx, p, &len); p += len; len = (int)(p - buf2); printf("base64 test "); if (len != sizeof(bin1) + sizeof(bin2) + sizeof(bin3) || memcmp(buf2, bin1, sizeof(bin1)) != 0 || memcmp(buf2 + sizeof(bin1), bin2, sizeof(bin2)) != 0 || memcmp(buf2 + sizeof(bin1) + sizeof(bin2), bin3, sizeof(bin3)) != 0) { printf("failed\n"); return -1; } else { printf("ok\n"); } return 1; } int main(void) { if (test_base64() != 1) goto err; printf("%s all tests passed\n", __FILE__); return 0; err: error_print(); return -1; }