112 lines
3.1 KiB
C++
112 lines
3.1 KiB
C++
//
|
|
// Copyright (C) 2012 The Android Open Source Project
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
//
|
|
|
|
#include "shill/mock_log.h"
|
|
|
|
#include <gmock/gmock.h>
|
|
#include <gtest/gtest.h>
|
|
|
|
#include "shill/logging.h"
|
|
|
|
|
|
using ::std::string;
|
|
using ::testing::_;
|
|
|
|
namespace shill {
|
|
|
|
namespace Logging {
|
|
static auto kModuleLogScope = ScopeLogger::kManager;
|
|
static string ObjectID(testing::Test* m) { return "(mock_log_test)"; }
|
|
}
|
|
|
|
class MockLogTest : public testing::Test {
|
|
protected:
|
|
MockLogTest() {}
|
|
|
|
void LogSomething(const string& message) const {
|
|
LOG(INFO) << message;
|
|
}
|
|
void SlogSomething(testing::Test* t, const string& message) const {
|
|
ScopeLogger::GetInstance()->EnableScopesByName("manager");
|
|
ScopeLogger::GetInstance()->set_verbose_level(2);
|
|
SLOG(t, 2) << message;
|
|
ScopeLogger::GetInstance()->EnableScopesByName("-manager");
|
|
ScopeLogger::GetInstance()->set_verbose_level(0);
|
|
}
|
|
};
|
|
|
|
TEST_F(MockLogTest, MatchMessageOnly) {
|
|
ScopedMockLog log;
|
|
const string kMessage("Something");
|
|
EXPECT_CALL(log, Log(_, _, kMessage));
|
|
LogSomething(kMessage);
|
|
}
|
|
|
|
TEST_F(MockLogTest, MatchSeverityAndMessage) {
|
|
ScopedMockLog log;
|
|
const string kMessage("Something");
|
|
EXPECT_CALL(log, Log(logging::LOG_INFO, _, kMessage));
|
|
LogSomething(kMessage);
|
|
}
|
|
|
|
TEST_F(MockLogTest, MatchSeverityAndFileAndMessage) {
|
|
ScopedMockLog log;
|
|
const string kMessage("Something");
|
|
EXPECT_CALL(log, Log(logging::LOG_INFO,
|
|
::testing::EndsWith("mock_log_unittest.cc"), kMessage));
|
|
LogSomething(kMessage);
|
|
}
|
|
|
|
TEST_F(MockLogTest, MatchEmptyString) {
|
|
ScopedMockLog log;
|
|
const string kMessage("");
|
|
EXPECT_CALL(log, Log(_, _, kMessage));
|
|
LogSomething(kMessage);
|
|
}
|
|
|
|
TEST_F(MockLogTest, MatchMessageContainsBracketAndNewline) {
|
|
ScopedMockLog log;
|
|
const string kMessage("blah [and more blah] \n yet more blah\n\n\n");
|
|
EXPECT_CALL(log, Log(_, _, kMessage));
|
|
LogSomething(kMessage);
|
|
}
|
|
|
|
TEST_F(MockLogTest, MatchSlog) {
|
|
ScopedMockLog log;
|
|
const string kMessage("Something");
|
|
const string kLogMessage("(anon) Something");
|
|
EXPECT_CALL(log, Log(_, _, kLogMessage));
|
|
SlogSomething(nullptr, kMessage);
|
|
}
|
|
|
|
TEST_F(MockLogTest, MatchSlogWithObject) {
|
|
ScopedMockLog log;
|
|
const string kMessage("Something");
|
|
const string kLogMessage("(mock_log_test) Something");
|
|
EXPECT_CALL(log, Log(_, _, kLogMessage));
|
|
SlogSomething(this, kMessage);
|
|
}
|
|
|
|
TEST_F(MockLogTest, MatchWithGmockMatchers) {
|
|
ScopedMockLog log;
|
|
const string kMessage("Something");
|
|
EXPECT_CALL(log, Log(::testing::Lt(::logging::LOG_ERROR),
|
|
::testing::EndsWith(".cc"),
|
|
::testing::StartsWith("Some")));
|
|
LogSomething(kMessage);
|
|
}
|
|
|
|
} // namespace shill
|