From 309e1d5d3b1985d59b39da7e81045e59e88b2a4a Mon Sep 17 00:00:00 2001 From: "kosak@google.com" Date: Mon, 17 Nov 2014 02:04:46 +0000 Subject: Fix gmock Action behaviour when return type is Wrapper git-svn-id: http://googlemock.googlecode.com/svn/trunk@492 8415998a-534a-0410-bf83-d39667b30386 --- test/gmock-actions_test.cc | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) (limited to 'test') diff --git a/test/gmock-actions_test.cc b/test/gmock-actions_test.cc index 28b48f1..8089a81 100644 --- a/test/gmock-actions_test.cc +++ b/test/gmock-actions_test.cc @@ -509,6 +509,26 @@ TEST(ReturnTest, AcceptsStringLiteral) { EXPECT_EQ("world", a2.Perform(make_tuple())); } +// Test struct which wraps a vector of integers. Used in +// 'SupportsWrapperReturnType' test. +struct IntegerVectorWrapper { + std::vector * v; + IntegerVectorWrapper(std::vector& _v) : v(&_v) {} // NOLINT +}; + +// Tests that Return() works when return type is a wrapper type. +TEST(ReturnTest, SupportsWrapperReturnType) { + // Initialize vector of integers. + std::vector v; + for (int i = 0; i < 5; ++i) v.push_back(i); + + // Return() called with 'v' as argument. The Action will return the same data + // as 'v' (copy) but it will be wrapped in an IntegerVectorWrapper. + Action a = Return(v); + const std::vector& result = *(a.Perform(make_tuple()).v); + EXPECT_THAT(result, ::testing::ElementsAre(0, 1, 2, 3, 4)); +} + // Tests that Return(v) is covaraint. struct Base { -- cgit v1.2.1