summaryrefslogtreecommitdiffstats
path: root/test/quic_multistream_test.c
diff options
context:
space:
mode:
authorHugo Landau <hlandau@openssl.org>2024-01-22 15:00:45 +0100
committerHugo Landau <hlandau@openssl.org>2024-02-08 17:50:00 +0100
commit898e1f1353682222efe96cd4dd5ac6a73e2cc8b3 (patch)
tree40ddb7441140f019f9c7b207dbb4255335eb2cbf /test/quic_multistream_test.c
parentQUIC CHANNEL: Fix idle timeout computation bug (diff)
downloadopenssl-898e1f1353682222efe96cd4dd5ac6a73e2cc8b3.tar.xz
openssl-898e1f1353682222efe96cd4dd5ac6a73e2cc8b3.zip
QUIC MULTISTREAM TEST: Test idle timeout configuration
Reviewed-by: Neil Horman <nhorman@openssl.org> Reviewed-by: Matt Caswell <matt@openssl.org> Reviewed-by: Tomas Mraz <tomas@openssl.org> (Merged from https://github.com/openssl/openssl/pull/23360)
Diffstat (limited to 'test/quic_multistream_test.c')
-rw-r--r--test/quic_multistream_test.c121
1 files changed, 120 insertions, 1 deletions
diff --git a/test/quic_multistream_test.c b/test/quic_multistream_test.c
index 01b039b7ad..e5ae060dff 100644
--- a/test/quic_multistream_test.c
+++ b/test/quic_multistream_test.c
@@ -327,6 +327,8 @@ struct script_op {
{OPK_POP_ERR},
#define OP_C_WRITE_EX2(stream_name, buf, buf_len, flags) \
{OPK_C_WRITE_EX2, (buf), (buf_len), NULL, #stream_name, (flags)},
+#define OP_CHECK2(func, arg1, arg2) \
+ {OPK_CHECK, NULL, (arg1), (func), NULL, (arg2)},
static OSSL_TIME get_time(void *arg)
{
@@ -5072,6 +5074,8 @@ static int check_got_session_ticket(struct helper *h, struct helper_local *hl)
return 1;
}
+static int check_idle_timeout(struct helper *h, struct helper_local *hl);
+
static const struct script_op script_78[] = {
OP_C_SET_ALPN ("ossltest")
OP_CHECK (setup_session, 0)
@@ -5094,6 +5098,8 @@ static const struct script_op script_78[] = {
OP_C_READ_EXPECT (a, "Strawberry", 10)
OP_CHECK (check_got_session_ticket, 0)
+ OP_CHECK2 (check_idle_timeout,
+ SSL_VALUE_CLASS_FEATURE_NEGOTIATED, 30000)
OP_END
};
@@ -5113,11 +5119,12 @@ static const struct script_op script_79[] = {
OP_END
};
+/* 80. Stateless reset detection test */
static QUIC_STATELESS_RESET_TOKEN test_reset_token = {
{ 0xde, 0xad, 0xbe, 0xef, 0xde, 0xad, 0xbe, 0xef, 0xde, 0xad, 0xbe, 0xef,
0xde, 0xad, 0xbe, 0xef }};
+
/*
- * 80. stateless reset
* Generate a packet in the following format:
* https://www.rfc-editor.org/rfc/rfc9000.html#name-stateless-reset
* Stateless Reset {
@@ -5226,6 +5233,115 @@ static const struct script_op script_80[] = {
OP_END
};
+/* 81. Idle timeout configuration */
+static int modify_idle_timeout(struct helper *h, struct helper_local *hl)
+{
+ uint64_t v = 0;
+
+ /* Test bad value is rejected. */
+ if (!TEST_false(SSL_set_feature_request_uint(h->c_conn,
+ SSL_VALUE_QUIC_IDLE_TIMEOUT,
+ (1UL << 62))))
+ return 0;
+
+ /* Set value. */
+ if (!TEST_true(SSL_set_feature_request_uint(h->c_conn,
+ SSL_VALUE_QUIC_IDLE_TIMEOUT,
+ hl->check_op->arg2)))
+ return 0;
+
+ if (!TEST_true(SSL_get_feature_request_uint(h->c_conn,
+ SSL_VALUE_QUIC_IDLE_TIMEOUT,
+ &v)))
+ return 0;
+
+ if (!TEST_uint64_t_eq(v, hl->check_op->arg2))
+ return 0;
+
+ return 1;
+}
+
+static int check_idle_timeout(struct helper *h, struct helper_local *hl)
+{
+ uint64_t v = 0;
+
+ if (!TEST_true(SSL_get_value_uint(h->c_conn, hl->check_op->arg1,
+ SSL_VALUE_QUIC_IDLE_TIMEOUT,
+ &v)))
+ return 0;
+
+ if (!TEST_uint64_t_eq(v, hl->check_op->arg2))
+ return 0;
+
+ return 1;
+}
+
+static const struct script_op script_81[] = {
+ OP_C_SET_ALPN ("ossltest")
+ OP_CHECK (modify_idle_timeout, 25000)
+ OP_C_CONNECT_WAIT ()
+
+ OP_C_SET_DEFAULT_STREAM_MODE(SSL_DEFAULT_STREAM_MODE_NONE)
+
+ OP_CHECK2 (check_idle_timeout,
+ SSL_VALUE_CLASS_FEATURE_PEER_REQUEST, 30000)
+ OP_CHECK2 (check_idle_timeout,
+ SSL_VALUE_CLASS_FEATURE_NEGOTIATED, 25000)
+
+ OP_END
+};
+
+/* 82. Negotiated default idle timeout if not configured */
+static const struct script_op script_82[] = {
+ OP_C_SET_ALPN ("ossltest")
+ OP_C_CONNECT_WAIT ()
+
+ OP_C_SET_DEFAULT_STREAM_MODE(SSL_DEFAULT_STREAM_MODE_NONE)
+
+ OP_CHECK2 (check_idle_timeout,
+ SSL_VALUE_CLASS_FEATURE_PEER_REQUEST, 30000)
+ OP_CHECK2 (check_idle_timeout,
+ SSL_VALUE_CLASS_FEATURE_NEGOTIATED, 30000)
+
+ OP_END
+};
+
+/* 83. No late changes to idle timeout */
+static int cannot_change_idle_timeout(struct helper *h, struct helper_local *hl)
+{
+ uint64_t v = 0;
+
+ if (!TEST_true(SSL_get_feature_request_uint(h->c_conn,
+ SSL_VALUE_QUIC_IDLE_TIMEOUT,
+ &v)))
+ return 0;
+
+ if (!TEST_uint64_t_eq(v, 30000))
+ return 0;
+
+ if (!TEST_false(SSL_set_feature_request_uint(h->c_conn,
+ SSL_VALUE_QUIC_IDLE_TIMEOUT,
+ 5000)))
+ return 0;
+
+ return 1;
+}
+
+static const struct script_op script_83[] = {
+ OP_C_SET_ALPN ("ossltest")
+ OP_C_CONNECT_WAIT ()
+
+ OP_C_SET_DEFAULT_STREAM_MODE(SSL_DEFAULT_STREAM_MODE_NONE)
+
+ OP_CHECK (cannot_change_idle_timeout, 0)
+ OP_CHECK2 (check_idle_timeout,
+ SSL_VALUE_CLASS_FEATURE_PEER_REQUEST, 30000)
+ OP_CHECK2 (check_idle_timeout,
+ SSL_VALUE_CLASS_FEATURE_NEGOTIATED, 30000)
+
+ OP_END
+};
+
static const struct script_op *const scripts[] = {
script_1,
script_2,
@@ -5307,6 +5423,9 @@ static const struct script_op *const scripts[] = {
script_78,
script_79,
script_80
+ script_81,
+ script_82,
+ script_83
};
static int test_script(int idx)