summaryrefslogtreecommitdiff
path: root/src/unitsuite.cpp
blob: d2e67ba9f308fdd7ed46071b12b6569519be21f8 (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
/*
 * Copyright (C) 2007-2008 Xagasoft, All rights reserved.
 *
 * This file is part of the libbu++ library and is released under the
 * terms of the license contained in the file LICENSE.
 */

#include "bu/unitsuite.h"

Bu::UnitSuite::UnitSuite() :
	iOptions( 0 )
{
}

Bu::UnitSuite::UnitSuite( int iOptions ) :
	iOptions( iOptions )
{
}

Bu::UnitSuite::~UnitSuite()
{
}

// Argument handling is coming soon, I promise.
int Bu::UnitSuite::run( int /*argc*/, char * /*argv */ [] )
{
	int iEPass = 0;
	int iEFail = 0;
	int iUPass = 0;
	int iUFail = 0;
	for( TestList::iterator i = lTests.begin(); i != lTests.end(); i++ )
	{
		printf("%s: ", i->sName.getStr() );
		fflush( stdout );
		try
		{
			(this->*(i->fTest))();
			switch( i->eExpect )
			{
				case expectPass: printf("expected pass.\n"); iEPass++; break;
				case expectFail: printf("unexpected pass.\n"); iUPass++; break;
			}
		}
		catch( Failed &e )
		{
			switch( i->eExpect )
			{
				case expectPass: printf("unexpected "); iUFail++; break;
				case expectFail: printf("expected "); iEFail++; break;
			}
			if( e.bFile )
			{
				printf("fail in unitTest(%s). (%s:%d)\n",
					e.str.getStr(),
					e.sFile.getStr(),
					e.nLine
					);
			}
			else
			{
				printf("fail in unitTest(%s).\n",
					e.str.getStr()
					);
			}

			if( (iOptions & optStopOnError) )
				return 0;
		}
		catch( std::exception &e )
		{
			switch( i->eExpect )
			{
				case expectPass: printf("unexpected "); iUFail++; break;
				case expectFail: printf("expected "); iEFail++; break;
			}
			printf("fail with unknown exception.  what: %s\n", e.what() );

			if( (iOptions & optStopOnError) )
				return 0;
		}
		catch( ... )
		{
			switch( i->eExpect )
			{
				case expectPass: printf("unexpected "); iUFail++; break;
				case expectFail: printf("expected "); iEFail++; break;
			}
			printf("fail with external exception.\n");

			if( (iOptions & optStopOnError) )
				return 0;
		}
	}

	printf("\nReport:\n"
		"\tTotal tests run:     %ld\n"
		"\tExpected passes:     %d\n"
		"\tExpected failures:   %d\n"
		"\tUnexpected passes:   %d\n"
		"\tUnexpected failures: %d\n\n",
		lTests.getSize(), iEPass, iEFail, iUPass, iUFail );
	if( iUPass == 0 && iUFail == 0 )
		printf("\tNothing unexpected.\n\n");

	return 0;
}

void Bu::UnitSuite::add( Test fTest, const Bu::FString &sName, Expect e )
{
	TestInfo ti;
	ti.sName = sName;
	ti.eExpect = e;
	long index = ti.sName.rfindIdx("::");
	if( index != -1 )
	{
		FString tmp = sSuiteName;
		tmp += ti.sName.getStr()+index;
		ti.sName = tmp;
	}
	ti.fTest = fTest;
	lTests.append( ti );
}

void Bu::UnitSuite::setName( const FString &sName )
{
	sSuiteName = sName;
}