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
|
/****************************************************************************
* $IBMCopyrightBlock:
*
* IBM Confidential
*
* Licensed Internal Code Source Materials
*
* IBM HostBoot Licensed Internal Code
*
* (C) Copyright IBM Corp. 2011
*
* The source code for this program is not published or other-
* wise divested of its trade secrets, irrespective of what has
* been deposited with the U.S. Copyright Office.
* $
****************************************************************************/
// 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
/******************************************************************************/
//
// 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 );
TRACDBIN( g_trac_test,
"Suite Completed: ",
suitename,
strlen(suitename) );
// printk( "%s completed %ld tests\n", suitename, numtests);
return;
}
};
#endif // __cxxtest__TestSuite_cpp__
|