summaryrefslogtreecommitdiffstats
path: root/src/jaegertracing/opentelemetry-cpp/sdk/test/common/global_log_handle_test.cc
blob: a38bdc8728ed92f567a5fcb9bdb5086c1f973d39 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
// Copyright The OpenTelemetry Authors
// SPDX-License-Identifier: Apache-2.0

#include "opentelemetry/sdk/common/global_log_handler.h"

#include <gtest/gtest.h>

#include <cstring>

class CustomLogHandler : public opentelemetry::sdk::common::internal_log::LogHandler
{
public:
  void Handle(opentelemetry::sdk::common::internal_log::LogLevel level,
              const char *,
              int,
              const char *msg,
              const opentelemetry::sdk::common::AttributeMap &) noexcept override
  {
    if (level == opentelemetry::sdk::common::internal_log::LogLevel::Debug)
    {
      EXPECT_EQ(0, strncmp(msg, "Debug message", 13));
    }
    else if (level == opentelemetry::sdk::common::internal_log::LogLevel::Error)
    {
      EXPECT_EQ(0, strncmp(msg, "Error message", 13));
    }
    else if (level == opentelemetry::sdk::common::internal_log::LogLevel::Info)
    {
      EXPECT_EQ(0, strncmp(msg, "Info message", 12));
    }
    else if (level == opentelemetry::sdk::common::internal_log::LogLevel::Warning)
    {
      EXPECT_EQ(0, strncmp(msg, "Warning message", 15));
    }
    ++count;
  }

  size_t count = 0;
};

TEST(GlobalLogHandleTest, CustomLogHandler)
{
  using opentelemetry::sdk::common::internal_log::LogHandler;
  auto backup_log_handle =
      opentelemetry::sdk::common::internal_log::GlobalLogHandler::GetLogHandler();
  auto backup_log_level = opentelemetry::sdk::common::internal_log::GlobalLogHandler::GetLogLevel();

  auto custom_log_handler = opentelemetry::nostd::shared_ptr<LogHandler>(new CustomLogHandler{});
  opentelemetry::sdk::common::internal_log::GlobalLogHandler::SetLogHandler(custom_log_handler);
  auto before_count = static_cast<CustomLogHandler *>(custom_log_handler.get())->count;
  opentelemetry::sdk::common::AttributeMap attributes = {
      {"url", "https://opentelemetry.io/"}, {"content-length", 0}, {"content-type", "text/html"}};
  OTEL_INTERNAL_LOG_ERROR("Error message");
  OTEL_INTERNAL_LOG_DEBUG("Debug message. Headers:", attributes);
  EXPECT_EQ(before_count + 1, static_cast<CustomLogHandler *>(custom_log_handler.get())->count);

  opentelemetry::sdk::common::internal_log::GlobalLogHandler::SetLogLevel(
      opentelemetry::sdk::common::internal_log::LogLevel::Debug);
  OTEL_INTERNAL_LOG_ERROR("Error message");
  OTEL_INTERNAL_LOG_DEBUG("Debug message. Headers:", attributes);
  OTEL_INTERNAL_LOG_INFO("Info message");
  OTEL_INTERNAL_LOG_WARN("Warning message");
  EXPECT_EQ(before_count + 5, static_cast<CustomLogHandler *>(custom_log_handler.get())->count);

  opentelemetry::sdk::common::internal_log::GlobalLogHandler::SetLogHandler(backup_log_handle);
  opentelemetry::sdk::common::internal_log::GlobalLogHandler::SetLogLevel(backup_log_level);
}