diff options
Diffstat (limited to 'libs/libevent/docs/test/regress_ssl.c')
-rw-r--r-- | libs/libevent/docs/test/regress_ssl.c | 781 |
1 files changed, 0 insertions, 781 deletions
diff --git a/libs/libevent/docs/test/regress_ssl.c b/libs/libevent/docs/test/regress_ssl.c deleted file mode 100644 index a415952a7d..0000000000 --- a/libs/libevent/docs/test/regress_ssl.c +++ /dev/null @@ -1,781 +0,0 @@ -/* - * Copyright (c) 2009-2012 Niels Provos and Nick Mathewson - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */ - -// Get rid of OSX 10.7 and greater deprecation warnings. -#if defined(__APPLE__) && defined(__clang__) -#pragma clang diagnostic ignored "-Wdeprecated-declarations" -#endif - -#ifdef _WIN32 -#include <winsock2.h> -#include <windows.h> -#endif - -#ifndef _WIN32 -#include <sys/types.h> -#include <sys/socket.h> -#include <netinet/in.h> -#endif - -#include "event2/util.h" -#include "event2/event.h" -#include "event2/bufferevent_ssl.h" -#include "event2/bufferevent_struct.h" -#include "event2/buffer.h" -#include "event2/listener.h" - -#include "regress.h" -#include "tinytest.h" -#include "tinytest_macros.h" - -#include <openssl/bio.h> -#include <openssl/err.h> -#include <openssl/pem.h> - -#include <string.h> -#ifdef _WIN32 -#include <io.h> -#define read _read -#define write _write -#else -#include <unistd.h> -#endif - -/* A short pre-generated key, to save the cost of doing an RSA key generation - * step during the unit tests. It's only 512 bits long, and it is published - * in this file, so you would have to be very foolish to consider using it in - * your own code. */ -static const char KEY[] = - "-----BEGIN RSA PRIVATE KEY-----\n" - "MIIBOgIBAAJBAKibTEzXjj+sqpipePX1lEk5BNFuL/dDBbw8QCXgaJWikOiKHeJq\n" - "3FQ0OmCnmpkdsPFE4x3ojYmmdgE2i0dJwq0CAwEAAQJAZ08gpUS+qE1IClps/2gG\n" - "AAer6Bc31K2AaiIQvCSQcH440cp062QtWMC3V5sEoWmdLsbAHFH26/9ZHn5zAflp\n" - "gQIhANWOx/UYeR8HD0WREU5kcuSzgzNLwUErHLzxP7U6aojpAiEAyh2H35CjN/P7\n" - "NhcZ4QYw3PeUWpqgJnaE/4i80BSYkSUCIQDLHFhLYLJZ80HwHTADif/ISn9/Ow6b\n" - "p6BWh3DbMar/eQIgBPS6azH5vpp983KXkNv9AL4VZi9ac/b+BeINdzC6GP0CIDmB\n" - "U6GFEQTZ3IfuiVabG5pummdC4DNbcdI+WKrSFNmQ\n" - "-----END RSA PRIVATE KEY-----\n"; - -EVP_PKEY * -ssl_getkey(void) -{ - EVP_PKEY *key; - BIO *bio; - - /* new read-only BIO backed by KEY. */ - bio = BIO_new_mem_buf((char*)KEY, -1); - tt_assert(bio); - - key = PEM_read_bio_PrivateKey(bio,NULL,NULL,NULL); - BIO_free(bio); - tt_assert(key); - - return key; -end: - return NULL; -} - -X509 * -ssl_getcert(void) -{ - /* Dummy code to make a quick-and-dirty valid certificate with - OpenSSL. Don't copy this code into your own program! It does a - number of things in a stupid and insecure way. */ - X509 *x509 = NULL; - X509_NAME *name = NULL; - EVP_PKEY *key = ssl_getkey(); - int nid; - time_t now = time(NULL); - - tt_assert(key); - - x509 = X509_new(); - tt_assert(x509); - tt_assert(0 != X509_set_version(x509, 2)); - tt_assert(0 != ASN1_INTEGER_set(X509_get_serialNumber(x509), - (long)now)); - - name = X509_NAME_new(); - tt_assert(name); - nid = OBJ_txt2nid("commonName"); - tt_assert(NID_undef != nid); - tt_assert(0 != X509_NAME_add_entry_by_NID( - name, nid, MBSTRING_ASC, (unsigned char*)"example.com", - -1, -1, 0)); - - X509_set_subject_name(x509, name); - X509_set_issuer_name(x509, name); - - X509_time_adj(X509_get_notBefore(x509), 0, &now); - now += 3600; - X509_time_adj(X509_get_notAfter(x509), 0, &now); - X509_set_pubkey(x509, key); - tt_assert(0 != X509_sign(x509, key, EVP_sha1())); - - return x509; -end: - X509_free(x509); - return NULL; -} - -static int disable_tls_11_and_12 = 0; -static SSL_CTX *the_ssl_ctx = NULL; - -SSL_CTX * -get_ssl_ctx(void) -{ - if (the_ssl_ctx) - return the_ssl_ctx; - the_ssl_ctx = SSL_CTX_new(SSLv23_method()); - if (!the_ssl_ctx) - return NULL; - if (disable_tls_11_and_12) { -#ifdef SSL_OP_NO_TLSv1_2 - SSL_CTX_set_options(the_ssl_ctx, SSL_OP_NO_TLSv1_2); -#endif -#ifdef SSL_OP_NO_TLSv1_1 - SSL_CTX_set_options(the_ssl_ctx, SSL_OP_NO_TLSv1_1); -#endif - } - return the_ssl_ctx; -} - -void -init_ssl(void) -{ - SSL_library_init(); - ERR_load_crypto_strings(); - SSL_load_error_strings(); - OpenSSL_add_all_algorithms(); - if (SSLeay() != OPENSSL_VERSION_NUMBER) { - TT_DECLARE("WARN", ("Version mismatch for openssl: compiled with %lx but running with %lx", (unsigned long)OPENSSL_VERSION_NUMBER, (unsigned long) SSLeay())); - } -} - -/* ==================== - Here's a simple test: we read a number from the input, increment it, and - reply, until we get to 1001. -*/ - -static int test_is_done = 0; -static int n_connected = 0; -static int got_close = 0; -static int got_error = 0; -static int got_timeout = 0; -static int renegotiate_at = -1; -static int stop_when_connected = 0; -static int pending_connect_events = 0; -static struct event_base *exit_base = NULL; - -enum regress_openssl_type -{ - REGRESS_OPENSSL_SOCKETPAIR = 1, - REGRESS_OPENSSL_FILTER = 2, - REGRESS_OPENSSL_RENEGOTIATE = 4, - REGRESS_OPENSSL_OPEN = 8, - REGRESS_OPENSSL_DIRTY_SHUTDOWN = 16, - REGRESS_OPENSSL_FD = 32, - - REGRESS_OPENSSL_CLIENT = 64, - REGRESS_OPENSSL_SERVER = 128, - - REGRESS_OPENSSL_FREED = 256, - REGRESS_OPENSSL_TIMEOUT = 512, - REGRESS_OPENSSL_SLEEP = 1024, -}; - -static void -bufferevent_openssl_check_fd(struct bufferevent *bev, int filter) -{ - if (filter) { - tt_int_op(bufferevent_getfd(bev), ==, -1); - tt_int_op(bufferevent_setfd(bev, -1), ==, -1); - } else { - tt_int_op(bufferevent_getfd(bev), !=, -1); - tt_int_op(bufferevent_setfd(bev, -1), ==, 0); - } - tt_int_op(bufferevent_getfd(bev), ==, -1); - -end: - ; -} -static void -bufferevent_openssl_check_freed(struct bufferevent *bev) -{ - tt_int_op(event_pending(&bev->ev_read, EVLIST_ALL, NULL), ==, 0); - tt_int_op(event_pending(&bev->ev_write, EVLIST_ALL, NULL), ==, 0); - -end: - ; -} - -static void -respond_to_number(struct bufferevent *bev, void *ctx) -{ - struct evbuffer *b = bufferevent_get_input(bev); - char *line; - int n; - - enum regress_openssl_type type; - type = (enum regress_openssl_type)ctx; - - line = evbuffer_readln(b, NULL, EVBUFFER_EOL_LF); - if (! line) - return; - n = atoi(line); - if (n <= 0) - TT_FAIL(("Bad number: %s", line)); - free(line); - TT_BLATHER(("The number was %d", n)); - if (n == 1001) { - ++test_is_done; - bufferevent_free(bev); /* Should trigger close on other side. */ - return; - } - if ((type & REGRESS_OPENSSL_CLIENT) && n == renegotiate_at) { - SSL_renegotiate(bufferevent_openssl_get_ssl(bev)); - } - ++n; - evbuffer_add_printf(bufferevent_get_output(bev), - "%d\n", n); - TT_BLATHER(("Done reading; now writing.")); - bufferevent_enable(bev, EV_WRITE); - bufferevent_disable(bev, EV_READ); -} - -static void -done_writing_cb(struct bufferevent *bev, void *ctx) -{ - struct evbuffer *b = bufferevent_get_output(bev); - if (evbuffer_get_length(b)) - return; - TT_BLATHER(("Done writing.")); - bufferevent_disable(bev, EV_WRITE); - bufferevent_enable(bev, EV_READ); -} - -static void -eventcb(struct bufferevent *bev, short what, void *ctx) -{ - enum regress_openssl_type type; - type = (enum regress_openssl_type)ctx; - - TT_BLATHER(("Got event %d", (int)what)); - if (what & BEV_EVENT_CONNECTED) { - SSL *ssl; - X509 *peer_cert; - ++n_connected; - ssl = bufferevent_openssl_get_ssl(bev); - tt_assert(ssl); - peer_cert = SSL_get_peer_certificate(ssl); - if (type & REGRESS_OPENSSL_SERVER) { - tt_assert(peer_cert == NULL); - } else { - tt_assert(peer_cert != NULL); - } - if (stop_when_connected) { - if (--pending_connect_events == 0) - event_base_loopexit(exit_base, NULL); - } - } else if (what & BEV_EVENT_EOF) { - TT_BLATHER(("Got a good EOF")); - ++got_close; - if (type & REGRESS_OPENSSL_FD) { - bufferevent_openssl_check_fd(bev, type & REGRESS_OPENSSL_FILTER); - } - if (type & REGRESS_OPENSSL_FREED) { - bufferevent_openssl_check_freed(bev); - } - bufferevent_free(bev); - } else if (what & BEV_EVENT_ERROR) { - TT_BLATHER(("Got an error.")); - ++got_error; - if (type & REGRESS_OPENSSL_FD) { - bufferevent_openssl_check_fd(bev, type & REGRESS_OPENSSL_FILTER); - } - if (type & REGRESS_OPENSSL_FREED) { - bufferevent_openssl_check_freed(bev); - } - bufferevent_free(bev); - } else if (what & BEV_EVENT_TIMEOUT) { - TT_BLATHER(("Got timeout.")); - ++got_timeout; - if (type & REGRESS_OPENSSL_FD) { - bufferevent_openssl_check_fd(bev, type & REGRESS_OPENSSL_FILTER); - } - if (type & REGRESS_OPENSSL_FREED) { - bufferevent_openssl_check_freed(bev); - } - bufferevent_free(bev); - } -end: - ; -} - -static void -open_ssl_bufevs(struct bufferevent **bev1_out, struct bufferevent **bev2_out, - struct event_base *base, int is_open, int flags, SSL *ssl1, SSL *ssl2, - evutil_socket_t *fd_pair, struct bufferevent **underlying_pair, - enum regress_openssl_type type) -{ - int state1 = is_open ? BUFFEREVENT_SSL_OPEN :BUFFEREVENT_SSL_CONNECTING; - int state2 = is_open ? BUFFEREVENT_SSL_OPEN :BUFFEREVENT_SSL_ACCEPTING; - int dirty_shutdown = type & REGRESS_OPENSSL_DIRTY_SHUTDOWN; - if (fd_pair) { - *bev1_out = bufferevent_openssl_socket_new( - base, fd_pair[0], ssl1, state1, flags); - *bev2_out = bufferevent_openssl_socket_new( - base, fd_pair[1], ssl2, state2, flags); - } else { - *bev1_out = bufferevent_openssl_filter_new( - base, underlying_pair[0], ssl1, state1, flags); - *bev2_out = bufferevent_openssl_filter_new( - base, underlying_pair[1], ssl2, state2, flags); - - } - bufferevent_setcb(*bev1_out, respond_to_number, done_writing_cb, - eventcb, (void*)(REGRESS_OPENSSL_CLIENT | (long)type)); - bufferevent_setcb(*bev2_out, respond_to_number, done_writing_cb, - eventcb, (void*)(REGRESS_OPENSSL_SERVER | (long)type)); - - bufferevent_openssl_set_allow_dirty_shutdown(*bev1_out, dirty_shutdown); - bufferevent_openssl_set_allow_dirty_shutdown(*bev2_out, dirty_shutdown); -} - -static void -regress_bufferevent_openssl(void *arg) -{ - struct basic_test_data *data = arg; - - struct bufferevent *bev1, *bev2; - SSL *ssl1, *ssl2; - X509 *cert = ssl_getcert(); - EVP_PKEY *key = ssl_getkey(); - int flags = BEV_OPT_DEFER_CALLBACKS; - struct bufferevent *bev_ll[2] = { NULL, NULL }; - evutil_socket_t *fd_pair = NULL; - - enum regress_openssl_type type; - type = (enum regress_openssl_type)data->setup_data; - - tt_assert(cert); - tt_assert(key); - - init_ssl(); - - if (type & REGRESS_OPENSSL_RENEGOTIATE) { - if (SSLeay() >= 0x10001000 && - SSLeay() < 0x1000104f) { - /* 1.0.1 up to 1.0.1c has a bug where TLS1.1 and 1.2 - * can't renegotiate with themselves. Disable. */ - disable_tls_11_and_12 = 1; - } - renegotiate_at = 600; - } - - ssl1 = SSL_new(get_ssl_ctx()); - ssl2 = SSL_new(get_ssl_ctx()); - - SSL_use_certificate(ssl2, cert); - SSL_use_PrivateKey(ssl2, key); - - if (!(type & REGRESS_OPENSSL_OPEN)) - flags |= BEV_OPT_CLOSE_ON_FREE; - - if (!(type & REGRESS_OPENSSL_FILTER)) { - tt_assert(type & REGRESS_OPENSSL_SOCKETPAIR); - fd_pair = data->pair; - } else { - bev_ll[0] = bufferevent_socket_new(data->base, data->pair[0], - BEV_OPT_CLOSE_ON_FREE); - bev_ll[1] = bufferevent_socket_new(data->base, data->pair[1], - BEV_OPT_CLOSE_ON_FREE); - } - - open_ssl_bufevs(&bev1, &bev2, data->base, 0, flags, ssl1, ssl2, - fd_pair, bev_ll, type); - - if (!(type & REGRESS_OPENSSL_FILTER)) { - tt_int_op(bufferevent_getfd(bev1), ==, data->pair[0]); - } else { - tt_ptr_op(bufferevent_get_underlying(bev1), ==, bev_ll[0]); - } - - if (type & REGRESS_OPENSSL_OPEN) { - pending_connect_events = 2; - stop_when_connected = 1; - exit_base = data->base; - event_base_dispatch(data->base); - /* Okay, now the renegotiation is done. Make new - * bufferevents to test opening in BUFFEREVENT_SSL_OPEN */ - flags |= BEV_OPT_CLOSE_ON_FREE; - bufferevent_free(bev1); - bufferevent_free(bev2); - bev1 = bev2 = NULL; - open_ssl_bufevs(&bev1, &bev2, data->base, 1, flags, ssl1, ssl2, - fd_pair, bev_ll, type); - } - - if (!(type & REGRESS_OPENSSL_TIMEOUT)) { - bufferevent_enable(bev1, EV_READ|EV_WRITE); - bufferevent_enable(bev2, EV_READ|EV_WRITE); - - evbuffer_add_printf(bufferevent_get_output(bev1), "1\n"); - - event_base_dispatch(data->base); - - tt_assert(test_is_done == 1); - tt_assert(n_connected == 2); - - /* We don't handle shutdown properly yet */ - if (type & REGRESS_OPENSSL_DIRTY_SHUTDOWN) { - tt_int_op(got_close, ==, 1); - tt_int_op(got_error, ==, 0); - } else { - tt_int_op(got_error, ==, 1); - } - tt_int_op(got_timeout, ==, 0); - } else { - struct timeval t = { 2, 0 }; - - bufferevent_enable(bev1, EV_READ|EV_WRITE); - bufferevent_disable(bev2, EV_READ|EV_WRITE); - - bufferevent_set_timeouts(bev1, &t, &t); - - evbuffer_add_printf(bufferevent_get_output(bev1), "1\n"); - - event_base_dispatch(data->base); - - tt_assert(test_is_done == 0); - tt_assert(n_connected == 0); - - tt_int_op(got_close, ==, 0); - tt_int_op(got_error, ==, 0); - tt_int_op(got_timeout, ==, 1); - } -end: - return; -} - -static void -acceptcb_deferred(evutil_socket_t fd, short events, void *arg) -{ - struct bufferevent *bev = arg; - bufferevent_enable(bev, EV_READ|EV_WRITE); -} -static void -acceptcb(struct evconnlistener *listener, evutil_socket_t fd, - struct sockaddr *addr, int socklen, void *arg) -{ - struct basic_test_data *data = arg; - struct bufferevent *bev; - enum regress_openssl_type type; - SSL *ssl = SSL_new(get_ssl_ctx()); - - type = (enum regress_openssl_type)data->setup_data; - - SSL_use_certificate(ssl, ssl_getcert()); - SSL_use_PrivateKey(ssl, ssl_getkey()); - - bev = bufferevent_openssl_socket_new( - data->base, - fd, - ssl, - BUFFEREVENT_SSL_ACCEPTING, - BEV_OPT_CLOSE_ON_FREE|BEV_OPT_DEFER_CALLBACKS); - - bufferevent_setcb(bev, respond_to_number, NULL, eventcb, - (void*)(REGRESS_OPENSSL_SERVER)); - - if (type & REGRESS_OPENSSL_SLEEP) { - struct timeval when = { 1, 0 }; - event_base_once(data->base, -1, EV_TIMEOUT, - acceptcb_deferred, bev, &when); - bufferevent_disable(bev, EV_READ|EV_WRITE); - } else { - bufferevent_enable(bev, EV_READ|EV_WRITE); - } - - /* Only accept once, then disable ourself. */ - evconnlistener_disable(listener); -} - -struct rwcount -{ - int fd; - size_t read; - size_t write; -}; -static int -bio_rwcount_new(BIO *b) -{ - b->init = 0; - b->num = -1; - b->ptr = NULL; - b->flags = 0; - return 1; -} -static int -bio_rwcount_free(BIO *b) -{ - if (!b) - return 0; - if (b->shutdown) { - b->init = 0; - b->flags = 0; - b->ptr = NULL; - } - return 1; -} -static int -bio_rwcount_read(BIO *b, char *out, int outlen) -{ - struct rwcount *rw = b->ptr; - ev_ssize_t ret = read(rw->fd, out, outlen); - ++rw->read; - if (ret == -1 && errno == EAGAIN) { - BIO_set_retry_read(b); - } - return ret; -} -static int -bio_rwcount_write(BIO *b, const char *in, int inlen) -{ - - struct rwcount *rw = b->ptr; - ev_ssize_t ret = write(rw->fd, in, inlen); - ++rw->write; - if (ret == -1 && errno == EAGAIN) { - BIO_set_retry_write(b); - } - return ret; -} -static long -bio_rwcount_ctrl(BIO *b, int cmd, long num, void *ptr) -{ - long ret = 0; - switch (cmd) { - case BIO_CTRL_GET_CLOSE: - ret = b->shutdown; - break; - case BIO_CTRL_SET_CLOSE: - b->shutdown = (int)num; - break; - case BIO_CTRL_PENDING: - ret = 0; - break; - case BIO_CTRL_WPENDING: - ret = 0; - break; - case BIO_CTRL_DUP: - case BIO_CTRL_FLUSH: - ret = 1; - break; - } - return ret; -} -static int -bio_rwcount_puts(BIO *b, const char *s) -{ - return bio_rwcount_write(b, s, strlen(s)); -} -#define BIO_TYPE_LIBEVENT_RWCOUNT 0xff1 -static BIO_METHOD methods_rwcount = { - BIO_TYPE_LIBEVENT_RWCOUNT, "rwcount", - bio_rwcount_write, - bio_rwcount_read, - bio_rwcount_puts, - NULL /* bio_rwcount_gets */, - bio_rwcount_ctrl, - bio_rwcount_new, - bio_rwcount_free, - NULL /* callback_ctrl */, -}; -static BIO_METHOD * -BIO_s_rwcount(void) -{ - return &methods_rwcount; -} -static BIO * -BIO_new_rwcount(int close_flag) -{ - BIO *result; - if (!(result = BIO_new(BIO_s_rwcount()))) - return NULL; - result->init = 1; - result->ptr = NULL; - result->shutdown = !!close_flag; - return result; -} - -static void -regress_bufferevent_openssl_connect(void *arg) -{ - struct basic_test_data *data = arg; - - struct event_base *base = data->base; - - struct evconnlistener *listener; - struct bufferevent *bev; - struct sockaddr_in sin; - struct sockaddr_storage ss; - ev_socklen_t slen; - SSL *ssl; - BIO *bio; - struct rwcount rw = { -1, 0, 0 }; - enum regress_openssl_type type; - - type = (enum regress_openssl_type)data->setup_data; - - init_ssl(); - - memset(&sin, 0, sizeof(sin)); - sin.sin_family = AF_INET; - sin.sin_addr.s_addr = htonl(0x7f000001); - - memset(&ss, 0, sizeof(ss)); - slen = sizeof(ss); - - listener = evconnlistener_new_bind(base, acceptcb, data, - LEV_OPT_CLOSE_ON_FREE|LEV_OPT_REUSEABLE, - -1, (struct sockaddr *)&sin, sizeof(sin)); - - tt_assert(listener); - tt_assert(evconnlistener_get_fd(listener) >= 0); - - ssl = SSL_new(get_ssl_ctx()); - tt_assert(ssl); - - bev = bufferevent_openssl_socket_new( - data->base, -1, ssl, - BUFFEREVENT_SSL_CONNECTING, - BEV_OPT_CLOSE_ON_FREE|BEV_OPT_DEFER_CALLBACKS); - tt_assert(bev); - - bufferevent_setcb(bev, respond_to_number, NULL, eventcb, - (void*)(REGRESS_OPENSSL_CLIENT)); - - tt_assert(getsockname(evconnlistener_get_fd(listener), - (struct sockaddr*)&ss, &slen) == 0); - tt_assert(slen == sizeof(struct sockaddr_in)); - tt_int_op(((struct sockaddr*)&ss)->sa_family, ==, AF_INET); - - tt_assert(0 == - bufferevent_socket_connect(bev, (struct sockaddr*)&ss, slen)); - /* Possible only when we have fd, since be_openssl can and will overwrite - * bio otherwise before */ - if (type & REGRESS_OPENSSL_SLEEP) { - rw.fd = bufferevent_getfd(bev); - bio = BIO_new_rwcount(0); - tt_assert(bio); - bio->ptr = &rw; - SSL_set_bio(ssl, bio, bio); - } - evbuffer_add_printf(bufferevent_get_output(bev), "1\n"); - bufferevent_enable(bev, EV_READ|EV_WRITE); - - event_base_dispatch(base); - - tt_int_op(rw.read, <=, 100); - tt_int_op(rw.write, <=, 100); -end: - ; -} - -struct testcase_t ssl_testcases[] = { -#define T(a) ((void *)(a)) - { "bufferevent_socketpair", regress_bufferevent_openssl, - TT_ISOLATED, &basic_setup, T(REGRESS_OPENSSL_SOCKETPAIR) }, - { "bufferevent_filter", regress_bufferevent_openssl, - TT_ISOLATED, &basic_setup, T(REGRESS_OPENSSL_FILTER) }, - { "bufferevent_renegotiate_socketpair", regress_bufferevent_openssl, - TT_ISOLATED, &basic_setup, - T(REGRESS_OPENSSL_SOCKETPAIR | REGRESS_OPENSSL_RENEGOTIATE) }, - { "bufferevent_renegotiate_filter", regress_bufferevent_openssl, - TT_ISOLATED, &basic_setup, - T(REGRESS_OPENSSL_FILTER | REGRESS_OPENSSL_RENEGOTIATE) }, - { "bufferevent_socketpair_startopen", regress_bufferevent_openssl, - TT_ISOLATED, &basic_setup, - T(REGRESS_OPENSSL_SOCKETPAIR | REGRESS_OPENSSL_OPEN) }, - { "bufferevent_filter_startopen", regress_bufferevent_openssl, - TT_ISOLATED, &basic_setup, - T(REGRESS_OPENSSL_FILTER | REGRESS_OPENSSL_OPEN) }, - - { "bufferevent_socketpair_dirty_shutdown", regress_bufferevent_openssl, - TT_ISOLATED, &basic_setup, - T(REGRESS_OPENSSL_SOCKETPAIR | REGRESS_OPENSSL_DIRTY_SHUTDOWN) }, - { "bufferevent_filter_dirty_shutdown", regress_bufferevent_openssl, - TT_ISOLATED, &basic_setup, - T(REGRESS_OPENSSL_FILTER | REGRESS_OPENSSL_DIRTY_SHUTDOWN) }, - { "bufferevent_renegotiate_socketpair_dirty_shutdown", - regress_bufferevent_openssl, - TT_ISOLATED, - &basic_setup, - T(REGRESS_OPENSSL_SOCKETPAIR | REGRESS_OPENSSL_RENEGOTIATE | REGRESS_OPENSSL_DIRTY_SHUTDOWN) }, - { "bufferevent_renegotiate_filter_dirty_shutdown", - regress_bufferevent_openssl, - TT_ISOLATED, - &basic_setup, - T(REGRESS_OPENSSL_FILTER | REGRESS_OPENSSL_RENEGOTIATE | REGRESS_OPENSSL_DIRTY_SHUTDOWN) }, - { "bufferevent_socketpair_startopen_dirty_shutdown", - regress_bufferevent_openssl, - TT_ISOLATED, &basic_setup, - T(REGRESS_OPENSSL_SOCKETPAIR | REGRESS_OPENSSL_OPEN | REGRESS_OPENSSL_DIRTY_SHUTDOWN) }, - { "bufferevent_filter_startopen_dirty_shutdown", - regress_bufferevent_openssl, - TT_ISOLATED, &basic_setup, - T(REGRESS_OPENSSL_FILTER | REGRESS_OPENSSL_OPEN | REGRESS_OPENSSL_DIRTY_SHUTDOWN) }, - - { "bufferevent_socketpair_fd", regress_bufferevent_openssl, - TT_ISOLATED, &basic_setup, - T(REGRESS_OPENSSL_SOCKETPAIR | REGRESS_OPENSSL_FD) }, - { "bufferevent_socketpair_freed", regress_bufferevent_openssl, - TT_ISOLATED, &basic_setup, - T(REGRESS_OPENSSL_SOCKETPAIR | REGRESS_OPENSSL_FREED) }, - { "bufferevent_socketpair_freed_fd", regress_bufferevent_openssl, - TT_ISOLATED, &basic_setup, - T(REGRESS_OPENSSL_SOCKETPAIR | REGRESS_OPENSSL_FREED | REGRESS_OPENSSL_FD) }, - { "bufferevent_filter_freed_fd", regress_bufferevent_openssl, - TT_ISOLATED, &basic_setup, - T(REGRESS_OPENSSL_FILTER | REGRESS_OPENSSL_FREED | REGRESS_OPENSSL_FD) }, - - { "bufferevent_socketpair_timeout", regress_bufferevent_openssl, - TT_ISOLATED, &basic_setup, - T(REGRESS_OPENSSL_SOCKETPAIR | REGRESS_OPENSSL_TIMEOUT) }, - { "bufferevent_socketpair_timeout_freed_fd", regress_bufferevent_openssl, - TT_ISOLATED, &basic_setup, - T(REGRESS_OPENSSL_SOCKETPAIR | REGRESS_OPENSSL_TIMEOUT | REGRESS_OPENSSL_FREED | REGRESS_OPENSSL_FD) }, - - { "bufferevent_connect", regress_bufferevent_openssl_connect, - TT_FORK|TT_NEED_BASE, &basic_setup, NULL }, - { "bufferevent_connect_sleep", regress_bufferevent_openssl_connect, - TT_FORK|TT_NEED_BASE, &basic_setup, T(REGRESS_OPENSSL_SLEEP) }, - -#undef T - - END_OF_TESTCASES, -}; |