/* This file is part of libmicrohttpd Copyright (C) 2007 Christian Grothoff libmicrohttpd is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2, or (at your option) any later version. libmicrohttpd is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with libmicrohttpd; see the file COPYING. If not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #ifndef TLS_TEST_COMMON_H_ #define TLS_TEST_COMMON_H_ #include "platform.h" #include "microhttpd.h" #include <curl/curl.h> #include <sys/stat.h> #include <limits.h> #include <gnutls/gnutls.h> /* this enables verbos CURL version checking */ #define DEBUG_HTTPS_TEST 0 #define CURL_VERBOS_LEVEL 0 #define DEAMON_TEST_PORT 4233 #define test_data "Hello World\n" #define ca_cert_file_name "tmp_ca_cert.pem" #define EMPTY_PAGE "<html><head><title>Empty page</title></head><body>Empty page</body></html>" #define PAGE_NOT_FOUND "<html><head><title>File not found</title></head><body>File not found</body></html>" #define MHD_E_MEM "Error: memory error\n" #define MHD_E_SERVER_INIT "Error: failed to start server\n" #define MHD_E_TEST_FILE_CREAT "Error: failed to setup test file\n" #define MHD_E_CERT_FILE_CREAT "Error: failed to setup test certificate\n" #define MHD_E_KEY_FILE_CREAT "Error: failed to setup test certificate\n" #define MHD_E_FAILED_TO_CONNECT "Error: server connection could not be established\n" /* TODO rm if unused */ struct https_test_data { void *cls; const char *cipher_suite; int proto_version; }; struct CBC { char *buf; size_t pos; size_t size; }; struct CipherDef { int options[2]; char *curlname; }; int curl_check_version (const char *req_version, ...); int curl_uses_nss_ssl (); FILE * setup_ca_cert (); /** * perform cURL request for file */ int test_daemon_get (void * cls, const char *cipher_suite, int proto_version, int port, int ver_peer); void print_test_result (int test_outcome, char *test_name); size_t copyBuffer (void *ptr, size_t size, size_t nmemb, void *ctx); int http_ahc (void *cls, struct MHD_Connection *connection, const char *url, const char *method, const char *upload_data, const char *version, size_t *upload_data_size, void **ptr); int http_dummy_ahc (void *cls, struct MHD_Connection *connection, const char *url, const char *method, const char *upload_data, const char *version, size_t *upload_data_size, void **ptr); /** * compile test file url pointing to the current running directory path * * @param url - char buffer into which the url is compiled * @param port port to use for the test * @return -1 on error */ int gen_test_file_url (char *url, int port); int send_curl_req (char *url, struct CBC *cbc, const char *cipher_suite, int proto_version); int test_https_transfer (void *cls, const char *cipher_suite, int proto_version); int setup_testcase (struct MHD_Daemon **d, int daemon_flags, va_list arg_list); void teardown_testcase (struct MHD_Daemon *d); int setup_session (gnutls_session_t * session, gnutls_datum_t * key, gnutls_datum_t * cert, gnutls_certificate_credentials_t * xcred); int teardown_session (gnutls_session_t session, gnutls_datum_t * key, gnutls_datum_t * cert, gnutls_certificate_credentials_t xcred); int test_wrap (const char *test_name, int (*test_function) (void * cls, const char *cipher_suite, int proto_version), void *test_function_cls, int daemon_flags, const char *cipher_suite, int proto_version, ...); #endif /* TLS_TEST_COMMON_H_ */