e0e7d0da68
The new V2ClientHello sniff asserts, for safety, that nothing else has initialized the record layer before it runs. However, OpenSSL allows you to avoid explicitly calling SSL_connect/SSL_accept and instead let SSL_read/SSL_write implicitly handshake for you. This check happens at a fairly low-level in the ssl3_read_bytes function, at which point the record layer has already been initialized. Add some tests to ensure this mode works. (Later we'll lift the handshake check to a higher-level which is probably simpler.) Change-Id: Ibeb7fb78e5eb75af5411ba15799248d94f12820b Reviewed-on: https://boringssl-review.googlesource.com/3334 Reviewed-by: Adam Langley <agl@google.com>
77 lines
2.2 KiB
C++
77 lines
2.2 KiB
C++
/* Copyright (c) 2014, Google Inc.
|
|
*
|
|
* Permission to use, copy, modify, and/or distribute this software for any
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
* copyright notice and this permission notice appear in all copies.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
|
|
* SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
|
|
* OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
|
|
* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */
|
|
|
|
#ifndef HEADER_TEST_CONFIG
|
|
#define HEADER_TEST_CONFIG
|
|
|
|
#include <string>
|
|
|
|
|
|
struct TestConfig {
|
|
TestConfig();
|
|
|
|
bool is_server;
|
|
bool is_dtls;
|
|
bool resume;
|
|
bool fallback_scsv;
|
|
std::string key_file;
|
|
std::string cert_file;
|
|
std::string expected_server_name;
|
|
std::string expected_certificate_types;
|
|
bool require_any_client_certificate;
|
|
std::string advertise_npn;
|
|
std::string expected_next_proto;
|
|
bool false_start;
|
|
std::string select_next_proto;
|
|
bool async;
|
|
bool write_different_record_sizes;
|
|
bool cbc_record_splitting;
|
|
bool partial_write;
|
|
bool no_tls12;
|
|
bool no_tls11;
|
|
bool no_tls1;
|
|
bool no_ssl3;
|
|
bool cookie_exchange;
|
|
std::string expected_channel_id;
|
|
std::string send_channel_id;
|
|
bool shim_writes_first;
|
|
bool tls_d5_bug;
|
|
std::string host_name;
|
|
std::string advertise_alpn;
|
|
std::string expected_alpn;
|
|
std::string expected_advertised_alpn;
|
|
std::string select_alpn;
|
|
bool expect_session_miss;
|
|
bool expect_extended_master_secret;
|
|
std::string psk;
|
|
std::string psk_identity;
|
|
bool renegotiate;
|
|
bool allow_unsafe_legacy_renegotiation;
|
|
std::string srtp_profiles;
|
|
bool enable_ocsp_stapling;
|
|
std::string expected_ocsp_response;
|
|
bool enable_signed_cert_timestamps;
|
|
std::string expected_signed_cert_timestamps;
|
|
bool fastradio_padding;
|
|
int min_version;
|
|
int max_version;
|
|
int mtu;
|
|
bool implicit_handshake;
|
|
};
|
|
|
|
bool ParseConfig(int argc, char **argv, TestConfig *out_config);
|
|
|
|
|
|
#endif // HEADER_TEST_CONFIG
|