1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
|
// SPDX-License-Identifier: LGPL-2.1-or-later
/*
* This file is part of the PCEPlib, a PCEP protocol library.
*
* Copyright (C) 2020 Volta Networks https://voltanet.io/
*
* Author : Brady Johnson <brady@voltanet.io>
*
*/
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#include <CUnit/Basic.h>
#include <CUnit/CUnit.h>
#include <CUnit/TestDB.h>
#include "pcep_timers_test.h"
#include "pcep_timers_event_loop_test.h"
int main(int argc, char **argv)
{
/* Unused parameters cause compilation warnings */
(void)argc;
(void)argv;
CU_initialize_registry();
/*
* Tests defined in pcep_timers_test.c
*/
CU_pSuite test_timers_suite = CU_add_suite_with_setup_and_teardown(
"PCEP Timers Test Suite", NULL,
NULL, // suite setup and cleanup function pointers
NULL, pcep_timers_test_teardown); // test case setup and
// teardown function pointers
CU_add_test(test_timers_suite, "test_double_initialization",
test_double_initialization);
CU_add_test(test_timers_suite, "test_initialization_null_callback",
test_initialization_null_callback);
CU_add_test(test_timers_suite, "test_not_initialized",
test_not_initialized);
CU_add_test(test_timers_suite, "test_create_timer", test_create_timer);
CU_add_test(test_timers_suite, "test_cancel_timer", test_cancel_timer);
CU_add_test(test_timers_suite, "test_cancel_timer_invalid",
test_cancel_timer_invalid);
CU_add_test(test_timers_suite, "test_reset_timer", test_reset_timer);
CU_add_test(test_timers_suite, "test_reset_timer_invalid",
test_reset_timer_invalid);
/*
* Tests defined in pcep_timers_event_loop_test.c
*/
CU_pSuite test_timers_event_loop_suite =
CU_add_suite_with_setup_and_teardown(
"PCEP Timers Event Loop Test Suite", NULL,
NULL, // suite setup and cleanup function pointers
pcep_timers_event_loop_test_setup, // test case setup
// function pointer
pcep_timers_event_loop_test_teardown); // test case
// teardown
// function
// pointer
CU_add_test(test_timers_event_loop_suite,
"test_walk_and_process_timers_no_timers",
test_walk_and_process_timers_no_timers);
CU_add_test(test_timers_event_loop_suite,
"test_walk_and_process_timers_timer_not_expired",
test_walk_and_process_timers_timer_not_expired);
CU_add_test(test_timers_event_loop_suite,
"test_walk_and_process_timers_timer_expired",
test_walk_and_process_timers_timer_expired);
CU_add_test(test_timers_event_loop_suite, "test_event_loop_null_handle",
test_event_loop_null_handle);
CU_add_test(test_timers_event_loop_suite, "test_event_loop_not_active",
test_event_loop_not_active);
/*
* Run the tests and cleanup.
*/
CU_basic_set_mode(CU_BRM_VERBOSE);
CU_basic_run_tests();
CU_FailureRecord *failure_record = CU_get_failure_list();
if (failure_record != NULL) {
printf("\nFailed tests:\n\t [Suite] [Test] [File:line-number]\n");
do {
printf("\t [%s] [%s] [%s:%d]\n",
failure_record->pSuite->pName,
failure_record->pTest->pName,
failure_record->strFileName,
failure_record->uiLineNumber);
failure_record = failure_record->pNext;
} while (failure_record != NULL);
}
CU_pRunSummary run_summary = CU_get_run_summary();
int result = run_summary->nTestsFailed;
CU_cleanup_registry();
return result;
}
|