| 
							- /*
 -   ==============================================================================
 - 
 -    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;
 - }
 
 
  |