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