blob: b7318da1ad0413098889d8c3d56c738fb0323124 [file] [log] [blame]
andrew@webrtc.org50419b02012-11-14 19:07:54 +00001/*
2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
Henrik Kjellander98f53512015-10-28 18:17:40 +010011#include "webrtc/system_wrappers/include/logging.h"
andrew@webrtc.org50419b02012-11-14 19:07:54 +000012
kwiberg77eab702016-09-28 17:42:01 -070013#include "webrtc/test/gtest.h"
tommiaff4b702016-01-18 10:20:17 -080014#include "webrtc/base/arraysize.h"
15#include "webrtc/base/event.h"
Henrik Kjellander98f53512015-10-28 18:17:40 +010016#include "webrtc/system_wrappers/include/trace.h"
andrew@webrtc.org50419b02012-11-14 19:07:54 +000017
18namespace webrtc {
19namespace {
tommiaff4b702016-01-18 10:20:17 -080020const char kTestLogString[] = "Incredibly important test message!(?)";
21const int kTestLevel = kTraceWarning;
andrew@webrtc.org50419b02012-11-14 19:07:54 +000022
tommiaff4b702016-01-18 10:20:17 -080023class LoggingTestCallback : public TraceCallback {
andrew@webrtc.org50419b02012-11-14 19:07:54 +000024 public:
tommiaff4b702016-01-18 10:20:17 -080025 LoggingTestCallback(rtc::Event* event) : event_(event) {}
26
27 private:
28 void Print(TraceLevel level, const char* msg, int length) override {
29 if (static_cast<size_t>(length) < arraysize(kTestLogString) ||
30 level != kTestLevel) {
31 return;
andrew@webrtc.org50419b02012-11-14 19:07:54 +000032 }
tommiaff4b702016-01-18 10:20:17 -080033
34 std::string msg_str(msg, length);
35 if (msg_str.find(kTestLogString) != std::string::npos)
36 event_->Set();
andrew@webrtc.org50419b02012-11-14 19:07:54 +000037 }
38
tommiaff4b702016-01-18 10:20:17 -080039 rtc::Event* const event_;
andrew@webrtc.org50419b02012-11-14 19:07:54 +000040};
41
andrew@webrtc.org50419b02012-11-14 19:07:54 +000042} // namespace
tommiaff4b702016-01-18 10:20:17 -080043
44TEST(LoggingTest, LogStream) {
45 Trace::CreateTrace();
46
47 rtc::Event event(false, false);
48 LoggingTestCallback callback(&event);
49 Trace::SetTraceCallback(&callback);
50
51 LOG(LS_WARNING) << kTestLogString;
52 EXPECT_TRUE(event.Wait(2000));
53
54 Trace::SetTraceCallback(nullptr);
55 Trace::ReturnTrace();
56}
andrew@webrtc.org50419b02012-11-14 19:07:54 +000057} // namespace webrtc