fork

Fork of cpputest by Rohit Grover

src/CppUTest/TestResult.cpp

Committer:
Kojto
Date:
2015-05-13
Revision:
3:9e8c8907d9ee
Parent:
1:4769360130ed

File content as of revision 3:9e8c8907d9ee:

/*
 * Copyright (c) 2007, Michael Feathers, James Grenning and Bas Vodde
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *     * Redistributions of source code must retain the above copyright
 *       notice, this list of conditions and the following disclaimer.
 *     * Redistributions in binary form must reproduce the above copyright
 *       notice, this list of conditions and the following disclaimer in the
 *       documentation and/or other materials provided with the distribution.
 *     * Neither the name of the <organization> nor the
 *       names of its contributors may be used to endorse or promote products
 *       derived from this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE EARLIER MENTIONED AUTHORS ``AS IS'' AND ANY
 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED. IN NO EVENT SHALL <copyright holder> BE LIABLE FOR ANY
 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

#include "CppUTest/TestHarness.h"
#include "CppUTest/TestResult.h"
#include "CppUTest/TestFailure.h"
#include "CppUTest/TestOutput.h"
#include "CppUTest/PlatformSpecificFunctions.h"

TestResult::TestResult(TestOutput& p) :
	output_(p), testCount_(0), runCount_(0), checkCount_(0), failureCount_(0), filteredOutCount_(0), ignoredCount_(0), totalExecutionTime_(0), timeStarted_(0), currentTestTimeStarted_(0),
			currentTestTotalExecutionTime_(0), currentGroupTimeStarted_(0), currentGroupTotalExecutionTime_(0)
{
}

void TestResult::setProgressIndicator(const char* indicator)
{
	output_.setProgressIndicator(indicator);
}

TestResult::~TestResult()
{
}

void TestResult::currentGroupStarted(UtestShell* test)
{
	output_.printCurrentGroupStarted(*test);
	currentGroupTimeStarted_ = GetPlatformSpecificTimeInMillis();
}

void TestResult::currentGroupEnded(UtestShell* /*test*/)
{
	currentGroupTotalExecutionTime_ = GetPlatformSpecificTimeInMillis() - currentGroupTimeStarted_;
	output_.printCurrentGroupEnded(*this);
}

void TestResult::currentTestStarted(UtestShell* test)
{
	output_.printCurrentTestStarted(*test);
	currentTestTimeStarted_ = GetPlatformSpecificTimeInMillis();
}

void TestResult::print(const char* text)
{
	output_.print(text);
}

void TestResult::currentTestEnded(UtestShell* /*test*/)
{
	currentTestTotalExecutionTime_ = GetPlatformSpecificTimeInMillis() - currentTestTimeStarted_;
	output_.printCurrentTestEnded(*this);

}

void TestResult::addFailure(const TestFailure& failure)
{
	output_.print(failure);
	failureCount_++;
}

void TestResult::countTest()
{
	testCount_++;
}

void TestResult::countRun()
{
	runCount_++;
}

void TestResult::countCheck()
{
	checkCount_++;
}

void TestResult::countFilteredOut()
{
	filteredOutCount_++;
}

void TestResult::countIgnored()
{
	ignoredCount_++;
}

void TestResult::testsStarted()
{
	timeStarted_ = GetPlatformSpecificTimeInMillis();
	output_.printTestsStarted();
}

void TestResult::testsEnded()
{
	long timeEnded = GetPlatformSpecificTimeInMillis();
	totalExecutionTime_ = timeEnded - timeStarted_;
	output_.printTestsEnded(*this);
}

long TestResult::getTotalExecutionTime() const
{
	return totalExecutionTime_;
}

void TestResult::setTotalExecutionTime(long exTime)
{
	totalExecutionTime_ = exTime;
}

long TestResult::getCurrentTestTotalExecutionTime() const
{
	return currentTestTotalExecutionTime_;
}

long TestResult::getCurrentGroupTotalExecutionTime() const
{
	return currentGroupTotalExecutionTime_;
}