blob: f30384d39fe48d59364254cf0a1f5bf4018424b8 [file] [log] [blame]
Jerry Yue5991322022-11-07 14:03:44 +08001#!/bin/sh
2
3# tls13-misc.sh
4#
5# Copyright The Mbed TLS Contributors
6# SPDX-License-Identifier: Apache-2.0
7#
8# Licensed under the Apache License, Version 2.0 (the "License"); you may
9# not use this file except in compliance with the License.
10# You may obtain a copy of the License at
11#
12# http://www.apache.org/licenses/LICENSE-2.0
13#
14# Unless required by applicable law or agreed to in writing, software
15# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
16# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17# See the License for the specific language governing permissions and
18# limitations under the License.
19#
20
21requires_gnutls_tls1_3
Jerry Yu616ba752022-11-08 21:49:47 +080022requires_config_enabled MBEDTLS_SSL_PROTO_TLS1_3
23requires_config_enabled MBEDTLS_SSL_TLS1_3_COMPATIBILITY_MODE
24requires_config_enabled MBEDTLS_SSL_SRV_C
25requires_config_enabled MBEDTLS_DEBUG_C
26requires_config_enabled MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_ENABLED
27
28run_test "TLS 1.3: PSK: No valid ciphersuite. G->m" \
Ronald Cron50ae84e2023-03-14 08:59:56 +010029 "$P_SRV tls13_kex_modes=all debug_level=5 $(get_srv_psk_list)" \
Jerry Yu616ba752022-11-08 21:49:47 +080030 "$G_NEXT_CLI -d 10 --priority NORMAL:-VERS-ALL:-CIPHER-ALL:+AES-256-GCM:+AEAD:+SHA384:-KX-ALL:+ECDHE-PSK:+DHE-PSK:+PSK:+VERS-TLS1.3 \
31 --pskusername Client_identity --pskkey=6162636465666768696a6b6c6d6e6f70 \
32 localhost" \
33 1 \
34 -s "found psk key exchange modes extension" \
35 -s "found pre_shared_key extension" \
36 -s "Found PSK_EPHEMERAL KEX MODE" \
37 -s "Found PSK KEX MODE" \
38 -s "No matched ciphersuite"
39
40requires_openssl_tls1_3
41requires_config_enabled MBEDTLS_SSL_PROTO_TLS1_3
42requires_config_enabled MBEDTLS_SSL_TLS1_3_COMPATIBILITY_MODE
43requires_config_enabled MBEDTLS_SSL_SRV_C
44requires_config_enabled MBEDTLS_DEBUG_C
45requires_config_enabled MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_ENABLED
46
47run_test "TLS 1.3: PSK: No valid ciphersuite. O->m" \
Ronald Cron50ae84e2023-03-14 08:59:56 +010048 "$P_SRV tls13_kex_modes=all debug_level=5 $(get_srv_psk_list)" \
Jerry Yu616ba752022-11-08 21:49:47 +080049 "$O_NEXT_CLI -tls1_3 -msg -allow_no_dhe_kex -ciphersuites TLS_AES_256_GCM_SHA384\
50 -psk_identity Client_identity -psk 6162636465666768696a6b6c6d6e6f70" \
51 1 \
52 -s "found psk key exchange modes extension" \
53 -s "found pre_shared_key extension" \
54 -s "Found PSK_EPHEMERAL KEX MODE" \
55 -s "Found PSK KEX MODE" \
56 -s "No matched ciphersuite"
57
58requires_all_configs_enabled MBEDTLS_SSL_PROTO_TLS1_3 MBEDTLS_SSL_SESSION_TICKETS MBEDTLS_SSL_SRV_C \
Ronald Cronf5b47062022-12-15 13:46:23 +010059 MBEDTLS_SSL_CLI_C MBEDTLS_DEBUG_C MBEDTLS_HAVE_TIME \
60 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED
Jerry Yu616ba752022-11-08 21:49:47 +080061run_test "TLS 1.3 m->m: Multiple PSKs: valid ticket, reconnect with ticket" \
Ronald Cron50ae84e2023-03-14 08:59:56 +010062 "$P_SRV tls13_kex_modes=psk_ephemeral debug_level=5 psk_identity=Client_identity psk=6162636465666768696a6b6c6d6e6f70 tickets=8" \
63 "$P_CLI tls13_kex_modes=psk_ephemeral debug_level=5 psk_identity=Client_identity psk=6162636465666768696a6b6c6d6e6f70 reco_mode=1 reconnect=1" \
Jerry Yu616ba752022-11-08 21:49:47 +080064 0 \
65 -c "Pre-configured PSK number = 2" \
66 -s "sent selected_identity: 0" \
67 -s "key exchange mode: psk_ephemeral" \
68 -S "key exchange mode: psk$" \
69 -S "key exchange mode: ephemeral$" \
70 -S "ticket is not authentic"
71
72requires_all_configs_enabled MBEDTLS_SSL_PROTO_TLS1_3 MBEDTLS_SSL_SESSION_TICKETS MBEDTLS_SSL_SRV_C \
Ronald Cronf5b47062022-12-15 13:46:23 +010073 MBEDTLS_SSL_CLI_C MBEDTLS_DEBUG_C MBEDTLS_HAVE_TIME \
74 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED
Jerry Yu616ba752022-11-08 21:49:47 +080075run_test "TLS 1.3 m->m: Multiple PSKs: invalid ticket, reconnect with PSK" \
Ronald Cron50ae84e2023-03-14 08:59:56 +010076 "$P_SRV tls13_kex_modes=psk_ephemeral debug_level=5 psk_identity=Client_identity psk=6162636465666768696a6b6c6d6e6f70 tickets=8 dummy_ticket=1" \
77 "$P_CLI tls13_kex_modes=psk_ephemeral debug_level=5 psk_identity=Client_identity psk=6162636465666768696a6b6c6d6e6f70 reco_mode=1 reconnect=1" \
Jerry Yu616ba752022-11-08 21:49:47 +080078 0 \
79 -c "Pre-configured PSK number = 2" \
80 -s "sent selected_identity: 1" \
81 -s "key exchange mode: psk_ephemeral" \
82 -S "key exchange mode: psk$" \
83 -S "key exchange mode: ephemeral$" \
84 -s "ticket is not authentic"
85
86requires_all_configs_enabled MBEDTLS_SSL_PROTO_TLS1_3 MBEDTLS_SSL_SESSION_TICKETS MBEDTLS_SSL_SRV_C \
Ronald Cronf5b47062022-12-15 13:46:23 +010087 MBEDTLS_SSL_CLI_C MBEDTLS_DEBUG_C MBEDTLS_HAVE_TIME \
88 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
89 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED
Jerry Yu616ba752022-11-08 21:49:47 +080090run_test "TLS 1.3 m->m: Session resumption failure, ticket authentication failed." \
Ronald Cron50ae84e2023-03-14 08:59:56 +010091 "$P_SRV debug_level=4 crt_file=data_files/server5.crt key_file=data_files/server5.key tickets=8 dummy_ticket=1" \
Jerry Yu616ba752022-11-08 21:49:47 +080092 "$P_CLI debug_level=4 reco_mode=1 reconnect=1" \
93 0 \
94 -c "Pre-configured PSK number = 1" \
95 -S "sent selected_identity:" \
96 -s "key exchange mode: ephemeral" \
97 -S "key exchange mode: psk_ephemeral" \
98 -S "key exchange mode: psk$" \
99 -s "ticket is not authentic" \
100 -S "ticket is expired" \
101 -S "Invalid ticket start time" \
102 -S "Ticket age exceeds limitation" \
103 -S "Ticket age outside tolerance window"
104
105requires_all_configs_enabled MBEDTLS_SSL_PROTO_TLS1_3 MBEDTLS_SSL_SESSION_TICKETS MBEDTLS_SSL_SRV_C \
Ronald Cronf5b47062022-12-15 13:46:23 +0100106 MBEDTLS_SSL_CLI_C MBEDTLS_DEBUG_C MBEDTLS_HAVE_TIME \
107 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
108 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED
Jerry Yu616ba752022-11-08 21:49:47 +0800109run_test "TLS 1.3 m->m: Session resumption failure, ticket expired." \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100110 "$P_SRV debug_level=4 crt_file=data_files/server5.crt key_file=data_files/server5.key tickets=8 dummy_ticket=2" \
Jerry Yu616ba752022-11-08 21:49:47 +0800111 "$P_CLI debug_level=4 reco_mode=1 reconnect=1" \
112 0 \
113 -c "Pre-configured PSK number = 1" \
114 -S "sent selected_identity:" \
115 -s "key exchange mode: ephemeral" \
116 -S "key exchange mode: psk_ephemeral" \
117 -S "key exchange mode: psk$" \
118 -S "ticket is not authentic" \
119 -s "ticket is expired" \
120 -S "Invalid ticket start time" \
121 -S "Ticket age exceeds limitation" \
122 -S "Ticket age outside tolerance window"
123
124requires_all_configs_enabled MBEDTLS_SSL_PROTO_TLS1_3 MBEDTLS_SSL_SESSION_TICKETS MBEDTLS_SSL_SRV_C \
Ronald Cronf5b47062022-12-15 13:46:23 +0100125 MBEDTLS_SSL_CLI_C MBEDTLS_DEBUG_C MBEDTLS_HAVE_TIME \
126 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
127 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED
Jerry Yu616ba752022-11-08 21:49:47 +0800128run_test "TLS 1.3 m->m: Session resumption failure, invalid start time." \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100129 "$P_SRV debug_level=4 crt_file=data_files/server5.crt key_file=data_files/server5.key tickets=8 dummy_ticket=3" \
Jerry Yu616ba752022-11-08 21:49:47 +0800130 "$P_CLI debug_level=4 reco_mode=1 reconnect=1" \
131 0 \
132 -c "Pre-configured PSK number = 1" \
133 -S "sent selected_identity:" \
134 -s "key exchange mode: ephemeral" \
135 -S "key exchange mode: psk_ephemeral" \
136 -S "key exchange mode: psk$" \
137 -S "ticket is not authentic" \
138 -S "ticket is expired" \
139 -s "Invalid ticket start time" \
140 -S "Ticket age exceeds limitation" \
141 -S "Ticket age outside tolerance window"
142
143requires_all_configs_enabled MBEDTLS_SSL_PROTO_TLS1_3 MBEDTLS_SSL_SESSION_TICKETS MBEDTLS_SSL_SRV_C \
Ronald Cronf5b47062022-12-15 13:46:23 +0100144 MBEDTLS_SSL_CLI_C MBEDTLS_DEBUG_C MBEDTLS_HAVE_TIME \
145 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
146 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED
Jerry Yu616ba752022-11-08 21:49:47 +0800147run_test "TLS 1.3 m->m: Session resumption failure, ticket expired. too old" \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100148 "$P_SRV debug_level=4 crt_file=data_files/server5.crt key_file=data_files/server5.key tickets=8 dummy_ticket=4" \
Jerry Yu616ba752022-11-08 21:49:47 +0800149 "$P_CLI debug_level=4 reco_mode=1 reconnect=1" \
150 0 \
151 -c "Pre-configured PSK number = 1" \
152 -S "sent selected_identity:" \
153 -s "key exchange mode: ephemeral" \
154 -S "key exchange mode: psk_ephemeral" \
155 -S "key exchange mode: psk$" \
156 -S "ticket is not authentic" \
157 -S "ticket is expired" \
158 -S "Invalid ticket start time" \
159 -s "Ticket age exceeds limitation" \
160 -S "Ticket age outside tolerance window"
161
162requires_all_configs_enabled MBEDTLS_SSL_PROTO_TLS1_3 MBEDTLS_SSL_SESSION_TICKETS MBEDTLS_SSL_SRV_C \
Ronald Cronf5b47062022-12-15 13:46:23 +0100163 MBEDTLS_SSL_CLI_C MBEDTLS_DEBUG_C MBEDTLS_HAVE_TIME \
164 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
165 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED
Jerry Yu616ba752022-11-08 21:49:47 +0800166run_test "TLS 1.3 m->m: Session resumption failure, age outside tolerance window, too young." \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100167 "$P_SRV debug_level=4 crt_file=data_files/server5.crt key_file=data_files/server5.key tickets=8 dummy_ticket=5" \
Jerry Yu616ba752022-11-08 21:49:47 +0800168 "$P_CLI debug_level=4 reco_mode=1 reconnect=1" \
169 0 \
170 -c "Pre-configured PSK number = 1" \
171 -S "sent selected_identity:" \
172 -s "key exchange mode: ephemeral" \
173 -S "key exchange mode: psk_ephemeral" \
174 -S "key exchange mode: psk$" \
175 -S "ticket is not authentic" \
176 -S "ticket is expired" \
177 -S "Invalid ticket start time" \
178 -S "Ticket age exceeds limitation" \
179 -s "Ticket age outside tolerance window"
180
181requires_all_configs_enabled MBEDTLS_SSL_PROTO_TLS1_3 MBEDTLS_SSL_SESSION_TICKETS MBEDTLS_SSL_SRV_C \
Ronald Cronf5b47062022-12-15 13:46:23 +0100182 MBEDTLS_SSL_CLI_C MBEDTLS_DEBUG_C MBEDTLS_HAVE_TIME \
183 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
184 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED
Jerry Yu616ba752022-11-08 21:49:47 +0800185run_test "TLS 1.3 m->m: Session resumption failure, age outside tolerance window, too old." \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100186 "$P_SRV debug_level=4 crt_file=data_files/server5.crt key_file=data_files/server5.key tickets=8 dummy_ticket=6" \
Jerry Yu616ba752022-11-08 21:49:47 +0800187 "$P_CLI debug_level=4 reco_mode=1 reconnect=1" \
188 0 \
189 -c "Pre-configured PSK number = 1" \
190 -S "sent selected_identity:" \
191 -s "key exchange mode: ephemeral" \
192 -S "key exchange mode: psk_ephemeral" \
193 -S "key exchange mode: psk$" \
194 -S "ticket is not authentic" \
195 -S "ticket is expired" \
196 -S "Invalid ticket start time" \
197 -S "Ticket age exceeds limitation" \
198 -s "Ticket age outside tolerance window"
199
200requires_gnutls_tls1_3
201requires_all_configs_enabled MBEDTLS_SSL_PROTO_TLS1_3 MBEDTLS_SSL_TLS1_3_COMPATIBILITY_MODE MBEDTLS_SSL_SRV_C MBEDTLS_DEBUG_C
202requires_config_enabled MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_ENABLED
203run_test "TLS 1.3: G->m: ephemeral_all/psk, fail, no common kex mode" \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100204 "$P_SRV tls13_kex_modes=psk debug_level=5 $(get_srv_psk_list)" \
Jerry Yu616ba752022-11-08 21:49:47 +0800205 "$G_NEXT_CLI -d 10 --priority NORMAL:-VERS-ALL:-KX-ALL:+ECDHE-PSK:+DHE-PSK:-PSK:+VERS-TLS1.3 \
206 --pskusername Client_identity --pskkey=6162636465666768696a6b6c6d6e6f70 \
207 localhost" \
208 1 \
209 -s "found psk key exchange modes extension" \
210 -s "found pre_shared_key extension" \
211 -s "Found PSK_EPHEMERAL KEX MODE" \
212 -S "Found PSK KEX MODE" \
213 -S "key exchange mode: psk$" \
214 -S "key exchange mode: psk_ephemeral" \
215 -S "key exchange mode: ephemeral"
216
217requires_gnutls_tls1_3
Jerry Yue5991322022-11-07 14:03:44 +0800218requires_all_configs_enabled MBEDTLS_SSL_PROTO_TLS1_3 MBEDTLS_SSL_SRV_C MBEDTLS_DEBUG_C \
219 MBEDTLS_SSL_TLS1_3_COMPATIBILITY_MODE \
220 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_ENABLED
221requires_all_configs_disabled MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED \
222 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED
223run_test "TLS 1.3: G->m: PSK: configured psk only, good." \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100224 "$P_SRV tls13_kex_modes=all debug_level=5 $(get_srv_psk_list)" \
Jerry Yue5991322022-11-07 14:03:44 +0800225 "$G_NEXT_CLI -d 10 --priority NORMAL:-VERS-ALL:-KX-ALL:+ECDHE-PSK:+DHE-PSK:+PSK:+VERS-TLS1.3:+GROUP-ALL \
226 --pskusername Client_identity --pskkey=6162636465666768696a6b6c6d6e6f70 \
227 localhost" \
228 0 \
229 -s "found psk key exchange modes extension" \
230 -s "found pre_shared_key extension" \
231 -s "Found PSK_EPHEMERAL KEX MODE" \
232 -s "Found PSK KEX MODE" \
233 -s "key exchange mode: psk$"
234
235requires_gnutls_tls1_3
236requires_all_configs_enabled MBEDTLS_SSL_PROTO_TLS1_3 MBEDTLS_SSL_SRV_C MBEDTLS_DEBUG_C \
237 MBEDTLS_SSL_TLS1_3_COMPATIBILITY_MODE \
238 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED
239requires_all_configs_disabled MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_ENABLED \
240 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED
241run_test "TLS 1.3: G->m: PSK: configured psk_ephemeral only, good." \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100242 "$P_SRV tls13_kex_modes=all debug_level=5 $(get_srv_psk_list)" \
Jerry Yue5991322022-11-07 14:03:44 +0800243 "$G_NEXT_CLI -d 10 --priority NORMAL:-VERS-ALL:-KX-ALL:+ECDHE-PSK:+DHE-PSK:+PSK:+VERS-TLS1.3:+GROUP-ALL \
244 --pskusername Client_identity --pskkey=6162636465666768696a6b6c6d6e6f70 \
245 localhost" \
246 0 \
247 -s "found psk key exchange modes extension" \
248 -s "found pre_shared_key extension" \
249 -s "Found PSK_EPHEMERAL KEX MODE" \
250 -s "Found PSK KEX MODE" \
251 -s "key exchange mode: psk_ephemeral$"
252
253requires_gnutls_tls1_3
254requires_all_configs_enabled MBEDTLS_SSL_PROTO_TLS1_3 MBEDTLS_SSL_SRV_C MBEDTLS_DEBUG_C \
255 MBEDTLS_SSL_TLS1_3_COMPATIBILITY_MODE \
256 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED
257requires_all_configs_disabled MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_ENABLED \
258 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED
259run_test "TLS 1.3: G->m: PSK: configured ephemeral only, good." \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100260 "$P_SRV tls13_kex_modes=all debug_level=5 $(get_srv_psk_list)" \
Jerry Yue5991322022-11-07 14:03:44 +0800261 "$G_NEXT_CLI -d 10 --priority NORMAL:-VERS-ALL:-KX-ALL:+ECDHE-PSK:+DHE-PSK:+PSK:+VERS-TLS1.3:+GROUP-ALL \
262 --pskusername Client_identity --pskkey=6162636465666768696a6b6c6d6e6f70 \
263 localhost" \
264 0 \
265 -s "key exchange mode: ephemeral$"
266
Xiaokang Qianf3cefb42022-11-16 03:23:46 +0000267requires_gnutls_tls1_3
268requires_config_enabled MBEDTLS_DEBUG_C
269requires_config_enabled MBEDTLS_SSL_CLI_C
270requires_all_configs_enabled MBEDTLS_SSL_TLS1_3_COMPATIBILITY_MODE \
271 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
Xiaokang Qianf3cefb42022-11-16 03:23:46 +0000272 MBEDTLS_SSL_EARLY_DATA
Xiaokang Qiane7bab002022-11-16 08:51:01 +0000273requires_any_configs_enabled MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED \
274 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_ENABLED
Xiaokang Qianf3cefb42022-11-16 03:23:46 +0000275run_test "TLS 1.3 m->G: EarlyData: basic check, good" \
276 "$G_NEXT_SRV -d 10 --priority=NORMAL:-VERS-ALL:+VERS-TLS1.3:+CIPHER-ALL:+ECDHE-PSK:+PSK --earlydata --disable-client-cert" \
Xiaokang Qian0de0d862023-02-08 06:04:50 +0000277 "$P_CLI debug_level=4 early_data=1 reco_mode=1 reconnect=1 reco_delay=900" \
Xiaokang Qian7ed30e52022-12-16 08:32:02 +0000278 0 \
Xiaokang Qianf3cefb42022-11-16 03:23:46 +0000279 -c "Reconnecting with saved session" \
280 -c "NewSessionTicket: early_data(42) extension received." \
281 -c "ClientHello: early_data(42) extension exists." \
282 -c "EncryptedExtensions: early_data(42) extension received." \
Xiaokang Qian8bee8992022-10-27 10:21:05 +0000283 -c "EncryptedExtensions: early_data(42) extension exists." \
Xiaokang Qian57a138d2022-12-19 06:40:47 +0000284 -c "<= write EndOfEarlyData" \
Xiaokang Qianf3cefb42022-11-16 03:23:46 +0000285 -s "Parsing extension 'Early Data/42' (0 bytes)" \
286 -s "Sending extension Early Data/42 (0 bytes)" \
Xiaokang Qian94dd1dd2022-12-15 15:13:04 +0000287 -s "END OF EARLY DATA (5) was received." \
Xiaokang Qianf3cefb42022-11-16 03:23:46 +0000288 -s "early data accepted"
289
290requires_gnutls_tls1_3
291requires_config_enabled MBEDTLS_DEBUG_C
292requires_config_enabled MBEDTLS_SSL_CLI_C
293requires_all_configs_enabled MBEDTLS_SSL_TLS1_3_COMPATIBILITY_MODE \
294 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
Xiaokang Qianf3cefb42022-11-16 03:23:46 +0000295 MBEDTLS_SSL_EARLY_DATA
Xiaokang Qiane7bab002022-11-16 08:51:01 +0000296requires_any_configs_enabled MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED \
297 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_ENABLED
Xiaokang Qiane9622ac2022-11-17 09:23:32 +0000298run_test "TLS 1.3 m->G: EarlyData: no early_data in NewSessionTicket, good" \
Xiaokang Qianf3cefb42022-11-16 03:23:46 +0000299 "$G_NEXT_SRV -d 10 --priority=NORMAL:-VERS-ALL:+VERS-TLS1.3:+CIPHER-ALL:+ECDHE-PSK:+PSK --disable-client-cert" \
Jerry Yua15af372022-12-05 15:55:24 +0800300 "$P_CLI debug_level=4 early_data=1 reco_mode=1 reconnect=1" \
Xiaokang Qianf3cefb42022-11-16 03:23:46 +0000301 0 \
302 -c "Reconnecting with saved session" \
303 -C "NewSessionTicket: early_data(42) extension received." \
304 -c "ClientHello: early_data(42) extension does not exist." \
305 -C "EncryptedExtensions: early_data(42) extension received." \
Xiaokang Qian8bee8992022-10-27 10:21:05 +0000306 -C "EncryptedExtensions: early_data(42) extension exists."
Xiaokang Qianf3cefb42022-11-16 03:23:46 +0000307
Xiaokang Qiane7bab002022-11-16 08:51:01 +0000308#TODO: OpenSSL tests don't work now. It might be openssl options issue, cause GnuTLS has worked.
Xiaokang Qianf3cefb42022-11-16 03:23:46 +0000309skip_next_test
Xiaokang Qiane7bab002022-11-16 08:51:01 +0000310requires_openssl_tls1_3
311requires_config_enabled MBEDTLS_DEBUG_C
Xiaokang Qianf3cefb42022-11-16 03:23:46 +0000312requires_config_enabled MBEDTLS_SSL_CLI_C
Xiaokang Qiane7bab002022-11-16 08:51:01 +0000313requires_all_configs_enabled MBEDTLS_SSL_TLS1_3_COMPATIBILITY_MODE \
314 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
315 MBEDTLS_SSL_EARLY_DATA
316requires_any_configs_enabled MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED \
317 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_ENABLED
Xiaokang Qianf3cefb42022-11-16 03:23:46 +0000318run_test "TLS 1.3, ext PSK, early data" \
319 "$O_NEXT_SRV_EARLY_DATA -msg -debug -tls1_3 -psk_identity 0a0b0c -psk 010203 -allow_no_dhe_kex -nocert" \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100320 "$P_CLI debug_level=5 tls13_kex_modes=psk early_data=1 psk=010203 psk_identity=0a0b0c" \
Xiaokang Qianf3cefb42022-11-16 03:23:46 +0000321 1 \
322 -c "Reconnecting with saved session" \
323 -c "NewSessionTicket: early_data(42) extension received." \
324 -c "ClientHello: early_data(42) extension exists." \
325 -c "EncryptedExtensions: early_data(42) extension received." \
326 -c "EncryptedExtensions: early_data(42) extension ( ignored )."
327
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800328requires_all_configs_enabled MBEDTLS_SSL_SESSION_TICKETS \
Pengyu Lvc1334d92023-01-12 16:18:08 +0800329 MBEDTLS_SSL_SRV_C MBEDTLS_SSL_CLI_C MBEDTLS_DEBUG_C \
330 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
331 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_ENABLED
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800332run_test "TLS 1.3 m->m: Resumption with ticket flags, psk/none." \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100333 "$P_SRV debug_level=4 crt_file=data_files/server5.crt key_file=data_files/server5.key dummy_ticket=7" \
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800334 "$P_CLI debug_level=4 tls13_kex_modes=psk_or_ephemeral reconnect=1" \
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800335 0 \
336 -c "Pre-configured PSK number = 1" \
337 -S "sent selected_identity:" \
338 -s "key exchange mode: ephemeral" \
339 -S "key exchange mode: psk_ephemeral" \
340 -S "key exchange mode: psk$" \
341 -s "No suitable key exchange mode" \
342 -s "No matched PSK or ticket"
Pengyu Lv302feb32022-12-09 14:27:08 +0800343
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800344requires_all_configs_enabled MBEDTLS_SSL_SESSION_TICKETS \
Pengyu Lvc1334d92023-01-12 16:18:08 +0800345 MBEDTLS_SSL_SRV_C MBEDTLS_SSL_CLI_C MBEDTLS_DEBUG_C \
346 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
347 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_ENABLED
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800348run_test "TLS 1.3 m->m: Resumption with ticket flags, psk/psk." \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100349 "$P_SRV debug_level=4 crt_file=data_files/server5.crt key_file=data_files/server5.key dummy_ticket=8" \
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800350 "$P_CLI debug_level=4 tls13_kex_modes=psk_or_ephemeral reconnect=1" \
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800351 0 \
352 -c "Pre-configured PSK number = 1" \
353 -S "No suitable key exchange mode" \
354 -s "found matched identity"
355
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800356requires_all_configs_enabled MBEDTLS_SSL_SESSION_TICKETS \
Pengyu Lvc1334d92023-01-12 16:18:08 +0800357 MBEDTLS_SSL_SRV_C MBEDTLS_SSL_CLI_C MBEDTLS_DEBUG_C \
358 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
359 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_ENABLED
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800360run_test "TLS 1.3 m->m: Resumption with ticket flags, psk/psk_ephemeral." \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100361 "$P_SRV debug_level=4 crt_file=data_files/server5.crt key_file=data_files/server5.key dummy_ticket=9" \
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800362 "$P_CLI debug_level=4 tls13_kex_modes=psk_or_ephemeral reconnect=1" \
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800363 0 \
364 -c "Pre-configured PSK number = 1" \
365 -S "sent selected_identity:" \
366 -s "key exchange mode: ephemeral" \
367 -S "key exchange mode: psk_ephemeral" \
368 -S "key exchange mode: psk$" \
369 -s "No suitable key exchange mode" \
370 -s "No matched PSK or ticket"
371
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800372requires_all_configs_enabled MBEDTLS_SSL_SESSION_TICKETS \
Pengyu Lvc1334d92023-01-12 16:18:08 +0800373 MBEDTLS_SSL_SRV_C MBEDTLS_SSL_CLI_C MBEDTLS_DEBUG_C \
374 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
375 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_ENABLED
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800376run_test "TLS 1.3 m->m: Resumption with ticket flags, psk/psk_all." \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100377 "$P_SRV debug_level=4 crt_file=data_files/server5.crt key_file=data_files/server5.key dummy_ticket=10" \
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800378 "$P_CLI debug_level=4 tls13_kex_modes=psk_or_ephemeral reconnect=1" \
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800379 0 \
380 -c "Pre-configured PSK number = 1" \
381 -S "No suitable key exchange mode" \
382 -s "found matched identity"
383
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800384requires_all_configs_enabled MBEDTLS_SSL_SESSION_TICKETS \
Pengyu Lvc1334d92023-01-12 16:18:08 +0800385 MBEDTLS_SSL_SRV_C MBEDTLS_SSL_CLI_C MBEDTLS_DEBUG_C \
386 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
387 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800388run_test "TLS 1.3 m->m: Resumption with ticket flags, psk_ephemeral/none." \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100389 "$P_SRV debug_level=4 crt_file=data_files/server5.crt key_file=data_files/server5.key dummy_ticket=7" \
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800390 "$P_CLI debug_level=4 tls13_kex_modes=ephemeral_all reconnect=1" \
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800391 0 \
392 -c "Pre-configured PSK number = 1" \
393 -S "sent selected_identity:" \
394 -s "key exchange mode: ephemeral" \
395 -S "key exchange mode: psk_ephemeral" \
396 -S "key exchange mode: psk$" \
397 -s "No suitable key exchange mode" \
398 -s "No matched PSK or ticket"
399
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800400requires_all_configs_enabled MBEDTLS_SSL_SESSION_TICKETS \
Pengyu Lvc1334d92023-01-12 16:18:08 +0800401 MBEDTLS_SSL_SRV_C MBEDTLS_SSL_CLI_C MBEDTLS_DEBUG_C \
402 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
403 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800404run_test "TLS 1.3 m->m: Resumption with ticket flags, psk_ephemeral/psk." \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100405 "$P_SRV debug_level=4 crt_file=data_files/server5.crt key_file=data_files/server5.key dummy_ticket=8" \
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800406 "$P_CLI debug_level=4 tls13_kex_modes=ephemeral_all reconnect=1" \
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800407 0 \
408 -c "Pre-configured PSK number = 1" \
409 -S "sent selected_identity:" \
410 -s "key exchange mode: ephemeral" \
411 -S "key exchange mode: psk_ephemeral" \
412 -S "key exchange mode: psk$" \
413 -s "No suitable key exchange mode" \
414 -s "No matched PSK or ticket"
415
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800416requires_all_configs_enabled MBEDTLS_SSL_SESSION_TICKETS \
Pengyu Lvc1334d92023-01-12 16:18:08 +0800417 MBEDTLS_SSL_SRV_C MBEDTLS_SSL_CLI_C MBEDTLS_DEBUG_C \
418 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
419 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800420run_test "TLS 1.3 m->m: Resumption with ticket flags, psk_ephemeral/psk_ephemeral." \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100421 "$P_SRV debug_level=4 crt_file=data_files/server5.crt key_file=data_files/server5.key dummy_ticket=9" \
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800422 "$P_CLI debug_level=4 tls13_kex_modes=ephemeral_all reconnect=1" \
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800423 0 \
424 -c "Pre-configured PSK number = 1" \
425 -S "No suitable key exchange mode" \
426 -s "found matched identity"
427
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800428requires_all_configs_enabled MBEDTLS_SSL_SESSION_TICKETS \
Pengyu Lvc1334d92023-01-12 16:18:08 +0800429 MBEDTLS_SSL_SRV_C MBEDTLS_SSL_CLI_C MBEDTLS_DEBUG_C \
430 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
431 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800432run_test "TLS 1.3 m->m: Resumption with ticket flags, psk_ephemeral/psk_all." \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100433 "$P_SRV debug_level=4 crt_file=data_files/server5.crt key_file=data_files/server5.key dummy_ticket=10" \
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800434 "$P_CLI debug_level=4 tls13_kex_modes=ephemeral_all reconnect=1" \
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800435 0 \
436 -c "Pre-configured PSK number = 1" \
437 -S "No suitable key exchange mode" \
438 -s "found matched identity"
439
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800440requires_all_configs_enabled MBEDTLS_SSL_SESSION_TICKETS \
Pengyu Lvc1334d92023-01-12 16:18:08 +0800441 MBEDTLS_SSL_SRV_C MBEDTLS_SSL_CLI_C MBEDTLS_DEBUG_C \
442 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
443 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_ENABLED \
444 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800445run_test "TLS 1.3 m->m: Resumption with ticket flags, psk_all/none." \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100446 "$P_SRV debug_level=4 crt_file=data_files/server5.crt key_file=data_files/server5.key dummy_ticket=7" \
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800447 "$P_CLI debug_level=4 tls13_kex_modes=all reconnect=1" \
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800448 0 \
449 -c "Pre-configured PSK number = 1" \
450 -S "sent selected_identity:" \
451 -s "key exchange mode: ephemeral" \
452 -S "key exchange mode: psk_ephemeral" \
453 -S "key exchange mode: psk$" \
454 -s "No suitable key exchange mode" \
455 -s "No matched PSK or ticket"
456
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800457requires_all_configs_enabled MBEDTLS_SSL_SESSION_TICKETS \
Pengyu Lvc1334d92023-01-12 16:18:08 +0800458 MBEDTLS_SSL_SRV_C MBEDTLS_SSL_CLI_C MBEDTLS_DEBUG_C \
459 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
460 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_ENABLED \
461 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800462run_test "TLS 1.3 m->m: Resumption with ticket flags, psk_all/psk." \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100463 "$P_SRV debug_level=4 crt_file=data_files/server5.crt key_file=data_files/server5.key dummy_ticket=8" \
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800464 "$P_CLI debug_level=4 tls13_kex_modes=all reconnect=1" \
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800465 0 \
466 -c "Pre-configured PSK number = 1" \
467 -S "No suitable key exchange mode" \
468 -s "found matched identity"
469
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800470requires_all_configs_enabled MBEDTLS_SSL_SESSION_TICKETS \
Pengyu Lvc1334d92023-01-12 16:18:08 +0800471 MBEDTLS_SSL_SRV_C MBEDTLS_SSL_CLI_C MBEDTLS_DEBUG_C \
472 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
473 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_ENABLED \
474 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800475run_test "TLS 1.3 m->m: Resumption with ticket flags, psk_all/psk_ephemeral." \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100476 "$P_SRV debug_level=4 crt_file=data_files/server5.crt key_file=data_files/server5.key dummy_ticket=9" \
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800477 "$P_CLI debug_level=4 tls13_kex_modes=all reconnect=1" \
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800478 0 \
479 -c "Pre-configured PSK number = 1" \
480 -S "No suitable key exchange mode" \
481 -s "found matched identity"
482
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800483requires_all_configs_enabled MBEDTLS_SSL_SESSION_TICKETS \
Pengyu Lvc1334d92023-01-12 16:18:08 +0800484 MBEDTLS_SSL_SRV_C MBEDTLS_SSL_CLI_C MBEDTLS_DEBUG_C \
485 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED \
486 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_ENABLED \
487 MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800488run_test "TLS 1.3 m->m: Resumption with ticket flags, psk_all/psk_all." \
Ronald Cron50ae84e2023-03-14 08:59:56 +0100489 "$P_SRV debug_level=4 crt_file=data_files/server5.crt key_file=data_files/server5.key dummy_ticket=10" \
Pengyu Lv2bfd7162023-01-16 13:44:10 +0800490 "$P_CLI debug_level=4 tls13_kex_modes=all reconnect=1" \
Pengyu Lv06cf66d2022-12-12 10:43:55 +0800491 0 \
492 -c "Pre-configured PSK number = 1" \
493 -S "No suitable key exchange mode" \
494 -s "found matched identity"
Pengyu Lv302feb32022-12-09 14:27:08 +0800495