# Test that SSL sample programs can interoperate with OpenSSL and GnuTLS. # Copyright The Mbed TLS Contributors # SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later : ${PROGRAMS_DIR:=../programs/ssl} requires_protocol_version tls12 run_test "Sample: ssl_client1, openssl server, TLS 1.2" \ -P 4433 \ "$O_SRV -tls1_2" \ "$PROGRAMS_DIR/ssl_client1" \ 0 \ -c "Protocol.*TLSv1.2" \ -S "ERROR" \ -C "error" requires_protocol_version tls12 run_test "Sample: ssl_client1, gnutls server, TLS 1.2" \ -P 4433 \ "$G_SRV --priority=NORMAL:-VERS-TLS-ALL:+VERS-TLS1.2" \ "$PROGRAMS_DIR/ssl_client1" \ 0 \ -s "Version: TLS1.2" \ -c "Protocol version:TLS1.2" \ -S "Error" \ -C "error" requires_protocol_version tls13 requires_openssl_tls1_3 run_test "Sample: ssl_client1, openssl server, TLS 1.3" \ -P 4433 \ "$O_NEXT_SRV -tls1_3" \ "$PROGRAMS_DIR/ssl_client1" \ 0 \ -c "New, TLSv1.3, Cipher is" \ -S "ERROR" \ -C "error" requires_protocol_version tls13 requires_gnutls_tls1_3 run_test "Sample: ssl_client1, gnutls server, TLS 1.3" \ -P 4433 \ "$G_NEXT_SRV --priority=NORMAL:-VERS-TLS-ALL:+VERS-TLS1.3" \ "$PROGRAMS_DIR/ssl_client1" \ 0 \ -s "Version: TLS1.3" \ -c "Protocol version:TLS1.3" \ -S "Error" \ -C "error" requires_protocol_version dtls12 run_test "Sample: dtls_client, openssl server, DTLS 1.2" \ -P 4433 \ "$O_SRV -dtls1_2" \ "$PROGRAMS_DIR/dtls_client" \ 0 \ -s "Echo this" \ -c "Echo this" \ -c "[1-9][0-9]* bytes written" \ -c "[1-9][0-9]* bytes read" \ -S "ERROR" \ -C "error" requires_protocol_version dtls12 run_test "Sample: dtls_client, gnutls server, DTLS 1.2" \ -P 4433 \ "$G_SRV -u --echo --priority=NORMAL:-VERS-TLS-ALL:+VERS-TLS1.2" \ "$PROGRAMS_DIR/dtls_client" \ 0 \ -s "Server listening" \ -s "[1-9][0-9]* bytes command:" \ -c "Echo this" \ -c "[1-9][0-9]* bytes written" \ -c "[1-9][0-9]* bytes read" \ -S "Error" \ -C "error" requires_protocol_version tls12 run_test "Sample: ssl_server, openssl client, TLS 1.2" \ -P 4433 \ "$PROGRAMS_DIR/ssl_server" \ "$O_CLI -tls1_2" \ 0 \ -s "Successful connection using: TLS-" \ -c "Protocol.*TLSv1.2" \ -S "error" \ -C "ERROR" requires_protocol_version tls12 run_test "Sample: ssl_server, gnutls client, TLS 1.2" \ -P 4433 \ "$PROGRAMS_DIR/ssl_server" \ "$G_CLI --priority=NORMAL:-VERS-TLS-ALL:+VERS-TLS1.2 localhost" \ 0 \ -s "Successful connection using: TLS-" \ -c "Description:.*TLS1.2" \ -S "error" \ -C "ERROR" requires_protocol_version tls13 requires_openssl_tls1_3 run_test "Sample: ssl_server, openssl client, TLS 1.3" \ -P 4433 \ "$PROGRAMS_DIR/ssl_server" \ "$O_NEXT_CLI -tls1_3" \ 0 \ -s "Successful connection using: TLS1-3-" \ -c "New, TLSv1.3, Cipher is" \ -S "error" \ -C "ERROR" requires_protocol_version tls13 requires_gnutls_tls1_3 run_test "Sample: ssl_server, gnutls client, TLS 1.3" \ -P 4433 \ "$PROGRAMS_DIR/ssl_server" \ "$G_NEXT_CLI --priority=NORMAL:-VERS-TLS-ALL:+VERS-TLS1.3 localhost" \ 0 \ -s "Successful connection using: TLS1-3-" \ -c "Description:.*TLS1.3" \ -S "error" \ -C "ERROR" requires_protocol_version tls12 run_test "Sample: ssl_fork_server, openssl client, TLS 1.2" \ -P 4433 \ "$PROGRAMS_DIR/ssl_fork_server" \ "$O_CLI -tls1_2" \ 0 \ -s "Successful connection using: TLS-" \ -c "Protocol.*TLSv1.2" \ -S "error" \ -C "ERROR" requires_protocol_version tls12 run_test "Sample: ssl_fork_server, gnutls client, TLS 1.2" \ -P 4433 \ "$PROGRAMS_DIR/ssl_fork_server" \ "$G_CLI --priority=NORMAL:-VERS-TLS-ALL:+VERS-TLS1.2 localhost" \ 0 \ -s "Successful connection using: TLS-" \ -c "Description:.*TLS1.2" \ -S "error" \ -C "ERROR" requires_protocol_version tls13 requires_openssl_tls1_3 run_test "Sample: ssl_fork_server, openssl client, TLS 1.3" \ -P 4433 \ "$PROGRAMS_DIR/ssl_fork_server" \ "$O_NEXT_CLI -tls1_3" \ 0 \ -s "Successful connection using: TLS1-3-" \ -c "New, TLSv1.3, Cipher is" \ -S "error" \ -C "ERROR" requires_protocol_version tls13 requires_gnutls_tls1_3 run_test "Sample: ssl_fork_server, gnutls client, TLS 1.3" \ -P 4433 \ "$PROGRAMS_DIR/ssl_fork_server" \ "$G_NEXT_CLI --priority=NORMAL:-VERS-TLS-ALL:+VERS-TLS1.3 localhost" \ 0 \ -s "Successful connection using: TLS1-3-" \ -c "Description:.*TLS1.3" \ -S "error" \ -C "ERROR" requires_protocol_version tls12 run_test "Sample: ssl_pthread_server, openssl client, TLS 1.2" \ -P 4433 \ "$PROGRAMS_DIR/ssl_pthread_server" \ "$O_CLI -tls1_2" \ 0 \ -s "Successful connection using: TLS-" \ -c "Protocol.*TLSv1.2" \ -S "error" \ -C "ERROR" requires_protocol_version tls12 run_test "Sample: ssl_pthread_server, gnutls client, TLS 1.2" \ -P 4433 \ "$PROGRAMS_DIR/ssl_pthread_server" \ "$G_CLI --priority=NORMAL:-VERS-TLS-ALL:+VERS-TLS1.2 localhost" \ 0 \ -s "Successful connection using: TLS-" \ -c "Description:.*TLS1.2" \ -S "error" \ -C "ERROR" requires_protocol_version tls13 requires_openssl_tls1_3 run_test "Sample: ssl_pthread_server, openssl client, TLS 1.3" \ -P 4433 \ "$PROGRAMS_DIR/ssl_pthread_server" \ "$O_NEXT_CLI -tls1_3" \ 0 \ -s "Successful connection using: TLS1-3-" \ -c "New, TLSv1.3, Cipher is" \ -S "error" \ -C "ERROR" requires_protocol_version tls13 requires_gnutls_tls1_3 run_test "Sample: ssl_pthread_server, gnutls client, TLS 1.3" \ -P 4433 \ "$PROGRAMS_DIR/ssl_pthread_server" \ "$G_NEXT_CLI --priority=NORMAL:-VERS-TLS-ALL:+VERS-TLS1.3 localhost" \ 0 \ -s "Successful connection using: TLS1-3-" \ -c "Description:.*TLS1.3" \ -S "error" \ -C "ERROR" requires_protocol_version dtls12 run_test "Sample: dtls_server, openssl client, DTLS 1.2" \ -P 4433 \ "$PROGRAMS_DIR/dtls_server" \ "$O_CLI -dtls1_2" \ 0 \ -s "[1-9][0-9]* bytes read" \ -s "[1-9][0-9]* bytes written" \ -c "Protocol.*TLSv1.2" \ -S "error" \ -C "ERROR" requires_protocol_version dtls12 run_test "Sample: dtls_server, gnutls client, DTLS 1.2" \ -P 4433 \ "$PROGRAMS_DIR/dtls_server" \ "$G_CLI -u --priority=NORMAL:-VERS-TLS-ALL:+VERS-TLS1.2 localhost" \ 0 \ -s "[1-9][0-9]* bytes read" \ -s "[1-9][0-9]* bytes written" \ -c "Description:.*DTLS1.2" \ -S "error" \ -C "ERROR"