1 /*
2 * COPYRIGHT AND PERMISSION NOTICE
3 *
4 * Copyright (c) 2003 Embedded Unit Project
5 *
6 * All rights reserved.
7 *
8 * Permission is hereby granted, free of charge, to any person obtaining
9 * a copy of this software and associated documentation files (the
10 * "Software"), to deal in the Software without restriction, including
11 * without limitation the rights to use, copy, modify, merge, publish,
12 * distribute, and/or sell copies of the Software, and to permit persons
13 * to whom the Software is furnished to do so, provided that the above
14 * copyright notice(s) and this permission notice appear in all copies
15 * of the Software and that both the above copyright notice(s) and this
16 * permission notice appear in supporting documentation.
17 *
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
19 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
20 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT
21 * OF THIRD PARTY RIGHTS. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
22 * HOLDERS INCLUDED IN THIS NOTICE BE LIABLE FOR ANY CLAIM, OR ANY
23 * SPECIAL INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES WHATSOEVER
24 * RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF
25 * CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
26 * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
27 *
28 * Except as contained in this notice, the name of a copyright holder
29 * shall not be used in advertising or otherwise to promote the sale,
30 * use or other dealings in this Software without prior written
31 * authorization of the copyright holder.
32 *
33 * $Id: TestCaller.c,v 1.6 2004/02/10 16:19:29 arms22 Exp $
34 */
35 #include "Test.h"
36 #include "TestCase.h"
37 #include "TestCaller.h"
38
TestCaller_name(TestCaller * self)39 char* TestCaller_name(TestCaller* self)
40 {
41 return self->name;
42 }
43
TestCaller_run(TestCaller * self,TestResult * result)44 void TestCaller_run(TestCaller* self,TestResult* result)
45 {
46 TestCase cs = new_TestCase(0,0,0,0);
47 int i;
48 cs.setUp= self->setUp;
49 cs.tearDown = self->tearDown;
50 for (i=0; i<self->numberOfFixtuers; i++) {
51 cs.name = self->fixtuers[i].name;
52 cs.runTest = self->fixtuers[i].test;
53 /*run test*/
54 Test_run(&cs,result);
55 }
56 }
57
TestCaller_countTestCases(TestCaller * self)58 int TestCaller_countTestCases(TestCaller* self)
59 {
60 return self->numberOfFixtuers;
61 }
62
63 const TestImplement TestCallerImplement = {
64 (TestNameFunction) TestCaller_name,
65 (TestRunFunction) TestCaller_run,
66 (TestCountTestCasesFunction)TestCaller_countTestCases,
67 };
68