You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

gtest_main.cpp 1.7 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. #include <gtest/gtest.h>
  2. #include "megdnn/basic_types.h"
  3. #include "src/common/utils.h"
  4. #include "test/common/random_state.h"
  5. namespace {
  6. class ResetSeedListener : public ::testing::EmptyTestEventListener {
  7. void OnTestStart(const ::testing::TestInfo&) override {
  8. megdnn::test::RandomState::reset();
  9. }
  10. };
  11. megdnn::LogLevel min_log_level;
  12. void set_log_level() {
  13. megdnn::LogLevel level = megdnn::LogLevel::INFO;
  14. auto setting = std::getenv("MEGDNN_LOG_LEVEL");
  15. if (setting) {
  16. if (!strcmp(setting, "INFO")) {
  17. level = megdnn::LogLevel::INFO;
  18. } else if (!strcmp(setting, "DEBUG")) {
  19. level = megdnn::LogLevel::DEBUG;
  20. } else if (!strcmp(setting, "WARN")) {
  21. level = megdnn::LogLevel::WARN;
  22. } else {
  23. megdnn_assert(!strcmp(setting, "ERROR"));
  24. level = megdnn::LogLevel::ERROR;
  25. }
  26. }
  27. min_log_level = level;
  28. }
  29. void log_handler(
  30. megdnn::LogLevel level, const char* file, const char* func, int line,
  31. const char* fmt, va_list ap) {
  32. if (level < min_log_level) {
  33. return;
  34. }
  35. char msg[1024];
  36. vsnprintf(msg, sizeof(msg), fmt, ap);
  37. fprintf(stderr, "[megdnn] %s @%s:%d %s\n", msg, file, line, func);
  38. }
  39. } // namespace
  40. #if MEGDNN_X86
  41. #include "../src/x86/utils.h"
  42. #endif
  43. extern "C" int gtest_main(int argc, char** argv) {
  44. ::megdnn::set_log_handler(log_handler);
  45. set_log_level();
  46. ResetSeedListener listener;
  47. auto&& listeners = ::testing::UnitTest::GetInstance()->listeners();
  48. ::testing::InitGoogleTest(&argc, argv);
  49. listeners.Append(&listener);
  50. auto ret = RUN_ALL_TESTS();
  51. listeners.Release(&listener);
  52. return ret;
  53. }
  54. // vim: syntax=cpp.doxygen