mirror of
https://github.com/Mbed-TLS/mbedtls.git
synced 2025-08-07 06:42:56 +03:00
54 lines
1.5 KiB
C
54 lines
1.5 KiB
C
/* BEGIN_HEADER */
|
|
#include "mbedtls/base64.h"
|
|
#include "mbedtls/pem.h"
|
|
#include "mbedtls/des.h"
|
|
#include "mbedtls/aes.h"
|
|
/* END_HEADER */
|
|
|
|
/* BEGIN_CASE depends_on:MBEDTLS_PEM_WRITE_C */
|
|
void mbedtls_pem_write_buffer(char *start, char *end, data_t *buf,
|
|
char *result_str)
|
|
{
|
|
unsigned char *check_buf = NULL;
|
|
int ret;
|
|
size_t olen = 0, olen2 = 0;
|
|
|
|
|
|
ret = mbedtls_pem_write_buffer(start, end, buf->x, buf->len, NULL, 0, &olen);
|
|
TEST_ASSERT(ret == MBEDTLS_ERR_BASE64_BUFFER_TOO_SMALL);
|
|
|
|
check_buf = (unsigned char *) mbedtls_calloc(1, olen);
|
|
TEST_ASSERT(check_buf != NULL);
|
|
|
|
ret = mbedtls_pem_write_buffer(start, end, buf->x, buf->len, check_buf, olen, &olen2);
|
|
|
|
TEST_ASSERT(olen2 <= olen);
|
|
TEST_ASSERT(olen > strlen((char *) result_str));
|
|
TEST_ASSERT(ret == 0);
|
|
TEST_ASSERT(strncmp((char *) check_buf, (char *) result_str, olen) == 0);
|
|
|
|
exit:
|
|
mbedtls_free(check_buf);
|
|
}
|
|
/* END_CASE */
|
|
|
|
/* BEGIN_CASE depends_on:MBEDTLS_PEM_PARSE_C:MBEDTLS_AES_C:MBEDTLS_DES_C:MBEDTLS_MD5_C:MBEDTLS_CIPHER_MODE_CBC */
|
|
void mbedtls_pem_read_buffer(char *header, char *footer, char *data,
|
|
char *pwd, int res)
|
|
{
|
|
mbedtls_pem_context ctx;
|
|
int ret;
|
|
size_t use_len = 0;
|
|
size_t pwd_len = strlen(pwd);
|
|
|
|
mbedtls_pem_init(&ctx);
|
|
|
|
ret = mbedtls_pem_read_buffer(&ctx, header, footer, (unsigned char *) data,
|
|
(unsigned char *) pwd, pwd_len, &use_len);
|
|
TEST_ASSERT(ret == res);
|
|
|
|
exit:
|
|
mbedtls_pem_free(&ctx);
|
|
}
|
|
/* END_CASE */
|