Add test for ssl_cache max_entries

This commit is contained in:
Manuel Pégourié-Gonnard 2014-02-20 21:32:41 +01:00
parent 274a12e17c
commit 4c88345f19
2 changed files with 48 additions and 2 deletions

View file

@ -69,6 +69,7 @@
#define DFL_AUTH_MODE SSL_VERIFY_OPTIONAL #define DFL_AUTH_MODE SSL_VERIFY_OPTIONAL
#define DFL_MFL_CODE SSL_MAX_FRAG_LEN_NONE #define DFL_MFL_CODE SSL_MAX_FRAG_LEN_NONE
#define DFL_TICKETS SSL_SESSION_TICKETS_ENABLED #define DFL_TICKETS SSL_SESSION_TICKETS_ENABLED
#define DFL_CACHE_MAX -1
#define LONG_RESPONSE "<p>01-blah-blah-blah-blah-blah-blah-blah-blah-blah\r\n" \ #define LONG_RESPONSE "<p>01-blah-blah-blah-blah-blah-blah-blah-blah-blah\r\n" \
"02-blah-blah-blah-blah-blah-blah-blah-blah-blah-blah-blah-blah-blah\r\n" \ "02-blah-blah-blah-blah-blah-blah-blah-blah-blah-blah-blah-blah-blah\r\n" \
@ -110,6 +111,7 @@ struct options
int auth_mode; /* verify mode for connection */ int auth_mode; /* verify mode for connection */
unsigned char mfl_code; /* code for maximum fragment length */ unsigned char mfl_code; /* code for maximum fragment length */
int tickets; /* enable / disable session tickets */ int tickets; /* enable / disable session tickets */
int cache_max; /* max number of session cache entries */
} opt; } opt;
static void my_debug( void *ctx, int level, const char *str ) static void my_debug( void *ctx, int level, const char *str )
@ -162,6 +164,13 @@ static void my_debug( void *ctx, int level, const char *str )
#define USAGE_TICKETS "" #define USAGE_TICKETS ""
#endif /* POLARSSL_SSL_SESSION_TICKETS */ #endif /* POLARSSL_SSL_SESSION_TICKETS */
#if defined(POLARSSL_SSL_CACHE_C)
#define USAGE_CACHE \
" cache_max=%%d default: cache default (50)\n"
#else
#define USAGE_CACHE ""
#endif /* POLARSSL_SSL_CACHE_C */
#if defined(POLARSSL_SSL_MAX_FRAGMENT_LENGTH) #if defined(POLARSSL_SSL_MAX_FRAGMENT_LENGTH)
#define USAGE_MAX_FRAG_LEN \ #define USAGE_MAX_FRAG_LEN \
" max_frag_len=%%d default: 16384 (tls default)\n" \ " max_frag_len=%%d default: 16384 (tls default)\n" \
@ -307,6 +316,7 @@ int main( int argc, char *argv[] )
opt.auth_mode = DFL_AUTH_MODE; opt.auth_mode = DFL_AUTH_MODE;
opt.mfl_code = DFL_MFL_CODE; opt.mfl_code = DFL_MFL_CODE;
opt.tickets = DFL_TICKETS; opt.tickets = DFL_TICKETS;
opt.cache_max = DFL_CACHE_MAX;
for( i = 1; i < argc; i++ ) for( i = 1; i < argc; i++ )
{ {
@ -456,6 +466,12 @@ int main( int argc, char *argv[] )
if( opt.tickets < 0 || opt.tickets > 1 ) if( opt.tickets < 0 || opt.tickets > 1 )
goto usage; goto usage;
} }
else if( strcmp( p, "cache_max" ) == 0 )
{
opt.cache_max = atoi( q );
if( opt.cache_max < 0 )
goto usage;
}
else else
goto usage; goto usage;
} }
@ -726,6 +742,9 @@ int main( int argc, char *argv[] )
ssl_set_dbg( &ssl, my_debug, stdout ); ssl_set_dbg( &ssl, my_debug, stdout );
#if defined(POLARSSL_SSL_CACHE_C) #if defined(POLARSSL_SSL_CACHE_C)
if( opt.cache_max != -1 )
ssl_cache_set_max_entries( &cache, opt.cache_max );
ssl_set_session_cache( &ssl, ssl_cache_get, &cache, ssl_set_session_cache( &ssl, ssl_cache_get, &cache,
ssl_cache_set, &cache ); ssl_cache_set, &cache );
#endif #endif

View file

@ -102,7 +102,7 @@ run_test "Truncated HMAC #1" \
# Tests for Session Tickets # Tests for Session Tickets
run_test "Session resume using tickets" \ run_test "Session resume using tickets #1" \
"debug_level=4 tickets=1" \ "debug_level=4 tickets=1" \
"debug_level=4 reconnect=1 tickets=1" \ "debug_level=4 reconnect=1 tickets=1" \
0 \ 0 \
@ -111,7 +111,16 @@ run_test "Session resume using tickets" \
-s "a session has been resumed" \ -s "a session has been resumed" \
-c "a session has been resumed" -c "a session has been resumed"
# Test for Session Resume base in session-ID and cache run_test "Session resume using tickets #2" \
"debug_level=4 tickets=1 cache_max=0" \
"debug_level=4 reconnect=1 tickets=1" \
0 \
-S "session successfully restored from cache" \
-s "session successfully restored from ticket" \
-s "a session has been resumed" \
-c "a session has been resumed"
# Test for Session Resume based on session-ID and cache
run_test "Session resume using cache #1" \ run_test "Session resume using cache #1" \
"debug_level=4 tickets=0" \ "debug_level=4 tickets=0" \
@ -131,6 +140,24 @@ run_test "Session resume using cache #2" \
-s "a session has been resumed" \ -s "a session has been resumed" \
-c "a session has been resumed" -c "a session has been resumed"
run_test "Session resume using cache #3" \
"debug_level=4 tickets=0 cache_max=0" \
"debug_level=4 reconnect=1 tickets=0" \
0 \
-S "session successfully restored from cache" \
-S "session successfully restored from ticket" \
-s "no session has been resumed" \
-c "no session has been resumed"
run_test "Session resume using cache #4" \
"debug_level=4 tickets=1 cache_max=1" \
"debug_level=4 reconnect=1 tickets=0" \
0 \
-s "session successfully restored from cache" \
-S "session successfully restored from ticket" \
-s "a session has been resumed" \
-c "a session has been resumed"
# Tests for Max Fragment Length extension # Tests for Max Fragment Length extension
run_test "Max fragment length #1" \ run_test "Max fragment length #1" \