gmock-generated-nice-strict.h 8.17 KB
Newer Older
zhanyong.wan's avatar
zhanyong.wan committed
1
2
3
// This file was GENERATED by command:
//     pump.py gmock-generated-nice-strict.h.pump
// DO NOT EDIT BY HAND!!!
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32

// Copyright 2008, Google Inc.
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are
// met:
//
//     * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
//     * Redistributions in binary form must reproduce the above
// copyright notice, this list of conditions and the following disclaimer
// in the documentation and/or other materials provided with the
// distribution.
//     * Neither the name of Google Inc. nor the names of its
// contributors may be used to endorse or promote products derived from
// this software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Gennadiy Civil's avatar
 
Gennadiy Civil committed
33

34

zhanyong.wan's avatar
zhanyong.wan committed
35
// Implements class templates NiceMock, NaggyMock, and StrictMock.
36
37
38
39
//
// Given a mock class MockFoo that is created using Google Mock,
// NiceMock<MockFoo> is a subclass of MockFoo that allows
// uninteresting calls (i.e. calls to mock methods that have no
zhanyong.wan's avatar
zhanyong.wan committed
40
41
42
43
// EXPECT_CALL specs), NaggyMock<MockFoo> is a subclass of MockFoo
// that prints a warning when an uninteresting call occurs, and
// StrictMock<MockFoo> is a subclass of MockFoo that treats all
// uninteresting calls as errors.
44
//
zhanyong.wan's avatar
zhanyong.wan committed
45
46
47
48
49
50
// Currently a mock is naggy by default, so MockFoo and
// NaggyMock<MockFoo> behave like the same.  However, we will soon
// switch the default behavior of mocks to be nice, as that in general
// leads to more maintainable tests.  When that happens, MockFoo will
// stop behaving like NaggyMock<MockFoo> and start behaving like
// NiceMock<MockFoo>.
51
//
zhanyong.wan's avatar
zhanyong.wan committed
52
// NiceMock, NaggyMock, and StrictMock "inherit" the constructors of
Gennadiy Civil's avatar
Gennadiy Civil committed
53
54
55
// their respective base class.  Therefore you can write
// NiceMock<MockFoo>(5, "a") to construct a nice mock where MockFoo
// has a constructor that accepts (int, const char*), for example.
zhanyong.wan's avatar
zhanyong.wan committed
56
57
58
59
60
61
62
63
//
// A known limitation is that NiceMock<MockFoo>, NaggyMock<MockFoo>,
// and StrictMock<MockFoo> only works for mock methods defined using
// the MOCK_METHOD* family of macros DIRECTLY in the MockFoo class.
// If a mock method is defined in a base class of MockFoo, the "nice"
// or "strict" modifier may not affect it, depending on the compiler.
// In particular, nesting NiceMock, NaggyMock, and StrictMock is NOT
// supported.
64

Gennadiy Civil's avatar
 
Gennadiy Civil committed
65
66
// GOOGLETEST_CM0002 DO NOT DELETE

67
68
69
#ifndef GMOCK_INCLUDE_GMOCK_GMOCK_GENERATED_NICE_STRICT_H_
#define GMOCK_INCLUDE_GMOCK_GMOCK_GENERATED_NICE_STRICT_H_

70
71
#include "gmock/gmock-spec-builders.h"
#include "gmock/internal/gmock-port.h"
72
73
74
75

namespace testing {

template <class MockClass>
76
class NiceMock : public MockClass {
77
 public:
78
79
80
81
  NiceMock() : MockClass() {
    ::testing::Mock::AllowUninterestingCalls(
        internal::ImplicitCast_<MockClass*>(this));
  }
Gennadiy Civil's avatar
Gennadiy Civil committed
82

Gennadiy Civil's avatar
 
Gennadiy Civil committed
83
84
85
86
87
  // Ideally, we would inherit base class's constructors through a using
  // declaration, which would preserve their visibility. However, many existing
  // tests rely on the fact that current implementation reexports protected
  // constructors as public. These tests would need to be cleaned up first.

Gennadiy Civil's avatar
Gennadiy Civil committed
88
89
90
  // Single argument constructor is special-cased so that it can be
  // made explicit.
  template <typename A>
91
92
93
94
  explicit NiceMock(A&& arg) : MockClass(std::forward<A>(arg)) {
    ::testing::Mock::AllowUninterestingCalls(
        internal::ImplicitCast_<MockClass*>(this));
  }
Gennadiy Civil's avatar
Gennadiy Civil committed
95
96
97
98

