Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Diff: src/CppUTest/TestOutput.cpp
- Revision:
- 0:0b799af9d58e
- Child:
- 1:4769360130ed
diff -r 000000000000 -r 0b799af9d58e src/CppUTest/TestOutput.cpp
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/src/CppUTest/TestOutput.cpp Tue Jan 28 09:27:41 2014 +0000
@@ -0,0 +1,253 @@
+/*
+ * 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/TestOutput.h"
+#include "CppUTest/PlatformSpecificFunctions.h"
+
+TestOutput::WorkingEnvironment TestOutput::workingEnvironment_ = TestOutput::detectEnvironment;
+
+void TestOutput::setWorkingEnvironment(TestOutput::WorkingEnvironment workEnvironment)
+{
+ workingEnvironment_ = workEnvironment;
+}
+
+TestOutput::WorkingEnvironment TestOutput::getWorkingEnvironment()
+{
+ if (workingEnvironment_ == TestOutput::detectEnvironment)
+ return PlatformSpecificGetWorkingEnvironment();
+ return workingEnvironment_;
+}
+
+
+TestOutput::TestOutput() :
+ dotCount_(0), verbose_(false), progressIndication_(".")
+{
+}
+
+TestOutput::~TestOutput()
+{
+}
+
+void TestOutput::verbose()
+{
+ verbose_ = true;
+}
+
+void TestOutput::print(const char* str)
+{
+ printBuffer(str);
+}
+
+void TestOutput::print(long n)
+{
+ print(StringFrom(n).asCharString());
+}
+
+void TestOutput::printDouble(double d)
+{
+ print(StringFrom(d).asCharString());
+}
+
+void TestOutput::printHex(long n)
+{
+ print(HexStringFrom(n).asCharString());
+}
+
+TestOutput& operator<<(TestOutput& p, const char* s)
+{
+ p.print(s);
+ return p;
+}
+
+TestOutput& operator<<(TestOutput& p, long int i)
+{
+ p.print(i);
+ return p;
+}
+
+void TestOutput::printCurrentTestStarted(const UtestShell& test)
+{
+ if (verbose_) print(test.getFormattedName().asCharString());
+}
+
+void TestOutput::printCurrentTestEnded(const TestResult& res)
+{
+ if (verbose_) {
+ print(" - ");
+ print(res.getCurrentTestTotalExecutionTime());
+ print(" ms\n");
+ }
+ else {
+ printProgressIndicator();
+ }
+}
+
+void TestOutput::printProgressIndicator()
+{
+ print(progressIndication_);
+ if (++dotCount_ % 50 == 0) print("\n");
+}
+
+void TestOutput::setProgressIndicator(const char* indicator)
+{
+ progressIndication_ = indicator;
+}
+
+void TestOutput::printTestsStarted()
+{
+}
+
+void TestOutput::printCurrentGroupStarted(const UtestShell& /*test*/)
+{
+}
+
+void TestOutput::printCurrentGroupEnded(const TestResult& /*res*/)
+{
+}
+
+void TestOutput::flush()
+{
+}
+
+void TestOutput::printTestsEnded(const TestResult& result)
+{
+ if (result.getFailureCount() > 0) {
+ print("\nErrors (");
+ print(result.getFailureCount());
+ print(" failures, ");
+ }
+ else {
+ print("\nOK (");
+ }
+ print(result.getTestCount());
+ print(" tests, ");
+ print(result.getRunCount());
+ print(" ran, ");
+ print(result.getCheckCount());
+ print(" checks, ");
+ print(result.getIgnoredCount());
+ print(" ignored, ");
+ print(result.getFilteredOutCount());
+ print(" filtered out, ");
+ print(result.getTotalExecutionTime());
+ print(" ms)\n\n");
+}
+
+void TestOutput::printTestRun(int number, int total)
+{
+ if (total > 1) {
+ print("Test run ");
+ print(number);
+ print(" of ");
+ print(total);
+ print("\n");
+ }
+}
+
+void TestOutput::print(const TestFailure& failure)
+{
+ if (failure.isOutsideTestFile() || failure.isInHelperFunction())
+ printFileAndLineForTestAndFailure(failure);
+ else
+ printFileAndLineForFailure(failure);
+
+ printFailureMessage(failure.getMessage());
+}
+
+void TestOutput::printFileAndLineForTestAndFailure(const TestFailure& failure)
+{
+ printErrorInFileOnLineFormattedForWorkingEnvironment(failure.getTestFileName(), failure.getTestLineNumber());
+ printFailureInTest(failure.getTestName());
+ printErrorInFileOnLineFormattedForWorkingEnvironment(failure.getFileName(), failure.getFailureLineNumber());
+}
+
+void TestOutput::printFileAndLineForFailure(const TestFailure& failure)
+{
+ printErrorInFileOnLineFormattedForWorkingEnvironment(failure.getFileName(), failure.getFailureLineNumber());
+ printFailureInTest(failure.getTestName());
+}
+
+void TestOutput::printFailureInTest(SimpleString testName)
+{
+ print(" Failure in ");
+ print(testName.asCharString());
+}
+
+void TestOutput::printFailureMessage(SimpleString reason)
+{
+ print("\n");
+ print("\t");
+ print(reason.asCharString());
+ print("\n\n");
+}
+
+void TestOutput::printErrorInFileOnLineFormattedForWorkingEnvironment(SimpleString file, int lineNumber)
+{
+ if (TestOutput::getWorkingEnvironment() == TestOutput::vistualStudio)
+ printVistualStudioErrorInFileOnLine(file, lineNumber);
+ else
+ printEclipseErrorInFileOnLine(file, lineNumber);
+}
+
+void TestOutput::printEclipseErrorInFileOnLine(SimpleString file, int lineNumber)
+{
+ print("\n");
+ print(file.asCharString());
+ print(":");
+ print(lineNumber);
+ print(":");
+ print(" error:");
+}
+
+void TestOutput::printVistualStudioErrorInFileOnLine(SimpleString file, int lineNumber)
+{
+ print("\n");
+ print(file.asCharString());
+ print("(");
+ print(lineNumber);
+ print("):");
+ print(" error:");
+}
+
+void ConsoleTestOutput::printBuffer(const char* s)
+{
+ while (*s) {
+ PlatformSpecificPutchar(*s);
+ s++;
+ }
+ flush();
+}
+
+void ConsoleTestOutput::flush()
+{
+ PlatformSpecificFlush();
+}
+
+StringBufferTestOutput::~StringBufferTestOutput()
+{
+}