121 lines
3.3 KiB
C++

/*
==============================================================================
This file is part of the JUCE library.
Copyright (c) 2022 - Raw Material Software Limited
JUCE is an open source library subject to commercial or open-source
licensing.
By using JUCE, you agree to the terms of both the JUCE 7 End-User License
Agreement and JUCE Privacy Policy.
End User License Agreement: www.juce.com/juce-7-licence
Privacy Policy: www.juce.com/juce-privacy-policy
Or: You may also use this code under the terms of the GPL v3 (see
www.gnu.org/licenses).
JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
DISCLAIMED.
==============================================================================
*/
#include <JuceHeader.h>
//==============================================================================
class ConsoleLogger : public Logger
{
void logMessage (const String& message) override
{
std::cout << message << std::endl;
#if JUCE_WINDOWS
Logger::outputDebugString (message);
#endif
}
};
//==============================================================================
class ConsoleUnitTestRunner : public UnitTestRunner
{
void logMessage (const String& message) override
{
Logger::writeToLog (message);
}
};
//==============================================================================
int main (int argc, char **argv)
{
ArgumentList args (argc, argv);
if (args.containsOption ("--help|-h"))
{
std::cout << argv[0] << " [--help|-h] [--list-categories] [--category category] [--seed seed]" << std::endl;
return 0;
}
if (args.containsOption ("--list-categories"))
{
for (auto& category : UnitTest::getAllCategories())
std::cout << category << std::endl;
return 0;
}
ConsoleLogger logger;
Logger::setCurrentLogger (&logger);
ConsoleUnitTestRunner runner;
auto seed = [&args]
{
if (args.containsOption ("--seed"))
{
auto seedValueString = args.getValueForOption ("--seed");
if (seedValueString.startsWith ("0x"))
return seedValueString.getHexValue64();
return seedValueString.getLargeIntValue();
}
return Random::getSystemRandom().nextInt64();
}();
if (args.containsOption ("--category"))
runner.runTestsInCategory (args.getValueForOption ("--category"), seed);
else
runner.runAllTests (seed);
std::vector<String> failures;
for (int i = 0; i < runner.getNumResults(); ++i)
{
auto* result = runner.getResult (i);
if (result->failures > 0)
failures.push_back (result->unitTestName + " / " + result->subcategoryName + ": " + String (result->failures) + " test failure" + (result->failures > 1 ? "s" : ""));
}
if (! failures.empty())
{
logger.writeToLog (newLine + "Test failure summary:" + newLine);
for (const auto& failure : failures)
logger.writeToLog (failure);
Logger::setCurrentLogger (nullptr);
return 1;
}
logger.writeToLog (newLine + "All tests completed successfully");
Logger::setCurrentLogger (nullptr);
return 0;
}