The JUCE cross-platform C++ framework, with DISTRHO/KXStudio specific changes
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

121 lines
3.4KB

  1. /*
  2. ==============================================================================
  3. This file is part of the JUCE library.
  4. Copyright (c) 2022 - Raw Material Software Limited
  5. JUCE is an open source library subject to commercial or open-source
  6. licensing.
  7. By using JUCE, you agree to the terms of both the JUCE 7 End-User License
  8. Agreement and JUCE Privacy Policy.
  9. End User License Agreement: www.juce.com/juce-7-licence
  10. Privacy Policy: www.juce.com/juce-privacy-policy
  11. Or: You may also use this code under the terms of the GPL v3 (see
  12. www.gnu.org/licenses).
  13. JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
  14. EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
  15. DISCLAIMED.
  16. ==============================================================================
  17. */
  18. #include <JuceHeader.h>
  19. //==============================================================================
  20. class ConsoleLogger final : public Logger
  21. {
  22. void logMessage (const String& message) override
  23. {
  24. std::cout << message << std::endl;
  25. #if JUCE_WINDOWS
  26. Logger::outputDebugString (message);
  27. #endif
  28. }
  29. };
  30. //==============================================================================
  31. class ConsoleUnitTestRunner final : public UnitTestRunner
  32. {
  33. void logMessage (const String& message) override
  34. {
  35. Logger::writeToLog (message);
  36. }
  37. };
  38. //==============================================================================
  39. int main (int argc, char **argv)
  40. {
  41. ArgumentList args (argc, argv);
  42. if (args.containsOption ("--help|-h"))
  43. {
  44. std::cout << argv[0] << " [--help|-h] [--list-categories] [--category=category] [--seed=seed]" << std::endl;
  45. return 0;
  46. }
  47. if (args.containsOption ("--list-categories"))
  48. {
  49. for (auto& category : UnitTest::getAllCategories())
  50. std::cout << category << std::endl;
  51. return 0;
  52. }
  53. ConsoleLogger logger;
  54. Logger::setCurrentLogger (&logger);
  55. ConsoleUnitTestRunner runner;
  56. auto seed = [&args]
  57. {
  58. if (args.containsOption ("--seed"))
  59. {
  60. auto seedValueString = args.getValueForOption ("--seed");
  61. if (seedValueString.startsWith ("0x"))
  62. return seedValueString.getHexValue64();
  63. return seedValueString.getLargeIntValue();
  64. }
  65. return Random::getSystemRandom().nextInt64();
  66. }();
  67. if (args.containsOption ("--category"))
  68. runner.runTestsInCategory (args.getValueForOption ("--category"), seed);
  69. else
  70. runner.runAllTests (seed);
  71. std::vector<String> failures;
  72. for (int i = 0; i < runner.getNumResults(); ++i)
  73. {
  74. auto* result = runner.getResult (i);
  75. if (result->failures > 0)
  76. failures.push_back (result->unitTestName + " / " + result->subcategoryName + ": " + String (result->failures) + " test failure" + (result->failures > 1 ? "s" : ""));
  77. }
  78. if (! failures.empty())
  79. {
  80. logger.writeToLog (newLine + "Test failure summary:" + newLine);
  81. for (const auto& failure : failures)
  82. logger.writeToLog (failure);
  83. Logger::setCurrentLogger (nullptr);
  84. return 1;
  85. }
  86. logger.writeToLog (newLine + "All tests completed successfully");
  87. Logger::setCurrentLogger (nullptr);
  88. return 0;
  89. }