cppjieba_rb 0.4.1 → 0.4.4
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.editorconfig +21 -0
- data/.github/workflows/linting.yml +30 -0
- data/.github/workflows/release.yml +42 -0
- data/.github/workflows/tests.yml +47 -0
- data/.gitignore +1 -0
- data/.rubocop.yml +45 -0
- data/.ruby-version +1 -0
- data/.yamllint +35 -0
- data/CHANGELOG.md +17 -0
- data/Gemfile +11 -0
- data/README.md +5 -5
- data/Rakefile +16 -7
- data/cppjieba_rb.gemspec +46 -33
- data/ext/cppjieba/.github/workflows/cmake.yml +52 -0
- data/ext/cppjieba/.github/workflows/stale-issues.yml +24 -0
- data/ext/cppjieba/.gitmodules +3 -0
- data/ext/cppjieba/{ChangeLog.md → CHANGELOG.md} +50 -1
- data/ext/cppjieba/CMakeLists.txt +11 -14
- data/ext/cppjieba/LICENSE +20 -0
- data/ext/cppjieba/README.md +9 -18
- data/ext/cppjieba/deps/limonp/.github/workflows/cmake.yml +43 -0
- data/ext/cppjieba/deps/limonp/.gitignore +9 -0
- data/ext/cppjieba/deps/limonp/CHANGELOG.md +160 -0
- data/ext/cppjieba/deps/limonp/CMakeLists.txt +61 -0
- data/ext/cppjieba/deps/limonp/LICENSE +20 -0
- data/ext/cppjieba/deps/limonp/README.md +38 -0
- data/ext/cppjieba/deps/limonp/{LocalVector.hpp → include/limonp/LocalVector.hpp} +3 -3
- data/ext/cppjieba/deps/limonp/{Logging.hpp → include/limonp/Logging.hpp} +17 -3
- data/ext/cppjieba/deps/limonp/{StringUtil.hpp → include/limonp/StringUtil.hpp} +31 -10
- data/ext/cppjieba/deps/limonp/test/CMakeLists.txt +8 -0
- data/ext/cppjieba/deps/limonp/test/demo.cpp +40 -0
- data/ext/cppjieba/deps/limonp/test/testdata/1.conf +5 -0
- data/ext/cppjieba/deps/limonp/test/testdata/StdExtension.data +3 -0
- data/ext/cppjieba/deps/limonp/test/testdata/dict.gbk +50 -0
- data/ext/cppjieba/deps/limonp/test/testdata/dict.utf8 +50 -0
- data/ext/cppjieba/deps/limonp/test/testdata/io_testfile +2 -0
- data/ext/cppjieba/deps/limonp/test/testdata/jieba.dict.0.1.utf8 +93 -0
- data/ext/cppjieba/deps/limonp/test/testdata/jieba.dict.0.utf8 +93 -0
- data/ext/cppjieba/deps/limonp/test/testdata/jieba.dict.1.utf8 +67 -0
- data/ext/cppjieba/deps/limonp/test/testdata/jieba.dict.2.utf8 +64 -0
- data/ext/cppjieba/deps/limonp/test/unittest/CMakeLists.txt +30 -0
- data/ext/cppjieba/deps/limonp/test/unittest/TArgvContext.cpp +16 -0
- data/ext/cppjieba/deps/limonp/test/unittest/TCastFloat.cpp +19 -0
- data/ext/cppjieba/deps/limonp/test/unittest/TClosure.cpp +85 -0
- data/ext/cppjieba/deps/limonp/test/unittest/TColorPrint.cpp +20 -0
- data/ext/cppjieba/deps/limonp/test/unittest/TConfig.cpp +17 -0
- data/ext/cppjieba/deps/limonp/test/unittest/TLocalVector.cpp +41 -0
- data/ext/cppjieba/deps/limonp/test/unittest/TLogging.cpp +12 -0
- data/ext/cppjieba/deps/limonp/test/unittest/TStdExtension.cpp +95 -0
- data/ext/cppjieba/deps/limonp/test/unittest/TStringUtil.cpp +183 -0
- data/ext/cppjieba/include/cppjieba/DictTrie.hpp +9 -0
- data/ext/cppjieba/include/cppjieba/Jieba.hpp +4 -0
- data/ext/cppjieba/include/cppjieba/Trie.hpp +27 -1
- data/ext/cppjieba/test/CMakeLists.txt +4 -3
- data/ext/cppjieba/test/unittest/CMakeLists.txt +16 -7
- data/ext/cppjieba_rb/extconf.rb +11 -6
- data/ext/cppjieba_rb/internal.cc +1 -1
- data/lib/cppjieba_rb/segment.rb +4 -1
- data/lib/cppjieba_rb/version.rb +3 -1
- data/lib/cppjieba_rb.rb +12 -5
- data/test/test_keyword.rb +8 -8
- data/test/test_segment.rb +14 -10
- data/test/test_stop_word_filter.rb +5 -3
- data/test/test_tagging.rb +5 -2
- metadata +63 -140
- data/.travis.yml +0 -30
- data/ext/cppjieba/.travis.yml +0 -21
- data/ext/cppjieba/README_EN.md +0 -115
- data/ext/cppjieba/appveyor.yml +0 -32
- data/ext/cppjieba/deps/CMakeLists.txt +0 -1
- data/ext/cppjieba/deps/gtest/CMakeLists.txt +0 -5
- data/ext/cppjieba/deps/gtest/include/gtest/gtest-death-test.h +0 -283
- data/ext/cppjieba/deps/gtest/include/gtest/gtest-message.h +0 -230
- data/ext/cppjieba/deps/gtest/include/gtest/gtest-param-test.h +0 -1421
- data/ext/cppjieba/deps/gtest/include/gtest/gtest-param-test.h.pump +0 -487
- data/ext/cppjieba/deps/gtest/include/gtest/gtest-printers.h +0 -796
- data/ext/cppjieba/deps/gtest/include/gtest/gtest-spi.h +0 -232
- data/ext/cppjieba/deps/gtest/include/gtest/gtest-test-part.h +0 -176
- data/ext/cppjieba/deps/gtest/include/gtest/gtest-typed-test.h +0 -259
- data/ext/cppjieba/deps/gtest/include/gtest/gtest.h +0 -2155
- data/ext/cppjieba/deps/gtest/include/gtest/gtest_pred_impl.h +0 -358
- data/ext/cppjieba/deps/gtest/include/gtest/gtest_prod.h +0 -58
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-death-test-internal.h +0 -308
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-filepath.h +0 -210
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-internal.h +0 -1226
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-linked_ptr.h +0 -233
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-param-util-generated.h +0 -4822
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-param-util-generated.h.pump +0 -301
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-param-util.h +0 -619
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-port.h +0 -1788
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-string.h +0 -350
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-tuple.h +0 -968
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-tuple.h.pump +0 -336
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-type-util.h +0 -3330
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-type-util.h.pump +0 -296
- data/ext/cppjieba/deps/gtest/src/.deps/gtest-all.Plo +0 -681
- data/ext/cppjieba/deps/gtest/src/.deps/gtest_main.Plo +0 -509
- data/ext/cppjieba/deps/gtest/src/.dirstamp +0 -0
- data/ext/cppjieba/deps/gtest/src/gtest-all.cc +0 -48
- data/ext/cppjieba/deps/gtest/src/gtest-death-test.cc +0 -1234
- data/ext/cppjieba/deps/gtest/src/gtest-filepath.cc +0 -380
- data/ext/cppjieba/deps/gtest/src/gtest-internal-inl.h +0 -1038
- data/ext/cppjieba/deps/gtest/src/gtest-port.cc +0 -746
- data/ext/cppjieba/deps/gtest/src/gtest-printers.cc +0 -356
- data/ext/cppjieba/deps/gtest/src/gtest-test-part.cc +0 -110
- data/ext/cppjieba/deps/gtest/src/gtest-typed-test.cc +0 -110
- data/ext/cppjieba/deps/gtest/src/gtest.cc +0 -4898
- data/ext/cppjieba/deps/limonp/BlockingQueue.hpp +0 -49
- data/ext/cppjieba/deps/limonp/BoundedBlockingQueue.hpp +0 -67
- data/ext/cppjieba/deps/limonp/BoundedQueue.hpp +0 -65
- data/ext/cppjieba/deps/limonp/FileLock.hpp +0 -74
- data/ext/cppjieba/deps/limonp/Md5.hpp +0 -411
- data/ext/cppjieba/deps/limonp/MutexLock.hpp +0 -51
- data/ext/cppjieba/deps/limonp/Thread.hpp +0 -44
- data/ext/cppjieba/deps/limonp/ThreadPool.hpp +0 -86
- data/ext/cppjieba/test/demo.cpp +0 -80
- /data/ext/cppjieba/deps/{gtest/src/.deps/.dirstamp → limonp/.gitmodules} +0 -0
- /data/ext/cppjieba/deps/limonp/{ArgvContext.hpp → include/limonp/ArgvContext.hpp} +0 -0
- /data/ext/cppjieba/deps/limonp/{Closure.hpp → include/limonp/Closure.hpp} +0 -0
- /data/ext/cppjieba/deps/limonp/{Colors.hpp → include/limonp/Colors.hpp} +0 -0
- /data/ext/cppjieba/deps/limonp/{Condition.hpp → include/limonp/Condition.hpp} +0 -0
- /data/ext/cppjieba/deps/limonp/{Config.hpp → include/limonp/Config.hpp} +0 -0
- /data/ext/cppjieba/deps/limonp/{ForcePublic.hpp → include/limonp/ForcePublic.hpp} +0 -0
- /data/ext/cppjieba/deps/limonp/{NonCopyable.hpp → include/limonp/NonCopyable.hpp} +0 -0
- /data/ext/cppjieba/deps/limonp/{StdExtension.hpp → include/limonp/StdExtension.hpp} +0 -0
- /data/ext/cppjieba/deps/{gtest/src/gtest_main.cc → limonp/test/unittest/gtest_main.cpp} +0 -0
@@ -1,232 +0,0 @@
|
|
1
|
-
// Copyright 2007, Google Inc.
|
2
|
-
// All rights reserved.
|
3
|
-
//
|
4
|
-
// Redistribution and use in source and binary forms, with or without
|
5
|
-
// modification, are permitted provided that the following conditions are
|
6
|
-
// met:
|
7
|
-
//
|
8
|
-
// * Redistributions of source code must retain the above copyright
|
9
|
-
// notice, this list of conditions and the following disclaimer.
|
10
|
-
// * Redistributions in binary form must reproduce the above
|
11
|
-
// copyright notice, this list of conditions and the following disclaimer
|
12
|
-
// in the documentation and/or other materials provided with the
|
13
|
-
// distribution.
|
14
|
-
// * Neither the name of Google Inc. nor the names of its
|
15
|
-
// contributors may be used to endorse or promote products derived from
|
16
|
-
// this software without specific prior written permission.
|
17
|
-
//
|
18
|
-
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
19
|
-
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
20
|
-
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
21
|
-
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
22
|
-
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
23
|
-
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
24
|
-
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
25
|
-
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
26
|
-
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
27
|
-
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
28
|
-
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
29
|
-
//
|
30
|
-
// Author: wan@google.com (Zhanyong Wan)
|
31
|
-
//
|
32
|
-
// Utilities for testing Google Test itself and code that uses Google Test
|
33
|
-
// (e.g. frameworks built on top of Google Test).
|
34
|
-
|
35
|
-
#ifndef GTEST_INCLUDE_GTEST_GTEST_SPI_H_
|
36
|
-
#define GTEST_INCLUDE_GTEST_GTEST_SPI_H_
|
37
|
-
|
38
|
-
#include "gtest/gtest.h"
|
39
|
-
|
40
|
-
namespace testing {
|
41
|
-
|
42
|
-
// This helper class can be used to mock out Google Test failure reporting
|
43
|
-
// so that we can test Google Test or code that builds on Google Test.
|
44
|
-
//
|
45
|
-
// An object of this class appends a TestPartResult object to the
|
46
|
-
// TestPartResultArray object given in the constructor whenever a Google Test
|
47
|
-
// failure is reported. It can either intercept only failures that are
|
48
|
-
// generated in the same thread that created this object or it can intercept
|
49
|
-
// all generated failures. The scope of this mock object can be controlled with
|
50
|
-
// the second argument to the two arguments constructor.
|
51
|
-
class GTEST_API_ ScopedFakeTestPartResultReporter
|
52
|
-
: public TestPartResultReporterInterface {
|
53
|
-
public:
|
54
|
-
// The two possible mocking modes of this object.
|
55
|
-
enum InterceptMode {
|
56
|
-
INTERCEPT_ONLY_CURRENT_THREAD, // Intercepts only thread local failures.
|
57
|
-
INTERCEPT_ALL_THREADS // Intercepts all failures.
|
58
|
-
};
|
59
|
-
|
60
|
-
// The c'tor sets this object as the test part result reporter used
|
61
|
-
// by Google Test. The 'result' parameter specifies where to report the
|
62
|
-
// results. This reporter will only catch failures generated in the current
|
63
|
-
// thread. DEPRECATED
|
64
|
-
explicit ScopedFakeTestPartResultReporter(TestPartResultArray* result);
|
65
|
-
|
66
|
-
// Same as above, but you can choose the interception scope of this object.
|
67
|
-
ScopedFakeTestPartResultReporter(InterceptMode intercept_mode,
|
68
|
-
TestPartResultArray* result);
|
69
|
-
|
70
|
-
// The d'tor restores the previous test part result reporter.
|
71
|
-
virtual ~ScopedFakeTestPartResultReporter();
|
72
|
-
|
73
|
-
// Appends the TestPartResult object to the TestPartResultArray
|
74
|
-
// received in the constructor.
|
75
|
-
//
|
76
|
-
// This method is from the TestPartResultReporterInterface
|
77
|
-
// interface.
|
78
|
-
virtual void ReportTestPartResult(const TestPartResult& result);
|
79
|
-
private:
|
80
|
-
void Init();
|
81
|
-
|
82
|
-
const InterceptMode intercept_mode_;
|
83
|
-
TestPartResultReporterInterface* old_reporter_;
|
84
|
-
TestPartResultArray* const result_;
|
85
|
-
|
86
|
-
GTEST_DISALLOW_COPY_AND_ASSIGN_(ScopedFakeTestPartResultReporter);
|
87
|
-
};
|
88
|
-
|
89
|
-
namespace internal {
|
90
|
-
|
91
|
-
// A helper class for implementing EXPECT_FATAL_FAILURE() and
|
92
|
-
// EXPECT_NONFATAL_FAILURE(). Its destructor verifies that the given
|
93
|
-
// TestPartResultArray contains exactly one failure that has the given
|
94
|
-
// type and contains the given substring. If that's not the case, a
|
95
|
-
// non-fatal failure will be generated.
|
96
|
-
class GTEST_API_ SingleFailureChecker {
|
97
|
-
public:
|
98
|
-
// The constructor remembers the arguments.
|
99
|
-
SingleFailureChecker(const TestPartResultArray* results,
|
100
|
-
TestPartResult::Type type,
|
101
|
-
const string& substr);
|
102
|
-
~SingleFailureChecker();
|
103
|
-
private:
|
104
|
-
const TestPartResultArray* const results_;
|
105
|
-
const TestPartResult::Type type_;
|
106
|
-
const string substr_;
|
107
|
-
|
108
|
-
GTEST_DISALLOW_COPY_AND_ASSIGN_(SingleFailureChecker);
|
109
|
-
};
|
110
|
-
|
111
|
-
} // namespace internal
|
112
|
-
|
113
|
-
} // namespace testing
|
114
|
-
|
115
|
-
// A set of macros for testing Google Test assertions or code that's expected
|
116
|
-
// to generate Google Test fatal failures. It verifies that the given
|
117
|
-
// statement will cause exactly one fatal Google Test failure with 'substr'
|
118
|
-
// being part of the failure message.
|
119
|
-
//
|
120
|
-
// There are two different versions of this macro. EXPECT_FATAL_FAILURE only
|
121
|
-
// affects and considers failures generated in the current thread and
|
122
|
-
// EXPECT_FATAL_FAILURE_ON_ALL_THREADS does the same but for all threads.
|
123
|
-
//
|
124
|
-
// The verification of the assertion is done correctly even when the statement
|
125
|
-
// throws an exception or aborts the current function.
|
126
|
-
//
|
127
|
-
// Known restrictions:
|
128
|
-
// - 'statement' cannot reference local non-static variables or
|
129
|
-
// non-static members of the current object.
|
130
|
-
// - 'statement' cannot return a value.
|
131
|
-
// - You cannot stream a failure message to this macro.
|
132
|
-
//
|
133
|
-
// Note that even though the implementations of the following two
|
134
|
-
// macros are much alike, we cannot refactor them to use a common
|
135
|
-
// helper macro, due to some peculiarity in how the preprocessor
|
136
|
-
// works. The AcceptsMacroThatExpandsToUnprotectedComma test in
|
137
|
-
// gtest_unittest.cc will fail to compile if we do that.
|
138
|
-
#define EXPECT_FATAL_FAILURE(statement, substr) \
|
139
|
-
do { \
|
140
|
-
class GTestExpectFatalFailureHelper {\
|
141
|
-
public:\
|
142
|
-
static void Execute() { statement; }\
|
143
|
-
};\
|
144
|
-
::testing::TestPartResultArray gtest_failures;\
|
145
|
-
::testing::internal::SingleFailureChecker gtest_checker(\
|
146
|
-
>est_failures, ::testing::TestPartResult::kFatalFailure, (substr));\
|
147
|
-
{\
|
148
|
-
::testing::ScopedFakeTestPartResultReporter gtest_reporter(\
|
149
|
-
::testing::ScopedFakeTestPartResultReporter:: \
|
150
|
-
INTERCEPT_ONLY_CURRENT_THREAD, >est_failures);\
|
151
|
-
GTestExpectFatalFailureHelper::Execute();\
|
152
|
-
}\
|
153
|
-
} while (::testing::internal::AlwaysFalse())
|
154
|
-
|
155
|
-
#define EXPECT_FATAL_FAILURE_ON_ALL_THREADS(statement, substr) \
|
156
|
-
do { \
|
157
|
-
class GTestExpectFatalFailureHelper {\
|
158
|
-
public:\
|
159
|
-
static void Execute() { statement; }\
|
160
|
-
};\
|
161
|
-
::testing::TestPartResultArray gtest_failures;\
|
162
|
-
::testing::internal::SingleFailureChecker gtest_checker(\
|
163
|
-
>est_failures, ::testing::TestPartResult::kFatalFailure, (substr));\
|
164
|
-
{\
|
165
|
-
::testing::ScopedFakeTestPartResultReporter gtest_reporter(\
|
166
|
-
::testing::ScopedFakeTestPartResultReporter:: \
|
167
|
-
INTERCEPT_ALL_THREADS, >est_failures);\
|
168
|
-
GTestExpectFatalFailureHelper::Execute();\
|
169
|
-
}\
|
170
|
-
} while (::testing::internal::AlwaysFalse())
|
171
|
-
|
172
|
-
// A macro for testing Google Test assertions or code that's expected to
|
173
|
-
// generate Google Test non-fatal failures. It asserts that the given
|
174
|
-
// statement will cause exactly one non-fatal Google Test failure with 'substr'
|
175
|
-
// being part of the failure message.
|
176
|
-
//
|
177
|
-
// There are two different versions of this macro. EXPECT_NONFATAL_FAILURE only
|
178
|
-
// affects and considers failures generated in the current thread and
|
179
|
-
// EXPECT_NONFATAL_FAILURE_ON_ALL_THREADS does the same but for all threads.
|
180
|
-
//
|
181
|
-
// 'statement' is allowed to reference local variables and members of
|
182
|
-
// the current object.
|
183
|
-
//
|
184
|
-
// The verification of the assertion is done correctly even when the statement
|
185
|
-
// throws an exception or aborts the current function.
|
186
|
-
//
|
187
|
-
// Known restrictions:
|
188
|
-
// - You cannot stream a failure message to this macro.
|
189
|
-
//
|
190
|
-
// Note that even though the implementations of the following two
|
191
|
-
// macros are much alike, we cannot refactor them to use a common
|
192
|
-
// helper macro, due to some peculiarity in how the preprocessor
|
193
|
-
// works. If we do that, the code won't compile when the user gives
|
194
|
-
// EXPECT_NONFATAL_FAILURE() a statement that contains a macro that
|
195
|
-
// expands to code containing an unprotected comma. The
|
196
|
-
// AcceptsMacroThatExpandsToUnprotectedComma test in gtest_unittest.cc
|
197
|
-
// catches that.
|
198
|
-
//
|
199
|
-
// For the same reason, we have to write
|
200
|
-
// if (::testing::internal::AlwaysTrue()) { statement; }
|
201
|
-
// instead of
|
202
|
-
// GTEST_SUPPRESS_UNREACHABLE_CODE_WARNING_BELOW_(statement)
|
203
|
-
// to avoid an MSVC warning on unreachable code.
|
204
|
-
#define EXPECT_NONFATAL_FAILURE(statement, substr) \
|
205
|
-
do {\
|
206
|
-
::testing::TestPartResultArray gtest_failures;\
|
207
|
-
::testing::internal::SingleFailureChecker gtest_checker(\
|
208
|
-
>est_failures, ::testing::TestPartResult::kNonFatalFailure, \
|
209
|
-
(substr));\
|
210
|
-
{\
|
211
|
-
::testing::ScopedFakeTestPartResultReporter gtest_reporter(\
|
212
|
-
::testing::ScopedFakeTestPartResultReporter:: \
|
213
|
-
INTERCEPT_ONLY_CURRENT_THREAD, >est_failures);\
|
214
|
-
if (::testing::internal::AlwaysTrue()) { statement; }\
|
215
|
-
}\
|
216
|
-
} while (::testing::internal::AlwaysFalse())
|
217
|
-
|
218
|
-
#define EXPECT_NONFATAL_FAILURE_ON_ALL_THREADS(statement, substr) \
|
219
|
-
do {\
|
220
|
-
::testing::TestPartResultArray gtest_failures;\
|
221
|
-
::testing::internal::SingleFailureChecker gtest_checker(\
|
222
|
-
>est_failures, ::testing::TestPartResult::kNonFatalFailure, \
|
223
|
-
(substr));\
|
224
|
-
{\
|
225
|
-
::testing::ScopedFakeTestPartResultReporter gtest_reporter(\
|
226
|
-
::testing::ScopedFakeTestPartResultReporter::INTERCEPT_ALL_THREADS,\
|
227
|
-
>est_failures);\
|
228
|
-
if (::testing::internal::AlwaysTrue()) { statement; }\
|
229
|
-
}\
|
230
|
-
} while (::testing::internal::AlwaysFalse())
|
231
|
-
|
232
|
-
#endif // GTEST_INCLUDE_GTEST_GTEST_SPI_H_
|
@@ -1,176 +0,0 @@
|
|
1
|
-
// Copyright 2008, Google Inc.
|
2
|
-
// All rights reserved.
|
3
|
-
//
|
4
|
-
// Redistribution and use in source and binary forms, with or without
|
5
|
-
// modification, are permitted provided that the following conditions are
|
6
|
-
// met:
|
7
|
-
//
|
8
|
-
// * Redistributions of source code must retain the above copyright
|
9
|
-
// notice, this list of conditions and the following disclaimer.
|
10
|
-
// * Redistributions in binary form must reproduce the above
|
11
|
-
// copyright notice, this list of conditions and the following disclaimer
|
12
|
-
// in the documentation and/or other materials provided with the
|
13
|
-
// distribution.
|
14
|
-
// * Neither the name of Google Inc. nor the names of its
|
15
|
-
// contributors may be used to endorse or promote products derived from
|
16
|
-
// this software without specific prior written permission.
|
17
|
-
//
|
18
|
-
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
19
|
-
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
20
|
-
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
21
|
-
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
22
|
-
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
23
|
-
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
24
|
-
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
25
|
-
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
26
|
-
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
27
|
-
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
28
|
-
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
29
|
-
//
|
30
|
-
// Author: mheule@google.com (Markus Heule)
|
31
|
-
//
|
32
|
-
|
33
|
-
#ifndef GTEST_INCLUDE_GTEST_GTEST_TEST_PART_H_
|
34
|
-
#define GTEST_INCLUDE_GTEST_GTEST_TEST_PART_H_
|
35
|
-
|
36
|
-
#include <iosfwd>
|
37
|
-
#include <vector>
|
38
|
-
#include "gtest/internal/gtest-internal.h"
|
39
|
-
#include "gtest/internal/gtest-string.h"
|
40
|
-
|
41
|
-
namespace testing {
|
42
|
-
|
43
|
-
// A copyable object representing the result of a test part (i.e. an
|
44
|
-
// assertion or an explicit FAIL(), ADD_FAILURE(), or SUCCESS()).
|
45
|
-
//
|
46
|
-
// Don't inherit from TestPartResult as its destructor is not virtual.
|
47
|
-
class GTEST_API_ TestPartResult {
|
48
|
-
public:
|
49
|
-
// The possible outcomes of a test part (i.e. an assertion or an
|
50
|
-
// explicit SUCCEED(), FAIL(), or ADD_FAILURE()).
|
51
|
-
enum Type {
|
52
|
-
kSuccess, // Succeeded.
|
53
|
-
kNonFatalFailure, // Failed but the test can continue.
|
54
|
-
kFatalFailure // Failed and the test should be terminated.
|
55
|
-
};
|
56
|
-
|
57
|
-
// C'tor. TestPartResult does NOT have a default constructor.
|
58
|
-
// Always use this constructor (with parameters) to create a
|
59
|
-
// TestPartResult object.
|
60
|
-
TestPartResult(Type a_type,
|
61
|
-
const char* a_file_name,
|
62
|
-
int a_line_number,
|
63
|
-
const char* a_message)
|
64
|
-
: type_(a_type),
|
65
|
-
file_name_(a_file_name),
|
66
|
-
line_number_(a_line_number),
|
67
|
-
summary_(ExtractSummary(a_message)),
|
68
|
-
message_(a_message) {
|
69
|
-
}
|
70
|
-
|
71
|
-
// Gets the outcome of the test part.
|
72
|
-
Type type() const { return type_; }
|
73
|
-
|
74
|
-
// Gets the name of the source file where the test part took place, or
|
75
|
-
// NULL if it's unknown.
|
76
|
-
const char* file_name() const { return file_name_.c_str(); }
|
77
|
-
|
78
|
-
// Gets the line in the source file where the test part took place,
|
79
|
-
// or -1 if it's unknown.
|
80
|
-
int line_number() const { return line_number_; }
|
81
|
-
|
82
|
-
// Gets the summary of the failure message.
|
83
|
-
const char* summary() const { return summary_.c_str(); }
|
84
|
-
|
85
|
-
// Gets the message associated with the test part.
|
86
|
-
const char* message() const { return message_.c_str(); }
|
87
|
-
|
88
|
-
// Returns true iff the test part passed.
|
89
|
-
bool passed() const { return type_ == kSuccess; }
|
90
|
-
|
91
|
-
// Returns true iff the test part failed.
|
92
|
-
bool failed() const { return type_ != kSuccess; }
|
93
|
-
|
94
|
-
// Returns true iff the test part non-fatally failed.
|
95
|
-
bool nonfatally_failed() const { return type_ == kNonFatalFailure; }
|
96
|
-
|
97
|
-
// Returns true iff the test part fatally failed.
|
98
|
-
bool fatally_failed() const { return type_ == kFatalFailure; }
|
99
|
-
private:
|
100
|
-
Type type_;
|
101
|
-
|
102
|
-
// Gets the summary of the failure message by omitting the stack
|
103
|
-
// trace in it.
|
104
|
-
static internal::String ExtractSummary(const char* message);
|
105
|
-
|
106
|
-
// The name of the source file where the test part took place, or
|
107
|
-
// NULL if the source file is unknown.
|
108
|
-
internal::String file_name_;
|
109
|
-
// The line in the source file where the test part took place, or -1
|
110
|
-
// if the line number is unknown.
|
111
|
-
int line_number_;
|
112
|
-
internal::String summary_; // The test failure summary.
|
113
|
-
internal::String message_; // The test failure message.
|
114
|
-
};
|
115
|
-
|
116
|
-
// Prints a TestPartResult object.
|
117
|
-
std::ostream& operator<<(std::ostream& os, const TestPartResult& result);
|
118
|
-
|
119
|
-
// An array of TestPartResult objects.
|
120
|
-
//
|
121
|
-
// Don't inherit from TestPartResultArray as its destructor is not
|
122
|
-
// virtual.
|
123
|
-
class GTEST_API_ TestPartResultArray {
|
124
|
-
public:
|
125
|
-
TestPartResultArray() {}
|
126
|
-
|
127
|
-
// Appends the given TestPartResult to the array.
|
128
|
-
void Append(const TestPartResult& result);
|
129
|
-
|
130
|
-
// Returns the TestPartResult at the given index (0-based).
|
131
|
-
const TestPartResult& GetTestPartResult(int index) const;
|
132
|
-
|
133
|
-
// Returns the number of TestPartResult objects in the array.
|
134
|
-
int size() const;
|
135
|
-
|
136
|
-
private:
|
137
|
-
std::vector<TestPartResult> array_;
|
138
|
-
|
139
|
-
GTEST_DISALLOW_COPY_AND_ASSIGN_(TestPartResultArray);
|
140
|
-
};
|
141
|
-
|
142
|
-
// This interface knows how to report a test part result.
|
143
|
-
class TestPartResultReporterInterface {
|
144
|
-
public:
|
145
|
-
virtual ~TestPartResultReporterInterface() {}
|
146
|
-
|
147
|
-
virtual void ReportTestPartResult(const TestPartResult& result) = 0;
|
148
|
-
};
|
149
|
-
|
150
|
-
namespace internal {
|
151
|
-
|
152
|
-
// This helper class is used by {ASSERT|EXPECT}_NO_FATAL_FAILURE to check if a
|
153
|
-
// statement generates new fatal failures. To do so it registers itself as the
|
154
|
-
// current test part result reporter. Besides checking if fatal failures were
|
155
|
-
// reported, it only delegates the reporting to the former result reporter.
|
156
|
-
// The original result reporter is restored in the destructor.
|
157
|
-
// INTERNAL IMPLEMENTATION - DO NOT USE IN A USER PROGRAM.
|
158
|
-
class GTEST_API_ HasNewFatalFailureHelper
|
159
|
-
: public TestPartResultReporterInterface {
|
160
|
-
public:
|
161
|
-
HasNewFatalFailureHelper();
|
162
|
-
virtual ~HasNewFatalFailureHelper();
|
163
|
-
virtual void ReportTestPartResult(const TestPartResult& result);
|
164
|
-
bool has_new_fatal_failure() const { return has_new_fatal_failure_; }
|
165
|
-
private:
|
166
|
-
bool has_new_fatal_failure_;
|
167
|
-
TestPartResultReporterInterface* original_reporter_;
|
168
|
-
|
169
|
-
GTEST_DISALLOW_COPY_AND_ASSIGN_(HasNewFatalFailureHelper);
|
170
|
-
};
|
171
|
-
|
172
|
-
} // namespace internal
|
173
|
-
|
174
|
-
} // namespace testing
|
175
|
-
|
176
|
-
#endif // GTEST_INCLUDE_GTEST_GTEST_TEST_PART_H_
|
@@ -1,259 +0,0 @@
|
|
1
|
-
// Copyright 2008 Google Inc.
|
2
|
-
// All Rights Reserved.
|
3
|
-
//
|
4
|
-
// Redistribution and use in source and binary forms, with or without
|
5
|
-
// modification, are permitted provided that the following conditions are
|
6
|
-
// met:
|
7
|
-
//
|
8
|
-
// * Redistributions of source code must retain the above copyright
|
9
|
-
// notice, this list of conditions and the following disclaimer.
|
10
|
-
// * Redistributions in binary form must reproduce the above
|
11
|
-
// copyright notice, this list of conditions and the following disclaimer
|
12
|
-
// in the documentation and/or other materials provided with the
|
13
|
-
// distribution.
|
14
|
-
// * Neither the name of Google Inc. nor the names of its
|
15
|
-
// contributors may be used to endorse or promote products derived from
|
16
|
-
// this software without specific prior written permission.
|
17
|
-
//
|
18
|
-
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
19
|
-
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
20
|
-
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
21
|
-
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
22
|
-
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
23
|
-
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
24
|
-
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
25
|
-
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
26
|
-
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
27
|
-
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
28
|
-
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
29
|
-
//
|
30
|
-
// Author: wan@google.com (Zhanyong Wan)
|
31
|
-
|
32
|
-
#ifndef GTEST_INCLUDE_GTEST_GTEST_TYPED_TEST_H_
|
33
|
-
#define GTEST_INCLUDE_GTEST_GTEST_TYPED_TEST_H_
|
34
|
-
|
35
|
-
// This header implements typed tests and type-parameterized tests.
|
36
|
-
|
37
|
-
// Typed (aka type-driven) tests repeat the same test for types in a
|
38
|
-
// list. You must know which types you want to test with when writing
|
39
|
-
// typed tests. Here's how you do it:
|
40
|
-
|
41
|
-
#if 0
|
42
|
-
|
43
|
-
// First, define a fixture class template. It should be parameterized
|
44
|
-
// by a type. Remember to derive it from testing::Test.
|
45
|
-
template <typename T>
|
46
|
-
class FooTest : public testing::Test {
|
47
|
-
public:
|
48
|
-
...
|
49
|
-
typedef std::list<T> List;
|
50
|
-
static T shared_;
|
51
|
-
T value_;
|
52
|
-
};
|
53
|
-
|
54
|
-
// Next, associate a list of types with the test case, which will be
|
55
|
-
// repeated for each type in the list. The typedef is necessary for
|
56
|
-
// the macro to parse correctly.
|
57
|
-
typedef testing::Types<char, int, unsigned int> MyTypes;
|
58
|
-
TYPED_TEST_CASE(FooTest, MyTypes);
|
59
|
-
|
60
|
-
// If the type list contains only one type, you can write that type
|
61
|
-
// directly without Types<...>:
|
62
|
-
// TYPED_TEST_CASE(FooTest, int);
|
63
|
-
|
64
|
-
// Then, use TYPED_TEST() instead of TEST_F() to define as many typed
|
65
|
-
// tests for this test case as you want.
|
66
|
-
TYPED_TEST(FooTest, DoesBlah) {
|
67
|
-
// Inside a test, refer to TypeParam to get the type parameter.
|
68
|
-
// Since we are inside a derived class template, C++ requires use to
|
69
|
-
// visit the members of FooTest via 'this'.
|
70
|
-
TypeParam n = this->value_;
|
71
|
-
|
72
|
-
// To visit static members of the fixture, add the TestFixture::
|
73
|
-
// prefix.
|
74
|
-
n += TestFixture::shared_;
|
75
|
-
|
76
|
-
// To refer to typedefs in the fixture, add the "typename
|
77
|
-
// TestFixture::" prefix.
|
78
|
-
typename TestFixture::List values;
|
79
|
-
values.push_back(n);
|
80
|
-
...
|
81
|
-
}
|
82
|
-
|
83
|
-
TYPED_TEST(FooTest, HasPropertyA) { ... }
|
84
|
-
|
85
|
-
#endif // 0
|
86
|
-
|
87
|
-
// Type-parameterized tests are abstract test patterns parameterized
|
88
|
-
// by a type. Compared with typed tests, type-parameterized tests
|
89
|
-
// allow you to define the test pattern without knowing what the type
|
90
|
-
// parameters are. The defined pattern can be instantiated with
|
91
|
-
// different types any number of times, in any number of translation
|
92
|
-
// units.
|
93
|
-
//
|
94
|
-
// If you are designing an interface or concept, you can define a
|
95
|
-
// suite of type-parameterized tests to verify properties that any
|
96
|
-
// valid implementation of the interface/concept should have. Then,
|
97
|
-
// each implementation can easily instantiate the test suite to verify
|
98
|
-
// that it conforms to the requirements, without having to write
|
99
|
-
// similar tests repeatedly. Here's an example:
|
100
|
-
|
101
|
-
#if 0
|
102
|
-
|
103
|
-
// First, define a fixture class template. It should be parameterized
|
104
|
-
// by a type. Remember to derive it from testing::Test.
|
105
|
-
template <typename T>
|
106
|
-
class FooTest : public testing::Test {
|
107
|
-
...
|
108
|
-
};
|
109
|
-
|
110
|
-
// Next, declare that you will define a type-parameterized test case
|
111
|
-
// (the _P suffix is for "parameterized" or "pattern", whichever you
|
112
|
-
// prefer):
|
113
|
-
TYPED_TEST_CASE_P(FooTest);
|
114
|
-
|
115
|
-
// Then, use TYPED_TEST_P() to define as many type-parameterized tests
|
116
|
-
// for this type-parameterized test case as you want.
|
117
|
-
TYPED_TEST_P(FooTest, DoesBlah) {
|
118
|
-
// Inside a test, refer to TypeParam to get the type parameter.
|
119
|
-
TypeParam n = 0;
|
120
|
-
...
|
121
|
-
}
|
122
|
-
|
123
|
-
TYPED_TEST_P(FooTest, HasPropertyA) { ... }
|
124
|
-
|
125
|
-
// Now the tricky part: you need to register all test patterns before
|
126
|
-
// you can instantiate them. The first argument of the macro is the
|
127
|
-
// test case name; the rest are the names of the tests in this test
|
128
|
-
// case.
|
129
|
-
REGISTER_TYPED_TEST_CASE_P(FooTest,
|
130
|
-
DoesBlah, HasPropertyA);
|
131
|
-
|
132
|
-
// Finally, you are free to instantiate the pattern with the types you
|
133
|
-
// want. If you put the above code in a header file, you can #include
|
134
|
-
// it in multiple C++ source files and instantiate it multiple times.
|
135
|
-
//
|
136
|
-
// To distinguish different instances of the pattern, the first
|
137
|
-
// argument to the INSTANTIATE_* macro is a prefix that will be added
|
138
|
-
// to the actual test case name. Remember to pick unique prefixes for
|
139
|
-
// different instances.
|
140
|
-
typedef testing::Types<char, int, unsigned int> MyTypes;
|
141
|
-
INSTANTIATE_TYPED_TEST_CASE_P(My, FooTest, MyTypes);
|
142
|
-
|
143
|
-
// If the type list contains only one type, you can write that type
|
144
|
-
// directly without Types<...>:
|
145
|
-
// INSTANTIATE_TYPED_TEST_CASE_P(My, FooTest, int);
|
146
|
-
|
147
|
-
#endif // 0
|
148
|
-
|
149
|
-
#include "gtest/internal/gtest-port.h"
|
150
|
-
#include "gtest/internal/gtest-type-util.h"
|
151
|
-
|
152
|
-
// Implements typed tests.
|
153
|
-
|
154
|
-
#if GTEST_HAS_TYPED_TEST
|
155
|
-
|
156
|
-
// INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE.
|
157
|
-
//
|
158
|
-
// Expands to the name of the typedef for the type parameters of the
|
159
|
-
// given test case.
|
160
|
-
# define GTEST_TYPE_PARAMS_(TestCaseName) gtest_type_params_##TestCaseName##_
|
161
|
-
|
162
|
-
// The 'Types' template argument below must have spaces around it
|
163
|
-
// since some compilers may choke on '>>' when passing a template
|
164
|
-
// instance (e.g. Types<int>)
|
165
|
-
# define TYPED_TEST_CASE(CaseName, Types) \
|
166
|
-
typedef ::testing::internal::TypeList< Types >::type \
|
167
|
-
GTEST_TYPE_PARAMS_(CaseName)
|
168
|
-
|
169
|
-
# define TYPED_TEST(CaseName, TestName) \
|
170
|
-
template <typename gtest_TypeParam_> \
|
171
|
-
class GTEST_TEST_CLASS_NAME_(CaseName, TestName) \
|
172
|
-
: public CaseName<gtest_TypeParam_> { \
|
173
|
-
private: \
|
174
|
-
typedef CaseName<gtest_TypeParam_> TestFixture; \
|
175
|
-
typedef gtest_TypeParam_ TypeParam; \
|
176
|
-
virtual void TestBody(); \
|
177
|
-
}; \
|
178
|
-
bool gtest_##CaseName##_##TestName##_registered_ GTEST_ATTRIBUTE_UNUSED_ = \
|
179
|
-
::testing::internal::TypeParameterizedTest< \
|
180
|
-
CaseName, \
|
181
|
-
::testing::internal::TemplateSel< \
|
182
|
-
GTEST_TEST_CLASS_NAME_(CaseName, TestName)>, \
|
183
|
-
GTEST_TYPE_PARAMS_(CaseName)>::Register(\
|
184
|
-
"", #CaseName, #TestName, 0); \
|
185
|
-
template <typename gtest_TypeParam_> \
|
186
|
-
void GTEST_TEST_CLASS_NAME_(CaseName, TestName)<gtest_TypeParam_>::TestBody()
|
187
|
-
|
188
|
-
#endif // GTEST_HAS_TYPED_TEST
|
189
|
-
|
190
|
-
// Implements type-parameterized tests.
|
191
|
-
|
192
|
-
#if GTEST_HAS_TYPED_TEST_P
|
193
|
-
|
194
|
-
// INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE.
|
195
|
-
//
|
196
|
-
// Expands to the namespace name that the type-parameterized tests for
|
197
|
-
// the given type-parameterized test case are defined in. The exact
|
198
|
-
// name of the namespace is subject to change without notice.
|
199
|
-
# define GTEST_CASE_NAMESPACE_(TestCaseName) \
|
200
|
-
gtest_case_##TestCaseName##_
|
201
|
-
|
202
|
-
// INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE.
|
203
|
-
//
|
204
|
-
// Expands to the name of the variable used to remember the names of
|
205
|
-
// the defined tests in the given test case.
|
206
|
-
# define GTEST_TYPED_TEST_CASE_P_STATE_(TestCaseName) \
|
207
|
-
gtest_typed_test_case_p_state_##TestCaseName##_
|
208
|
-
|
209
|
-
// INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE DIRECTLY.
|
210
|
-
//
|
211
|
-
// Expands to the name of the variable used to remember the names of
|
212
|
-
// the registered tests in the given test case.
|
213
|
-
# define GTEST_REGISTERED_TEST_NAMES_(TestCaseName) \
|
214
|
-
gtest_registered_test_names_##TestCaseName##_
|
215
|
-
|
216
|
-
// The variables defined in the type-parameterized test macros are
|
217
|
-
// static as typically these macros are used in a .h file that can be
|
218
|
-
// #included in multiple translation units linked together.
|
219
|
-
# define TYPED_TEST_CASE_P(CaseName) \
|
220
|
-
static ::testing::internal::TypedTestCasePState \
|
221
|
-
GTEST_TYPED_TEST_CASE_P_STATE_(CaseName)
|
222
|
-
|
223
|
-
# define TYPED_TEST_P(CaseName, TestName) \
|
224
|
-
namespace GTEST_CASE_NAMESPACE_(CaseName) { \
|
225
|
-
template <typename gtest_TypeParam_> \
|
226
|
-
class TestName : public CaseName<gtest_TypeParam_> { \
|
227
|
-
private: \
|
228
|
-
typedef CaseName<gtest_TypeParam_> TestFixture; \
|
229
|
-
typedef gtest_TypeParam_ TypeParam; \
|
230
|
-
virtual void TestBody(); \
|
231
|
-
}; \
|
232
|
-
static bool gtest_##TestName##_defined_ GTEST_ATTRIBUTE_UNUSED_ = \
|
233
|
-
GTEST_TYPED_TEST_CASE_P_STATE_(CaseName).AddTestName(\
|
234
|
-
__FILE__, __LINE__, #CaseName, #TestName); \
|
235
|
-
} \
|
236
|
-
template <typename gtest_TypeParam_> \
|
237
|
-
void GTEST_CASE_NAMESPACE_(CaseName)::TestName<gtest_TypeParam_>::TestBody()
|
238
|
-
|
239
|
-
# define REGISTER_TYPED_TEST_CASE_P(CaseName, ...) \
|
240
|
-
namespace GTEST_CASE_NAMESPACE_(CaseName) { \
|
241
|
-
typedef ::testing::internal::Templates<__VA_ARGS__>::type gtest_AllTests_; \
|
242
|
-
} \
|
243
|
-
static const char* const GTEST_REGISTERED_TEST_NAMES_(CaseName) = \
|
244
|
-
GTEST_TYPED_TEST_CASE_P_STATE_(CaseName).VerifyRegisteredTestNames(\
|
245
|
-
__FILE__, __LINE__, #__VA_ARGS__)
|
246
|
-
|
247
|
-
// The 'Types' template argument below must have spaces around it
|
248
|
-
// since some compilers may choke on '>>' when passing a template
|
249
|
-
// instance (e.g. Types<int>)
|
250
|
-
# define INSTANTIATE_TYPED_TEST_CASE_P(Prefix, CaseName, Types) \
|
251
|
-
bool gtest_##Prefix##_##CaseName GTEST_ATTRIBUTE_UNUSED_ = \
|
252
|
-
::testing::internal::TypeParameterizedTestCase<CaseName, \
|
253
|
-
GTEST_CASE_NAMESPACE_(CaseName)::gtest_AllTests_, \
|
254
|
-
::testing::internal::TypeList< Types >::type>::Register(\
|
255
|
-
#Prefix, #CaseName, GTEST_REGISTERED_TEST_NAMES_(CaseName))
|
256
|
-
|
257
|
-
#endif // GTEST_HAS_TYPED_TEST_P
|
258
|
-
|
259
|
-
#endif // GTEST_INCLUDE_GTEST_GTEST_TYPED_TEST_H_
|