Merge branch 'master' of https://github.com/google/googletest
This commit is contained in:
commit
6e37201260
@ -399,6 +399,16 @@ class GTEST_API_ Mock {
|
|||||||
static bool VerifyAndClear(void* mock_obj)
|
static bool VerifyAndClear(void* mock_obj)
|
||||||
GTEST_LOCK_EXCLUDED_(internal::g_gmock_mutex);
|
GTEST_LOCK_EXCLUDED_(internal::g_gmock_mutex);
|
||||||
|
|
||||||
|
// Returns whether the mock was created as a naggy mock (default)
|
||||||
|
static bool IsNaggy(void* mock_obj)
|
||||||
|
GTEST_LOCK_EXCLUDED_(internal::g_gmock_mutex);
|
||||||
|
// Returns whether the mock was created as a nice mock
|
||||||
|
static bool IsNice(void* mock_obj)
|
||||||
|
GTEST_LOCK_EXCLUDED_(internal::g_gmock_mutex);
|
||||||
|
// Returns whether the mock was created as a strict mock
|
||||||
|
static bool IsStrict(void* mock_obj)
|
||||||
|
GTEST_LOCK_EXCLUDED_(internal::g_gmock_mutex);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
friend class internal::UntypedFunctionMockerBase;
|
friend class internal::UntypedFunctionMockerBase;
|
||||||
|
|
||||||
|
@ -757,6 +757,19 @@ bool Mock::VerifyAndClearExpectationsLocked(void* mock_obj)
|
|||||||
return expectations_met;
|
return expectations_met;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool Mock::IsNaggy(void* mock_obj)
|
||||||
|
GTEST_LOCK_EXCLUDED_(internal::g_gmock_mutex) {
|
||||||
|
return Mock::GetReactionOnUninterestingCalls(mock_obj) == internal::kWarn;
|
||||||
|
}
|
||||||
|
bool Mock::IsNice(void* mock_obj)
|
||||||
|
GTEST_LOCK_EXCLUDED_(internal::g_gmock_mutex) {
|
||||||
|
return Mock::GetReactionOnUninterestingCalls(mock_obj) == internal::kAllow;
|
||||||
|
}
|
||||||
|
bool Mock::IsStrict(void* mock_obj)
|
||||||
|
GTEST_LOCK_EXCLUDED_(internal::g_gmock_mutex) {
|
||||||
|
return Mock::GetReactionOnUninterestingCalls(mock_obj) == internal::kFail;
|
||||||
|
}
|
||||||
|
|
||||||
// Registers a mock object and a mock method it owns.
|
// Registers a mock object and a mock method it owns.
|
||||||
void Mock::Register(const void* mock_obj,
|
void Mock::Register(const void* mock_obj,
|
||||||
internal::UntypedFunctionMockerBase* mocker)
|
internal::UntypedFunctionMockerBase* mocker)
|
||||||
|
@ -184,6 +184,13 @@ TEST(RawMockTest, InfoForUninterestingCall) {
|
|||||||
GMOCK_FLAG(verbose) = saved_flag;
|
GMOCK_FLAG(verbose) = saved_flag;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST(RawMockTest, IsNaggy_IsNice_IsStrict) {
|
||||||
|
MockFoo raw_foo;
|
||||||
|
EXPECT_TRUE(Mock::IsNaggy(&raw_foo));
|
||||||
|
EXPECT_FALSE(Mock::IsNice(&raw_foo));
|
||||||
|
EXPECT_FALSE(Mock::IsStrict(&raw_foo));
|
||||||
|
}
|
||||||
|
|
||||||
// Tests that a nice mock generates no warning for uninteresting calls.
|
// Tests that a nice mock generates no warning for uninteresting calls.
|
||||||
TEST(NiceMockTest, NoWarningForUninterestingCall) {
|
TEST(NiceMockTest, NoWarningForUninterestingCall) {
|
||||||
NiceMock<MockFoo> nice_foo;
|
NiceMock<MockFoo> nice_foo;
|
||||||
@ -309,6 +316,13 @@ TEST(NiceMockTest, AcceptsClassNamedMock) {
|
|||||||
}
|
}
|
||||||
#endif // !GTEST_OS_SYMBIAN && !GTEST_OS_WINDOWS_MOBILE
|
#endif // !GTEST_OS_SYMBIAN && !GTEST_OS_WINDOWS_MOBILE
|
||||||
|
|
||||||
|
TEST(NiceMockTest, IsNaggy_IsNice_IsStrict) {
|
||||||
|
NiceMock<MockFoo> nice_foo;
|
||||||
|
EXPECT_FALSE(Mock::IsNaggy(&nice_foo));
|
||||||
|
EXPECT_TRUE(Mock::IsNice(&nice_foo));
|
||||||
|
EXPECT_FALSE(Mock::IsStrict(&nice_foo));
|
||||||
|
}
|
||||||
|
|
||||||
#if GTEST_HAS_STREAM_REDIRECTION
|
#if GTEST_HAS_STREAM_REDIRECTION
|
||||||
|
|
||||||
// Tests that a naggy mock generates warnings for uninteresting calls.
|
// Tests that a naggy mock generates warnings for uninteresting calls.
|
||||||
@ -417,6 +431,13 @@ TEST(NaggyMockTest, AcceptsClassNamedMock) {
|
|||||||
}
|
}
|
||||||
#endif // !GTEST_OS_SYMBIAN && !GTEST_OS_WINDOWS_MOBILE
|
#endif // !GTEST_OS_SYMBIAN && !GTEST_OS_WINDOWS_MOBILE
|
||||||
|
|
||||||
|
TEST(NaggyMockTest, IsNaggy_IsNice_IsStrict) {
|
||||||
|
NaggyMock<MockFoo> naggy_foo;
|
||||||
|
EXPECT_TRUE(Mock::IsNaggy(&naggy_foo));
|
||||||
|
EXPECT_FALSE(Mock::IsNice(&naggy_foo));
|
||||||
|
EXPECT_FALSE(Mock::IsStrict(&naggy_foo));
|
||||||
|
}
|
||||||
|
|
||||||
// Tests that a strict mock allows expected calls.
|
// Tests that a strict mock allows expected calls.
|
||||||
TEST(StrictMockTest, AllowsExpectedCall) {
|
TEST(StrictMockTest, AllowsExpectedCall) {
|
||||||
StrictMock<MockFoo> strict_foo;
|
StrictMock<MockFoo> strict_foo;
|
||||||
@ -506,5 +527,12 @@ TEST(StrictMockTest, AcceptsClassNamedMock) {
|
|||||||
}
|
}
|
||||||
#endif // !GTEST_OS_SYMBIAN && !GTEST_OS_WINDOWS_MOBILE
|
#endif // !GTEST_OS_SYMBIAN && !GTEST_OS_WINDOWS_MOBILE
|
||||||
|
|
||||||
|
TEST(StrictMockTest, IsNaggy_IsNice_IsStrict) {
|
||||||
|
StrictMock<MockFoo> strict_foo;
|
||||||
|
EXPECT_FALSE(Mock::IsNaggy(&strict_foo));
|
||||||
|
EXPECT_FALSE(Mock::IsNice(&strict_foo));
|
||||||
|
EXPECT_TRUE(Mock::IsStrict(&strict_foo));
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace gmock_nice_strict_test
|
} // namespace gmock_nice_strict_test
|
||||||
} // namespace testing
|
} // namespace testing
|
||||||
|
@ -1487,7 +1487,7 @@ returns the value of `testing::PrintToString(GetParam())`. It does not work for
|
|||||||
|
|
||||||
NOTE: test names must be non-empty, unique, and may only contain ASCII
|
NOTE: test names must be non-empty, unique, and may only contain ASCII
|
||||||
alphanumeric characters. In particular, they [should not contain
|
alphanumeric characters. In particular, they [should not contain
|
||||||
underscores](https://g3doc.corp.google.com/third_party/googletest/googletest/g3doc/faq.md#no-underscores).
|
underscores](https://github.com/google/googletest/blob/master/googletest/docs/faq.md#why-should-test-case-names-and-test-names-not-contain-underscore).
|
||||||
|
|
||||||
```c++
|
```c++
|
||||||
class MyTestCase : public testing::TestWithParam<int> {};
|
class MyTestCase : public testing::TestWithParam<int> {};
|
||||||
|
Loading…
Reference in New Issue
Block a user