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

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  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(megdnn::LogLevel level, const char* file, const char* func,
  40. int line, const char* fmt, va_list ap) {
  41. if (level < min_log_level) {
  42. return;
  43. }
  44. char msg[1024];
  45. vsnprintf(msg, sizeof(msg), fmt, ap);
  46. fprintf(stderr, "[megdnn] %s @%s:%d %s\n", msg, file, line, func);
  47. }
  48. } // namespace
  49. #if MEGDNN_X86
  50. #include "../src/x86/utils.h"
  51. #endif
  52. extern "C" int gtest_main(int argc, char** argv) {
  53. ::megdnn::set_log_handler(log_handler);
  54. set_log_level();
  55. ResetSeedListener listener;
  56. auto&& listeners = ::testing::UnitTest::GetInstance()->listeners();
  57. ::testing::InitGoogleTest(&argc, argv);
  58. listeners.Append(&listener);
  59. auto ret = RUN_ALL_TESTS();
  60. listeners.Release(&listener);
  61. return ret;
  62. }
  63. // vim: syntax=cpp.doxygen

MegEngine 安装包中集成了使用 GPU 运行代码所需的 CUDA 环境,不用区分 CPU 和 GPU 版。 如果想要运行 GPU 程序,请确保机器本身配有 GPU 硬件设备并安装好驱动。 如果你想体验在云端 GPU 算力平台进行深度学习开发的感觉,欢迎访问 MegStudio 平台