aboutsummaryrefslogtreecommitdiff
path: root/externals/mbedtls/tests/suites/test_suite_pkwrite.function
diff options
context:
space:
mode:
Diffstat (limited to 'externals/mbedtls/tests/suites/test_suite_pkwrite.function')
-rw-r--r--externals/mbedtls/tests/suites/test_suite_pkwrite.function90
1 files changed, 90 insertions, 0 deletions
diff --git a/externals/mbedtls/tests/suites/test_suite_pkwrite.function b/externals/mbedtls/tests/suites/test_suite_pkwrite.function
new file mode 100644
index 0000000000..2bad4ed137
--- /dev/null
+++ b/externals/mbedtls/tests/suites/test_suite_pkwrite.function
@@ -0,0 +1,90 @@
+/* BEGIN_HEADER */
+#include "mbedtls/pk.h"
+#include "mbedtls/pem.h"
+#include "mbedtls/oid.h"
+/* END_HEADER */
+
+/* BEGIN_DEPENDENCIES
+ * depends_on:MBEDTLS_PK_PARSE_C:MBEDTLS_PK_WRITE_C:MBEDTLS_BIGNUM_C:MBEDTLS_FS_IO
+ * END_DEPENDENCIES
+ */
+
+/* BEGIN_CASE depends_on:MBEDTLS_PEM_WRITE_C */
+void pk_write_pubkey_check( char * key_file )
+{
+ mbedtls_pk_context key;
+ unsigned char buf[5000];
+ unsigned char check_buf[5000];
+ int ret;
+ FILE *f;
+ size_t ilen, pem_len, buf_index;
+
+ memset( buf, 0, sizeof( buf ) );
+ memset( check_buf, 0, sizeof( check_buf ) );
+
+ mbedtls_pk_init( &key );
+ TEST_ASSERT( mbedtls_pk_parse_public_keyfile( &key, key_file ) == 0 );
+
+ ret = mbedtls_pk_write_pubkey_pem( &key, buf, sizeof( buf ));
+ TEST_ASSERT( ret == 0 );
+
+ pem_len = strlen( (char *) buf );
+
+ // check that the rest of the buffer remains clear
+ for( buf_index = pem_len; buf_index < sizeof( buf ); ++buf_index )
+ {
+ TEST_ASSERT( buf[buf_index] == 0 );
+ }
+
+ f = fopen( key_file, "r" );
+ TEST_ASSERT( f != NULL );
+ ilen = fread( check_buf, 1, sizeof( check_buf ), f );
+ fclose( f );
+
+ TEST_ASSERT( ilen == pem_len );
+ TEST_ASSERT( memcmp( (char *) buf, (char *) check_buf, ilen ) == 0 );
+
+exit:
+ mbedtls_pk_free( &key );
+}
+/* END_CASE */
+
+/* BEGIN_CASE depends_on:MBEDTLS_PEM_WRITE_C */
+void pk_write_key_check( char * key_file )
+{
+ mbedtls_pk_context key;
+ unsigned char buf[5000];
+ unsigned char check_buf[5000];
+ int ret;
+ FILE *f;
+ size_t ilen, pem_len, buf_index;
+
+ memset( buf, 0, sizeof( buf ) );
+ memset( check_buf, 0, sizeof( check_buf ) );
+
+ mbedtls_pk_init( &key );
+ TEST_ASSERT( mbedtls_pk_parse_keyfile( &key, key_file, NULL ) == 0 );
+
+ ret = mbedtls_pk_write_key_pem( &key, buf, sizeof( buf ));
+ TEST_ASSERT( ret == 0 );
+
+ pem_len = strlen( (char *) buf );
+
+ // check that the rest of the buffer remains clear
+ for( buf_index = pem_len; buf_index < sizeof( buf ); ++buf_index )
+ {
+ TEST_ASSERT( buf[buf_index] == 0 );
+ }
+
+ f = fopen( key_file, "r" );
+ TEST_ASSERT( f != NULL );
+ ilen = fread( check_buf, 1, sizeof( check_buf ), f );
+ fclose( f );
+
+ TEST_ASSERT( ilen == strlen( (char *) buf ) );
+ TEST_ASSERT( memcmp( (char *) buf, (char *) check_buf, ilen ) == 0 );
+
+exit:
+ mbedtls_pk_free( &key );
+}
+/* END_CASE */