123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253 |
- #ifndef OSSL_TEST_SSL_TEST_CTX_H
- #define OSSL_TEST_SSL_TEST_CTX_H
- #include <openssl/conf.h>
- #include <openssl/ssl.h>
- typedef enum {
- SSL_TEST_SUCCESS = 0,
- SSL_TEST_SERVER_FAIL,
- SSL_TEST_CLIENT_FAIL,
- SSL_TEST_INTERNAL_ERROR,
-
- SSL_TEST_FIRST_HANDSHAKE_FAILED
- } ssl_test_result_t;
- typedef enum {
- SSL_TEST_VERIFY_NONE = 0,
- SSL_TEST_VERIFY_ACCEPT_ALL,
- SSL_TEST_VERIFY_REJECT_ALL
- } ssl_verify_callback_t;
- typedef enum {
- SSL_TEST_SERVERNAME_NONE = 0,
- SSL_TEST_SERVERNAME_SERVER1,
- SSL_TEST_SERVERNAME_SERVER2,
- SSL_TEST_SERVERNAME_INVALID
- } ssl_servername_t;
- typedef enum {
- SSL_TEST_SERVERNAME_CB_NONE = 0,
- SSL_TEST_SERVERNAME_IGNORE_MISMATCH,
- SSL_TEST_SERVERNAME_REJECT_MISMATCH,
- SSL_TEST_SERVERNAME_CLIENT_HELLO_IGNORE_MISMATCH,
- SSL_TEST_SERVERNAME_CLIENT_HELLO_REJECT_MISMATCH,
- SSL_TEST_SERVERNAME_CLIENT_HELLO_NO_V12
- } ssl_servername_callback_t;
- typedef enum {
- SSL_TEST_SESSION_TICKET_IGNORE = 0,
- SSL_TEST_SESSION_TICKET_YES,
- SSL_TEST_SESSION_TICKET_NO,
- SSL_TEST_SESSION_TICKET_BROKEN
- } ssl_session_ticket_t;
- typedef enum {
- SSL_TEST_COMPRESSION_NO = 0,
- SSL_TEST_COMPRESSION_YES
- } ssl_compression_t;
- typedef enum {
- SSL_TEST_SESSION_ID_IGNORE = 0,
- SSL_TEST_SESSION_ID_YES,
- SSL_TEST_SESSION_ID_NO
- } ssl_session_id_t;
- typedef enum {
- SSL_TEST_METHOD_TLS = 0,
- SSL_TEST_METHOD_DTLS
- } ssl_test_method_t;
- typedef enum {
- SSL_TEST_HANDSHAKE_SIMPLE = 0,
- SSL_TEST_HANDSHAKE_RESUME,
- SSL_TEST_HANDSHAKE_RENEG_SERVER,
- SSL_TEST_HANDSHAKE_RENEG_CLIENT,
- SSL_TEST_HANDSHAKE_KEY_UPDATE_SERVER,
- SSL_TEST_HANDSHAKE_KEY_UPDATE_CLIENT,
- SSL_TEST_HANDSHAKE_POST_HANDSHAKE_AUTH
- } ssl_handshake_mode_t;
- typedef enum {
- SSL_TEST_CT_VALIDATION_NONE = 0,
- SSL_TEST_CT_VALIDATION_PERMISSIVE,
- SSL_TEST_CT_VALIDATION_STRICT
- } ssl_ct_validation_t;
- typedef enum {
- SSL_TEST_CERT_STATUS_NONE = 0,
- SSL_TEST_CERT_STATUS_GOOD_RESPONSE,
- SSL_TEST_CERT_STATUS_BAD_RESPONSE
- } ssl_cert_status_t;
- typedef struct {
-
- ssl_verify_callback_t verify_callback;
-
- ssl_servername_t servername;
-
- int max_fragment_len_mode;
-
- char *npn_protocols;
- char *alpn_protocols;
- ssl_ct_validation_t ct_validation;
-
- char *reneg_ciphers;
- char *srp_user;
- char *srp_password;
-
- int enable_pha;
- } SSL_TEST_CLIENT_CONF;
- typedef struct {
-
- ssl_servername_callback_t servername_callback;
-
- char *npn_protocols;
- char *alpn_protocols;
-
- int broken_session_ticket;
-
- ssl_cert_status_t cert_status;
-
- char *srp_user;
- char *srp_password;
-
- int force_pha;
- char *session_ticket_app_data;
- } SSL_TEST_SERVER_CONF;
- typedef struct {
- SSL_TEST_CLIENT_CONF client;
- SSL_TEST_SERVER_CONF server;
- SSL_TEST_SERVER_CONF server2;
- } SSL_TEST_EXTRA_CONF;
- typedef struct {
-
-
- ssl_test_method_t method;
-
- ssl_handshake_mode_t handshake_mode;
-
- int app_data_size;
-
- int max_fragment_size;
-
- int key_update_type;
-
-
- SSL_TEST_EXTRA_CONF extra;
-
- SSL_TEST_EXTRA_CONF resume_extra;
-
-
- ssl_test_result_t expected_result;
-
-
-
- int expected_client_alert;
-
- int expected_server_alert;
-
-
- int expected_protocol;
-
- ssl_servername_t expected_servername;
- ssl_session_ticket_t session_ticket_expected;
- int compression_expected;
-
- char *expected_npn_protocol;
- char *expected_alpn_protocol;
-
- int resumption_expected;
-
- int expected_tmp_key_type;
-
- int expected_server_cert_type;
-
- int expected_server_sign_hash;
-
- int expected_server_sign_type;
-
- STACK_OF(X509_NAME) *expected_server_ca_names;
-
- int expected_client_cert_type;
-
- int expected_client_sign_hash;
-
- int expected_client_sign_type;
-
- STACK_OF(X509_NAME) *expected_client_ca_names;
-
- int use_sctp;
-
- int enable_client_sctp_label_bug;
-
- int enable_server_sctp_label_bug;
-
- ssl_session_id_t session_id_expected;
- char *expected_cipher;
-
- char *expected_session_ticket_app_data;
- } SSL_TEST_CTX;
- const char *ssl_test_result_name(ssl_test_result_t result);
- const char *ssl_alert_name(int alert);
- const char *ssl_protocol_name(int protocol);
- const char *ssl_verify_callback_name(ssl_verify_callback_t verify_callback);
- const char *ssl_servername_name(ssl_servername_t server);
- const char *ssl_servername_callback_name(ssl_servername_callback_t
- servername_callback);
- const char *ssl_session_ticket_name(ssl_session_ticket_t server);
- const char *ssl_session_id_name(ssl_session_id_t server);
- const char *ssl_test_method_name(ssl_test_method_t method);
- const char *ssl_handshake_mode_name(ssl_handshake_mode_t mode);
- const char *ssl_ct_validation_name(ssl_ct_validation_t mode);
- const char *ssl_certstatus_name(ssl_cert_status_t cert_status);
- const char *ssl_max_fragment_len_name(int MFL_mode);
- SSL_TEST_CTX *SSL_TEST_CTX_create(const CONF *conf, const char *test_section);
- SSL_TEST_CTX *SSL_TEST_CTX_new(void);
- void SSL_TEST_CTX_free(SSL_TEST_CTX *ctx);
- #endif
|