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
|
/*
-------------------------------------------------------------------------
CxxTest: A lightweight C++ unit testing library.
Copyright (c) 2008 Sandia Corporation.
This software is distributed under the LGPL License v3
For more information, see the COPYING file in the top CxxTest directory.
Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation,
the U.S. Government retains certain rights in this software.
-------------------------------------------------------------------------
*/
#ifndef __cxxtest__Descriptions_cpp__
#define __cxxtest__Descriptions_cpp__
#include <cxxtest/Descriptions.h>
namespace CxxTest
{
TestDescription::~TestDescription() {}
SuiteDescription::~SuiteDescription() {}
WorldDescription::~WorldDescription() {}
//
// Convert total tests to string
//
#ifndef _CXXTEST_FACTOR
char *WorldDescription::strTotalTests(char *s) const
{
numberToString(numTotalTests(), s);
return s;
}
#else // _CXXTEST_FACTOR
char *WorldDescription::strTotalTests(char *s) const
{
char *p = numberToString(numTotalTests(), s);
if (numTotalTests() <= 1)
{
return s;
}
unsigned n = numTotalTests();
unsigned numFactors = 0;
for (unsigned factor = 2; (factor * factor) <= n; factor += (factor == 2) ? 1 : 2)
{
unsigned power;
for (power = 0; (n % factor) == 0; n /= factor)
{
++ power;
}
if (!power)
{
continue;
}
p = numberToString(factor, copyString(p, (numFactors == 0) ? " = " : " * "));
if (power > 1)
{
p = numberToString(power, copyString(p, "^"));
}
++ numFactors;
}
if (n > 1)
{
if (!numFactors)
{
copyString(p, tracker().failedTests() ? " :(" : tracker().warnings() ? " :|" : " :)");
}
else
{
numberToString(n, copyString(p, " * "));
}
}
return s;
}
#endif // _CXXTEST_FACTOR
}
#endif // __cxxtest__Descriptions_cpp__
|