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 2.1 kB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. /**
  2. * \file dnn/test/gtest_main.cpp
  3. * MegEngine is Licensed under the Apache License, Version 2.0 (the "License")
  4. *
  5. * Copyright (c) 2014-2021 Megvii Inc. All rights reserved.
  6. *
  7. * Unless required by applicable law or agreed to in writing,
  8. * software distributed under the License is distributed on an
  9. * "AS IS" BASIS, WITHOUT ARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  10. */
  11. #include <gtest/gtest.h>
  12. #include "megdnn/basic_types.h"
  13. #include "src/common/utils.h"
  14. #include "test/common/random_state.h"
  15. namespace {
  16. class ResetSeedListener : public ::testing::EmptyTestEventListener {
  17. void OnTestStart(const ::testing::TestInfo&) override {
  18. megdnn::test::RandomState::reset();
  19. }
  20. };
  21. megdnn::LogLevel min_log_level;
  22. void set_log_level() {
  23. megdnn::LogLevel level = megdnn::LogLevel::INFO;
  24. auto setting = std::getenv("MEGDNN_LOG_LEVEL");
  25. if (setting) {
  26. if (!strcmp(setting, "INFO")) {
  27. level = megdnn::LogLevel::INFO;
  28. } else if (!strcmp(setting, "DEBUG")) {
  29. level = megdnn::LogLevel::DEBUG;
  30. } else if (!strcmp(setting, "WARN")) {
  31. level = megdnn::LogLevel::WARN;
  32. } else {
  33. megdnn_assert(!strcmp(setting, "ERROR"));
  34. level = megdnn::LogLevel::ERROR;
  35. }
  36. }
  37. min_log_level = level;
  38. }
  39. void log_handler(
  40. megdnn::LogLevel level, const char* file, const char* func, int line,
  41. const char* fmt, va_list ap) {
  42. if (level < min_log_level) {
  43. return;
  44. }
  45. char msg[1024];
  46. vsnprintf(msg, sizeof(msg), fmt, ap);
  47. fprintf(stderr, "[megdnn] %s @%s:%d %s\n", msg, file, line, func);
  48. }
  49. } // namespace
  50. #if MEGDNN_X86
  51. #include "../src/x86/utils.h"
  52. #endif
  53. extern "C" int gtest_main(int argc, char** argv) {
  54. ::megdnn::set_log_handler(log_handler);
  55. set_log_level();
  56. ResetSeedListener listener;
  57. auto&& listeners = ::testing::UnitTest::GetInstance()->listeners();
  58. ::testing::InitGoogleTest(&argc, argv);
  59. listeners.Append(&listener);
  60. auto ret = RUN_ALL_TESTS();
  61. listeners.Release(&listener);
  62. return ret;
  63. }
  64. // vim: syntax=cpp.doxygen