[PATCH v5 6/7] app/test: convert hash test to use test suite runner
Stephen Hemminger
stephen at networkplumber.org
Fri Jan 30 21:21:56 CET 2026
Replace the manual sequence of if/return checks with the
unit_test_suite_runner framework. This provides structured
test output with per-test pass/fail status and summary counts.
Signed-off-by: Stephen Hemminger <stephen at networkplumber.org>
---
app/test/test_hash.c | 159 +++++++++++++++++++++++++------------------
1 file changed, 91 insertions(+), 68 deletions(-)
diff --git a/app/test/test_hash.c b/app/test/test_hash.c
index 1d140ec2cc..f0825ca75d 100644
--- a/app/test/test_hash.c
+++ b/app/test/test_hash.c
@@ -2330,87 +2330,110 @@ test_hash_rcu_qsbr_dq_reclaim(void)
}
/*
- * Do all unit and performance tests.
+ * Wrapper functions for tests that take parameters.
*/
static int
-test_hash(void)
+test_average_table_utilization_no_ext(void)
{
- RTE_BUILD_BUG_ON(sizeof(struct flow_key) % sizeof(uint32_t) != 0);
-
- if (test_add_delete() < 0)
- return -1;
- if (test_hash_add_delete_jhash2() < 0)
- return -1;
- if (test_hash_add_delete_2_jhash2() < 0)
- return -1;
- if (test_hash_add_delete_jhash_1word() < 0)
- return -1;
- if (test_hash_add_delete_jhash_2word() < 0)
- return -1;
- if (test_hash_add_delete_jhash_3word() < 0)
- return -1;
- if (test_hash_get_key_with_position() < 0)
- return -1;
- if (test_hash_find_existing() < 0)
- return -1;
- if (test_add_update_delete() < 0)
- return -1;
- if (test_add_update_delete_free() < 0)
- return -1;
- if (test_add_delete_free_lf() < 0)
- return -1;
- if (test_five_keys() < 0)
- return -1;
- if (test_full_bucket() < 0)
- return -1;
- if (test_extendable_bucket() < 0)
- return -1;
-
- if (test_fbk_hash_find_existing() < 0)
- return -1;
- if (fbk_hash_unit_test() < 0)
- return -1;
- if (test_hash_creation_with_bad_parameters() < 0)
- return -1;
- if (test_hash_creation_with_good_parameters() < 0)
- return -1;
-
- /* ext table disabled */
- if (test_average_table_utilization(0) < 0)
- return -1;
- if (test_hash_iteration(0) < 0)
- return -1;
+ return test_average_table_utilization(0);
+}
- /* ext table enabled */
- if (test_average_table_utilization(1) < 0)
- return -1;
- if (test_hash_iteration(1) < 0)
- return -1;
+static int
+test_average_table_utilization_ext(void)
+{
+ return test_average_table_utilization(1);
+}
- run_hash_func_tests();
+static int
+test_hash_iteration_no_ext(void)
+{
+ return test_hash_iteration(0);
+}
- if (test_crc32_hash_alg_equiv() < 0)
- return -1;
+static int
+test_hash_iteration_ext(void)
+{
+ return test_hash_iteration(1);
+}
- if (test_hash_rcu_qsbr_add() < 0)
- return -1;
+static int
+test_hash_rcu_qsbr_dq_mode_no_ext(void)
+{
+ return test_hash_rcu_qsbr_dq_mode(0);
+}
- if (test_hash_rcu_qsbr_dq_mode(0) < 0)
- return -1;
+static int
+test_hash_rcu_qsbr_dq_mode_ext(void)
+{
+ return test_hash_rcu_qsbr_dq_mode(1);
+}
- if (test_hash_rcu_qsbr_dq_mode(1) < 0)
- return -1;
+static int
+test_hash_rcu_qsbr_sync_mode_no_ext(void)
+{
+ return test_hash_rcu_qsbr_sync_mode(0);
+}
- if (test_hash_rcu_qsbr_sync_mode(0) < 0)
- return -1;
+static int
+test_hash_rcu_qsbr_sync_mode_ext(void)
+{
+ return test_hash_rcu_qsbr_sync_mode(1);
+}
- if (test_hash_rcu_qsbr_sync_mode(1) < 0)
- return -1;
+static int
+test_hash_func_tests(void)
+{
+ run_hash_func_tests();
+ return TEST_SUCCESS;
+}
- if (test_hash_rcu_qsbr_dq_reclaim() < 0)
- return -1;
+static_assert(sizeof(struct flow_key) % sizeof(uint32_t) == 0,
+ "flow_key size must be a multiple of 4 bytes");
+
+static struct unit_test_suite hash_test_suite = {
+ .suite_name = "Hash Unit Test Suite",
+ .unit_test_cases = {
+ TEST_CASE(test_add_delete),
+ TEST_CASE(test_hash_add_delete_jhash2),
+ TEST_CASE(test_hash_add_delete_2_jhash2),
+ TEST_CASE(test_hash_add_delete_jhash_1word),
+ TEST_CASE(test_hash_add_delete_jhash_2word),
+ TEST_CASE(test_hash_add_delete_jhash_3word),
+ TEST_CASE(test_hash_get_key_with_position),
+ TEST_CASE(test_hash_find_existing),
+ TEST_CASE(test_add_update_delete),
+ TEST_CASE(test_add_update_delete_free),
+ TEST_CASE(test_add_delete_free_lf),
+ TEST_CASE(test_five_keys),
+ TEST_CASE(test_full_bucket),
+ TEST_CASE(test_extendable_bucket),
+ TEST_CASE(test_fbk_hash_find_existing),
+ TEST_CASE(fbk_hash_unit_test),
+ TEST_CASE(test_hash_creation_with_bad_parameters),
+ TEST_CASE(test_hash_creation_with_good_parameters),
+ TEST_CASE(test_average_table_utilization_no_ext),
+ TEST_CASE(test_hash_iteration_no_ext),
+ TEST_CASE(test_average_table_utilization_ext),
+ TEST_CASE(test_hash_iteration_ext),
+ TEST_CASE(test_hash_func_tests),
+ TEST_CASE(test_crc32_hash_alg_equiv),
+ TEST_CASE(test_hash_rcu_qsbr_add),
+ TEST_CASE(test_hash_rcu_qsbr_dq_mode_no_ext),
+ TEST_CASE(test_hash_rcu_qsbr_dq_mode_ext),
+ TEST_CASE(test_hash_rcu_qsbr_sync_mode_no_ext),
+ TEST_CASE(test_hash_rcu_qsbr_sync_mode_ext),
+ TEST_CASE(test_hash_rcu_qsbr_dq_reclaim),
+ TEST_CASES_END()
+ }
+};
- return 0;
+/*
+ * Do all unit and performance tests.
+ */
+static int
+test_hash(void)
+{
+ return unit_test_suite_runner(&hash_test_suite);
}
REGISTER_FAST_TEST(hash_autotest, NOHUGE_OK, ASAN_OK, test_hash);
--
2.51.0
More information about the dev
mailing list