test_suite_asn1write.function 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. /* BEGIN_HEADER */
  2. #include "mbedtls/asn1write.h"
  3. #define GUARD_LEN 4
  4. #define GUARD_VAL 0x2a
  5. /* END_HEADER */
  6. /* BEGIN_DEPENDENCIES
  7. * depends_on:MBEDTLS_ASN1_WRITE_C
  8. * END_DEPENDENCIES
  9. */
  10. /* BEGIN_CASE */
  11. void mbedtls_asn1_write_octet_string( char *hex_str, char *hex_asn1,
  12. int buf_len, int result )
  13. {
  14. int ret;
  15. unsigned char buf[150];
  16. unsigned char str[150] = { 0 };
  17. unsigned char asn1[150] = { 0 };
  18. size_t str_len, asn1_len, i;
  19. unsigned char *p;
  20. memset( buf, GUARD_VAL, sizeof( buf ) );
  21. str_len = unhexify( str, hex_str );
  22. asn1_len = unhexify( asn1, hex_asn1 );
  23. p = buf + GUARD_LEN + buf_len;
  24. ret = mbedtls_asn1_write_octet_string( &p, buf + GUARD_LEN, str, str_len );
  25. /* Check for buffer overwrite on both sides */
  26. for( i = 0; i < GUARD_LEN; i++ )
  27. {
  28. TEST_ASSERT( buf[i] == GUARD_VAL );
  29. TEST_ASSERT( buf[GUARD_LEN + buf_len + i] == GUARD_VAL );
  30. }
  31. if( result >= 0 )
  32. {
  33. TEST_ASSERT( (size_t) ret == asn1_len );
  34. TEST_ASSERT( p + asn1_len == buf + GUARD_LEN + buf_len );
  35. TEST_ASSERT( memcmp( p, asn1, asn1_len ) == 0 );
  36. }
  37. }
  38. /* END_CASE */
  39. /* BEGIN_CASE */
  40. void mbedtls_asn1_write_ia5_string( char *str, char *hex_asn1,
  41. int buf_len, int result )
  42. {
  43. int ret;
  44. unsigned char buf[150];
  45. unsigned char asn1[150] = { 0 };
  46. size_t str_len, asn1_len, i;
  47. unsigned char *p;
  48. memset( buf, GUARD_VAL, sizeof( buf ) );
  49. str_len = strlen( str );
  50. asn1_len = unhexify( asn1, hex_asn1 );
  51. p = buf + GUARD_LEN + buf_len;
  52. ret = mbedtls_asn1_write_ia5_string( &p, buf + GUARD_LEN, str, str_len );
  53. /* Check for buffer overwrite on both sides */
  54. for( i = 0; i < GUARD_LEN; i++ )
  55. {
  56. TEST_ASSERT( buf[i] == GUARD_VAL );
  57. TEST_ASSERT( buf[GUARD_LEN + buf_len + i] == GUARD_VAL );
  58. }
  59. if( result >= 0 )
  60. {
  61. TEST_ASSERT( (size_t) ret == asn1_len );
  62. TEST_ASSERT( p + asn1_len == buf + GUARD_LEN + buf_len );
  63. TEST_ASSERT( memcmp( p, asn1, asn1_len ) == 0 );
  64. }
  65. }
  66. /* END_CASE */
  67. /* BEGIN_CASE */
  68. void mbedtls_asn1_write_len( int len, char *check_str, int buf_len,
  69. int result )
  70. {
  71. int ret;
  72. unsigned char buf[150];
  73. unsigned char asn1[150];
  74. unsigned char *p;
  75. size_t asn1_len, i, read_len;
  76. memset( buf, GUARD_VAL, sizeof( buf ) );
  77. memset( asn1, 0, sizeof( asn1 ) );
  78. asn1_len = unhexify( asn1, check_str );
  79. p = buf + GUARD_LEN + buf_len;
  80. ret = mbedtls_asn1_write_len( &p, buf + GUARD_LEN, (size_t) len );
  81. TEST_ASSERT( ret == result );
  82. /* Check for buffer overwrite on both sides */
  83. for( i = 0; i < GUARD_LEN; i++ )
  84. {
  85. TEST_ASSERT( buf[i] == GUARD_VAL );
  86. TEST_ASSERT( buf[GUARD_LEN + buf_len + i] == GUARD_VAL );
  87. }
  88. if( result >= 0 )
  89. {
  90. TEST_ASSERT( (size_t) ret == asn1_len );
  91. TEST_ASSERT( p + asn1_len == buf + GUARD_LEN + buf_len );
  92. TEST_ASSERT( memcmp( p, asn1, asn1_len ) == 0 );
  93. /* Read back with mbedtls_asn1_get_len() to check */
  94. ret = mbedtls_asn1_get_len( &p, buf + GUARD_LEN + buf_len, &read_len );
  95. if( len == 0 )
  96. {
  97. TEST_ASSERT( ret == 0 );
  98. }
  99. else
  100. {
  101. /* Return will be MBEDTLS_ERR_ASN1_OUT_OF_DATA because the rest of
  102. * the buffer is missing
  103. */
  104. TEST_ASSERT( ret == MBEDTLS_ERR_ASN1_OUT_OF_DATA );
  105. }
  106. TEST_ASSERT( read_len == (size_t) len );
  107. TEST_ASSERT( p == buf + GUARD_LEN + buf_len );
  108. }
  109. }
  110. /* END_CASE */