testcore.cpp
1 //------------------------------------------------------------------------------
2 // testcore.cpp
3 //------------------------------------------------------------------------------
4 //
5 // This program is free software; you can redistribute it and/or
6 // modify it under the terms of the GNU General Public License
7 // as published by the Free Software Foundation; either version 2
8 // of the License, or (at your option) any later version.
9 //
10 // This program is distributed in the hope that it will be useful,
11 // but WITHOUT ANY WARRANTY; without even the implied warranty of
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 // GNU General Public License for more details.
14 //
15 // You should have received a copy of the GNU General Public License
16 // along with this program; if not, write to the Free Software
17 // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
18 // 02110-1301, USA.
19 //
20 //------------------------------------------------------------------------------
21 // Copyright (C) 2010 "Zalewa" <zalewapl@gmail.com>
22 //------------------------------------------------------------------------------
23 #include "testcore.h"
24 #include <QTime>
25 
26 TestCore::TestCore()
27 {
28  clearCounters();
29 }
30 
32 {
33  testsFailed = 0;
34  testsSucceeded = 0;
35 }
36 
38 {
39  testLog << "--------------------------------------------------------";
40  testLog << QString("Test: %1").arg(pTest->testName());
41  testLog << "--------------------------------------------------------";
42 
43  QTime time;
44  time.start();
45 
46  bool bResult = pTest->executeTest();
47  delete pTest;
48 
49  int executionTime = time.elapsed();
50 
51  QString resultString = "Result: %1. Time: %2 ms";
52  resultString = resultString.arg(bResult ? "SUCCESS" : "FAIL").arg(executionTime);
53 
54  testLog << "--------------------------------------------------------";
55  testLog << resultString;
56  testLog << "--------------------------------------------------------";
57  testLog << "";
58 
59  if (bResult)
60  {
61  ++testsSucceeded;
62  }
63  else
64  {
65  ++testsFailed;
66  }
67 }
Base class for Test Units.
Definition: testbase.h:42
void clearCounters()
Clears success/fail counters.
Definition: testcore.cpp:31
void executeTest(TestUnitBase *pTest)
Definition: testcore.cpp:37