  template <typename A1, typename A2, typename... An>
  NiceMock(A1&& arg1, A2&& arg2, An&&... args)
      : MockClass(std::forward<A1>(arg1), std::forward<A2>(arg2),
99
100
101
102
                  std::forward<An>(args)...) {
    ::testing::Mock::AllowUninterestingCalls(
        internal::ImplicitCast_<MockClass*>(this));
  }
103

Abseil Team's avatar
Abseil Team committed
104
  ~NiceMock() {  // NOLINT
105
106
107
108
    ::testing::Mock::UnregisterCallReaction(
        internal::ImplicitCast_<MockClass*>(this));
  }

109
110
 private:
  GTEST_DISALLOW_COPY_AND_ASSIGN_(NiceMock);
111
112
};

zhanyong.wan's avatar
zhanyong.wan committed
113
template <class MockClass>
114
class NaggyMock : public MockClass {
zhanyong.wan's avatar
zhanyong.wan committed
115
 public:
116
117
118
119
  NaggyMock() : MockClass() {
    ::testing::Mock::WarnUninterestingCalls(
        internal::ImplicitCast_<MockClass*>(this));
  }
Gennadiy Civil's avatar
Gennadiy Civil committed
120

Gennadiy Civil's avatar
 
Gennadiy Civil committed
121
122
123
124
125
  // Ideally, we would inherit base class's constructors through a using
  // declaration, which would preserve their visibility. However, many existing
  // tests rely on the fact that current implementation reexports protected
  // constructors as public. These tests would need to be cleaned up first.

Gennadiy Civil's avatar
Gennadiy Civil committed
126
127
128
  // Single argument constructor is special-cased so that it can be
  // made explicit.
  template <typename A>
129
130
131
132
  explicit NaggyMock(A&& arg) : MockClass(std::forward<A>(arg)) {
    ::testing::Mock::WarnUninterestingCalls(
        internal::ImplicitCast_<MockClass*>(this));
  }
Gennadiy Civil's avatar
Gennadiy Civil committed
133
134
135
136

  template <typename A1, typename A2, typename... An>
  NaggyMock(A1&& arg1, A2&& arg2, An&&... args)
      : MockClass(std::forward<A1>(arg1), std::forward<A2>(arg2),
137
138
139
140
                  std::forward<An>(args)...) {
    ::testing::Mock::WarnUninterestingCalls(
        internal::ImplicitCast_<MockClass*>(this));
  }
zhanyong.wan's avatar
zhanyong.wan committed
141

Abseil Team's avatar
Abseil Team committed
142
  ~NaggyMock() {  // NOLINT
143
144
145
146
    ::testing::Mock::UnregisterCallReaction(
        internal::ImplicitCast_<MockClass*>(this));
  }

zhanyong.wan's avatar
zhanyong.wan committed
147
148
149
150
 private:
  GTEST_DISALLOW_COPY_AND_ASSIGN_(NaggyMock);
};

Gennadiy Civil's avatar
Gennadiy Civil committed
151
template <class MockClass>
152
class StrictMock : public MockClass {
153
 public:
154
155
156
157
  StrictMock() : MockClass() {
    ::testing::Mock::FailUninterestingCalls(
        internal::ImplicitCast_<MockClass*>(this));
  }
Gennadiy Civil's avatar
Gennadiy Civil committed
158

Gennadiy Civil's avatar
 
Gennadiy Civil committed
159
160
161
162
163
  // Ideally, we would inherit base class's constructors through a using
  // declaration, which would preserve their visibility. However, many existing
  // tests rely on the fact that current implementation reexports protected
  // constructors as public. These tests would need to be cleaned up first.

Gennadiy Civil's avatar
Gennadiy Civil committed
164
165
166
  // Single argument constructor is special-cased so that it can be
  // made explicit.
  template <typename A>
167
168
169
170
  explicit StrictMock(A&& arg) : MockClass(std::forward<A>(arg)) {
    ::testing::Mock::FailUninterestingCalls(
        internal::ImplicitCast_<MockClass*>(this));
  }
Gennadiy Civil's avatar
Gennadiy Civil committed
171
172
173
174

  template <typename A1, typename A2, typename... An>
  StrictMock(A1&& arg1, A2&& arg2, An&&... args)
      : MockClass(std::forward<A1>(arg1), std::forward<A2>(arg2),
175
176
177
178
                  std::forward<An>(args)...) {
    ::testing::Mock::FailUninterestingCalls(
        internal::ImplicitCast_<MockClass*>(this));
  }
179

Abseil Team's avatar
Abseil Team committed
180
  ~StrictMock() {  // NOLINT
181
182
183
184
    ::testing::Mock::UnregisterCallReaction(
        internal::ImplicitCast_<MockClass*>(this));
  }

185
186
 private:
  GTEST_DISALLOW_COPY_AND_ASSIGN_(StrictMock);
187
188
189
190
191
192
};

// The following specializations catch some (relatively more common)
// user errors of nesting nice and strict mocks.  They do NOT catch
// all possible errors.

zhanyong.wan's avatar
zhanyong.wan committed
193
194
195
// These specializations are declared but not defined, as NiceMock,
// NaggyMock, and StrictMock cannot be nested.

196
197
198
template <typename MockClass>
class NiceMock<NiceMock<MockClass> >;
template <typename MockClass>
zhanyong.wan's avatar
zhanyong.wan committed
199
200
class NiceMock<NaggyMock<MockClass> >;
template <typename MockClass>
201
class NiceMock<StrictMock<MockClass> >;
zhanyong.wan's avatar
zhanyong.wan committed
202
203
204
205
206
207
208
209

template <typename MockClass>
class NaggyMock<NiceMock<MockClass> >;
template <typename MockClass>
class NaggyMock<NaggyMock<MockClass> >;
template <typename MockClass>
class NaggyMock<StrictMock<MockClass> >;

210
211
212
template <typename MockClass>
class StrictMock<NiceMock<MockClass> >;
template <typename MockClass>
zhanyong.wan's avatar
zhanyong.wan committed
213
214
class StrictMock<NaggyMock<MockClass> >;
template <typename MockClass>
215
216
217
218
219
class StrictMock<StrictMock<MockClass> >;

}  // namespace testing

#endif  // GMOCK_INCLUDE_GMOCK_GMOCK_GENERATED_NICE_STRICT_H_