123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177 |
- /*
- * Copyright 2022-2023 The OpenSSL Project Authors. All Rights Reserved.
- *
- * Licensed under the Apache License 2.0 (the "License"). You may not use
- * this file except in compliance with the License. You can obtain a copy
- * in the file LICENSE in the source distribution or at
- * https://www.openssl.org/source/license.html
- */
- #include "internal/packet.h"
- #include "internal/quic_cfq.h"
- #include "internal/quic_wire.h"
- #include "testutil.h"
- static const unsigned char ref_buf[] = {
- 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, 0x19
- };
- static const uint32_t ref_priority[] = {
- 90, 80, 70, 60, 95, 40, 94, 20, 10, 0
- };
- static const uint32_t ref_pn_space[] = {
- QUIC_PN_SPACE_INITIAL,
- QUIC_PN_SPACE_HANDSHAKE,
- QUIC_PN_SPACE_HANDSHAKE,
- QUIC_PN_SPACE_INITIAL,
- QUIC_PN_SPACE_INITIAL,
- QUIC_PN_SPACE_INITIAL,
- QUIC_PN_SPACE_INITIAL,
- QUIC_PN_SPACE_INITIAL,
- QUIC_PN_SPACE_APP,
- QUIC_PN_SPACE_APP,
- };
- static const uint64_t ref_frame_type[] = {
- OSSL_QUIC_FRAME_TYPE_NEW_CONN_ID,
- OSSL_QUIC_FRAME_TYPE_NEW_CONN_ID,
- OSSL_QUIC_FRAME_TYPE_NEW_CONN_ID,
- OSSL_QUIC_FRAME_TYPE_NEW_CONN_ID,
- OSSL_QUIC_FRAME_TYPE_NEW_CONN_ID,
- OSSL_QUIC_FRAME_TYPE_NEW_CONN_ID,
- OSSL_QUIC_FRAME_TYPE_NEW_CONN_ID,
- OSSL_QUIC_FRAME_TYPE_NEW_CONN_ID,
- OSSL_QUIC_FRAME_TYPE_NEW_CONN_ID,
- OSSL_QUIC_FRAME_TYPE_RETIRE_CONN_ID,
- };
- static const uint32_t expect[QUIC_PN_SPACE_NUM][11] = {
- { 4, 6, 0, 3, 5, 7, UINT32_MAX },
- { 1, 2, UINT32_MAX },
- { 8, 9, UINT32_MAX },
- };
- static QUIC_CFQ_ITEM *items[QUIC_PN_SPACE_NUM][10];
- static unsigned char *g_free;
- static size_t g_free_len;
- static void free_cb(unsigned char *buf, size_t buf_len, void *arg)
- {
- g_free = buf;
- g_free_len = buf_len;
- }
- static int check(QUIC_CFQ *cfq)
- {
- int testresult = 0;
- QUIC_CFQ_ITEM *item;
- size_t i;
- uint32_t pn_space;
- for (pn_space = QUIC_PN_SPACE_INITIAL; pn_space < QUIC_PN_SPACE_NUM; ++pn_space)
- for (i = 0, item = ossl_quic_cfq_get_priority_head(cfq, pn_space);;
- ++i, item = ossl_quic_cfq_item_get_priority_next(item, pn_space)) {
- if (expect[pn_space][i] == UINT32_MAX) {
- if (!TEST_ptr_null(item))
- goto err;
- break;
- }
- items[pn_space][i] = item;
- if (!TEST_ptr(item)
- || !TEST_ptr_eq(ossl_quic_cfq_item_get_encoded(item),
- ref_buf + expect[pn_space][i])
- || !TEST_int_eq(ossl_quic_cfq_item_get_pn_space(item), pn_space)
- || !TEST_int_eq(ossl_quic_cfq_item_get_state(item),
- QUIC_CFQ_STATE_NEW))
- goto err;
- }
- testresult = 1;
- err:
- return testresult;
- }
- static int test_cfq(void)
- {
- int testresult = 0;
- QUIC_CFQ *cfq = NULL;
- QUIC_CFQ_ITEM *item, *inext;
- size_t i;
- uint32_t pn_space;
- if (!TEST_ptr(cfq = ossl_quic_cfq_new()))
- goto err;
- g_free = NULL;
- g_free_len = 0;
- for (i = 0; i < OSSL_NELEM(ref_buf); ++i) {
- if (!TEST_ptr(item = ossl_quic_cfq_add_frame(cfq, ref_priority[i],
- ref_pn_space[i],
- ref_frame_type[i], 0,
- ref_buf + i,
- 1,
- free_cb,
- NULL))
- || !TEST_int_eq(ossl_quic_cfq_item_get_state(item),
- QUIC_CFQ_STATE_NEW)
- || !TEST_uint_eq(ossl_quic_cfq_item_get_pn_space(item),
- ref_pn_space[i])
- || !TEST_uint64_t_eq(ossl_quic_cfq_item_get_frame_type(item),
- ref_frame_type[i])
- || !TEST_ptr_eq(ossl_quic_cfq_item_get_encoded(item),
- ref_buf + i)
- || !TEST_size_t_eq(ossl_quic_cfq_item_get_encoded_len(item),
- 1))
- goto err;
- }
- if (!check(cfq))
- goto err;
- for (pn_space = QUIC_PN_SPACE_INITIAL; pn_space < QUIC_PN_SPACE_NUM; ++pn_space)
- for (item = ossl_quic_cfq_get_priority_head(cfq, pn_space);
- item != NULL; item = inext) {
- inext = ossl_quic_cfq_item_get_priority_next(item, pn_space);
- ossl_quic_cfq_mark_tx(cfq, item);
- }
- for (pn_space = QUIC_PN_SPACE_INITIAL; pn_space < QUIC_PN_SPACE_NUM; ++pn_space)
- if (!TEST_ptr_null(ossl_quic_cfq_get_priority_head(cfq, pn_space)))
- goto err;
- for (pn_space = QUIC_PN_SPACE_INITIAL; pn_space < QUIC_PN_SPACE_NUM; ++pn_space)
- for (i = 0; i < OSSL_NELEM(items[0]); ++i)
- if (items[pn_space][i] != NULL)
- ossl_quic_cfq_mark_lost(cfq, items[pn_space][i], UINT32_MAX);
- if (!check(cfq))
- goto err;
- for (pn_space = QUIC_PN_SPACE_INITIAL; pn_space < QUIC_PN_SPACE_NUM; ++pn_space)
- for (i = 0; i < OSSL_NELEM(items[0]); ++i)
- if (items[pn_space][i] != NULL)
- ossl_quic_cfq_release(cfq, items[pn_space][i]);
- for (pn_space = QUIC_PN_SPACE_INITIAL; pn_space < QUIC_PN_SPACE_NUM; ++pn_space)
- if (!TEST_ptr_null(ossl_quic_cfq_get_priority_head(cfq, pn_space)))
- goto err;
- testresult = 1;
- err:
- ossl_quic_cfq_free(cfq);
- return testresult;
- }
- int setup_tests(void)
- {
- ADD_TEST(test_cfq);
- return 1;
- }
|