summaryrefslogtreecommitdiffstats
path: root/src/usr/cxxtest/TestSuite.C
blob: 99055d0cfb5232e08d8695e9c7d875dc79e57a9e (plain)
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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
// Imported from FSP tree - /src/test/cxxtest/cxxtest/

#ifndef __cxxtest__TestSuite_cpp__
#define __cxxtest__TestSuite_cpp__

#include <stdarg.h>
#include <arch/ppc.H>
#include <kernel/console.H>

#include <cxxtest/TestSuite.H>

namespace CxxTest
{
/******************************************************************************/
// Globals/Constants
/******************************************************************************/

/**
 * @brief global vars to keep track of unit tests.
 *
 * totaltests - initialized to 0, updated by reporttotaltests() below.
 *      each test suite will call reporttotaltests after all tests have
 *      run with the total number of tests for that suite.
 *      Once all the testsuites have run, the global totaltests will hold
 *      the total of number of unit test for that run.
 *
 *      Each unit test macro (TS_TRACE, TS_WARN, and TS_FAIL) will update
 *      the proper variable.  At the end the unit tester will print out
 *      the totals.
 * // Global cxxtest values - Keep global so it can be found in syms file
 */
uint64_t        g_TotalTests      =       0;
uint64_t        g_TraceCalls      =       0;
uint64_t        g_Warnings        =       0;
uint64_t        g_FailedTests     =       0;


//
// TestSuite members
//
TestSuite::~TestSuite() {}
void TestSuite::setUp() {}
void TestSuite::tearDown() {}

/**
 *
 *   @brief Implement trace action in unit tests
 *
 *   @return void
 *
 */
void doTrace( void )
{

    __sync_add_and_fetch( &g_TraceCalls, 1 );

    return;
}

/**
 *
 *   @brief Implement warn action in unit tests
 *
 *   @param [in] pointer to filename  (not used right now )
 *   @param [in] line number
 *   @param [in] warning message
 *
 *   @return void
 *
 */
void doWarn( const char *file, unsigned line, const char *message )
{

    printk("WARN: %s %u %s\n", file, line, message);
    __sync_add_and_fetch( &g_Warnings, 1 );
}

/**
 *   @brief Implement Fail action in unit tests
 *
 *   @param [in] pointer to filename  (not used right now )
 *   @param [in] line number
 *   @param [in] failure message
 *
 *   @return void
 */

void doFailTest( const char *file, unsigned line, const char *message )
{

    printk("FAIL: %s %u %s\n", file, line, message);
    __sync_add_and_fetch( &g_FailedTests, 1 );
}

/**
 *  @brief Report total number of unit tests in a test suite
 *
 *  A unit test suite will call this to report how many tests
 *  it has.  The call itself is autogenerated
 *
 *  @param [in] pointer to filename  (not used right now )
 *  @param [in] line number
 *  @param [in] trace message
 *
 *  @return void
 */
void    reportTotalTests( const char *suitename, uint64_t numtests )
{

    //  $$TODO do nothing with the suite name for now, later it may be useful
    __sync_add_and_fetch( &g_TotalTests, numtests );
    printk( "%s completed %ld tests\n", suitename, numtests);

    return;
}

/**
 * @brief   accessor to read global totaltests var
 * @TODO  make these readonly accessors
 *
 * @return  number of total tests
 */
uint64_t    getTotalTests(void)
{

    return  g_TotalTests;
}

/**
 * @brief   accessor to read global failedtests var
 * @TODO  make these readonly accessors
 *
 * @return  total number off failures executed
 */
uint64_t    getFailedTests(void)
{

    return  g_FailedTests;
}

/**
 * @brief   accessor to read global warnings var
 * @TODO  make these readonly accessors
 *
 * @return  total number of warnings executed
 */
uint64_t    getWarnings(void)
{

    return  g_Warnings;
}

/**
 * @brief   accessor to read global tracecalls var
 * @TODO  make these readonly accessors
 *
 * @return  total number of trace calls executed
 */
uint64_t    getTraceCalls(void)
{

    return  g_TraceCalls;
}

};

#endif // __cxxtest__TestSuite_cpp__
OpenPOWER on IntegriCloud