OLD | NEW |
| (Empty) |
1 /* | |
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 | |
11 #include "webrtc/system_wrappers/include/logging.h" | |
12 | |
13 #include "webrtc/base/arraysize.h" | |
14 #include "webrtc/base/event.h" | |
15 #include "webrtc/system_wrappers/include/trace.h" | |
16 #include "webrtc/test/gtest.h" | |
17 | |
18 namespace webrtc { | |
19 namespace { | |
20 const char kTestLogString[] = "Incredibly important test message!(?)"; | |
21 const int kTestLevel = kTraceWarning; | |
22 | |
23 class LoggingTestCallback : public TraceCallback { | |
24 public: | |
25 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; | |
32 } | |
33 | |
34 std::string msg_str(msg, length); | |
35 if (msg_str.find(kTestLogString) != std::string::npos) | |
36 event_->Set(); | |
37 } | |
38 | |
39 rtc::Event* const event_; | |
40 }; | |
41 | |
42 } // namespace | |
43 | |
44 TEST(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 } | |
57 } // namespace webrtc | |
OLD | NEW |