rj_schema 0.0.1 → 0.0.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (323) hide show
  1. checksums.yaml +5 -5
  2. data/Rakefile +4 -0
  3. data/ext/rj_schema/rapidjson/thirdparty/gtest/CMakeLists.txt +16 -0
  4. data/ext/rj_schema/rapidjson/thirdparty/gtest/README.md +141 -0
  5. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/CHANGES +126 -0
  6. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/CMakeLists.txt +202 -0
  7. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/CONTRIBUTORS +40 -0
  8. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/LICENSE +28 -0
  9. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/Makefile.am +224 -0
  10. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/README.md +333 -0
  11. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/configure.ac +146 -0
  12. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/CheatSheet.md +562 -0
  13. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/CookBook.md +3675 -0
  14. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/DesignDoc.md +280 -0
  15. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/DevGuide.md +132 -0
  16. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/Documentation.md +12 -0
  17. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/ForDummies.md +439 -0
  18. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/FrequentlyAskedQuestions.md +628 -0
  19. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/KnownIssues.md +19 -0
  20. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/v1_5/CheatSheet.md +525 -0
  21. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/v1_5/CookBook.md +3250 -0
  22. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/v1_5/Documentation.md +11 -0
  23. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/v1_5/ForDummies.md +439 -0
  24. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/v1_5/FrequentlyAskedQuestions.md +624 -0
  25. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/v1_6/CheatSheet.md +534 -0
  26. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/v1_6/CookBook.md +3342 -0
  27. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/v1_6/Documentation.md +12 -0
  28. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/v1_6/ForDummies.md +439 -0
  29. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/v1_6/FrequentlyAskedQuestions.md +628 -0
  30. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/v1_7/CheatSheet.md +556 -0
  31. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/v1_7/CookBook.md +3432 -0
  32. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/v1_7/Documentation.md +12 -0
  33. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/v1_7/ForDummies.md +439 -0
  34. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/docs/v1_7/FrequentlyAskedQuestions.md +628 -0
  35. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-actions.h +1205 -0
  36. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-cardinalities.h +147 -0
  37. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-generated-actions.h +2377 -0
  38. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-generated-actions.h.pump +794 -0
  39. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-generated-function-mockers.h +1095 -0
  40. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-generated-function-mockers.h.pump +291 -0
  41. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-generated-matchers.h +2179 -0
  42. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-generated-matchers.h.pump +672 -0
  43. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-generated-nice-strict.h +397 -0
  44. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-generated-nice-strict.h.pump +161 -0
  45. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-matchers.h +4399 -0
  46. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-more-actions.h +246 -0
  47. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-more-matchers.h +58 -0
  48. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-spec-builders.h +1847 -0
  49. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock.h +94 -0
  50. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/internal/custom/gmock-generated-actions.h +8 -0
  51. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/internal/custom/gmock-generated-actions.h.pump +10 -0
  52. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/internal/custom/gmock-matchers.h +39 -0
  53. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/internal/custom/gmock-port.h +46 -0
  54. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/internal/gmock-generated-internal-utils.h +279 -0
  55. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/internal/gmock-generated-internal-utils.h.pump +136 -0
  56. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/internal/gmock-internal-utils.h +511 -0
  57. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/include/gmock/internal/gmock-port.h +91 -0
  58. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/make/Makefile +101 -0
  59. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/msvc/2005/gmock.sln +32 -0
  60. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/msvc/2005/gmock.vcproj +191 -0
  61. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/msvc/2005/gmock_config.vsprops +15 -0
  62. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/msvc/2005/gmock_main.vcproj +187 -0
  63. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/msvc/2005/gmock_test.vcproj +201 -0
  64. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/msvc/2010/gmock.sln +32 -0
  65. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/msvc/2010/gmock.vcxproj +82 -0
  66. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/msvc/2010/gmock_config.props +19 -0
  67. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/msvc/2010/gmock_main.vcxproj +88 -0
  68. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/msvc/2010/gmock_test.vcxproj +101 -0
  69. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/msvc/2015/gmock.sln +32 -0
  70. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/msvc/2015/gmock.vcxproj +84 -0
  71. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/msvc/2015/gmock_config.props +19 -0
  72. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/msvc/2015/gmock_main.vcxproj +90 -0
  73. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/msvc/2015/gmock_test.vcxproj +103 -0
  74. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/scripts/fuse_gmock_files.py +240 -0
  75. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/scripts/generator/LICENSE +203 -0
  76. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/scripts/generator/README +35 -0
  77. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/scripts/generator/README.cppclean +115 -0
  78. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/scripts/generator/cpp/__init__.py +0 -0
  79. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/scripts/generator/cpp/ast.py +1733 -0
  80. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/scripts/generator/cpp/gmock_class.py +227 -0
  81. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/scripts/generator/cpp/gmock_class_test.py +448 -0
  82. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/scripts/generator/cpp/keywords.py +59 -0
  83. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/scripts/generator/cpp/tokenize.py +287 -0
  84. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/scripts/generator/cpp/utils.py +41 -0
  85. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/scripts/generator/gmock_gen.py +31 -0
  86. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/scripts/gmock-config.in +303 -0
  87. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/scripts/gmock_doctor.py +640 -0
  88. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/scripts/upload.py +1387 -0
  89. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/scripts/upload_gmock.py +78 -0
  90. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/src/gmock-all.cc +47 -0
  91. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/src/gmock-cardinalities.cc +156 -0
  92. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/src/gmock-internal-utils.cc +174 -0
  93. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/src/gmock-matchers.cc +498 -0
  94. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/src/gmock-spec-builders.cc +823 -0
  95. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/src/gmock.cc +183 -0
  96. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/src/gmock_main.cc +54 -0
  97. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock-actions_test.cc +1411 -0
  98. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock-cardinalities_test.cc +428 -0
  99. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock-generated-actions_test.cc +1228 -0
  100. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock-generated-function-mockers_test.cc +622 -0
  101. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock-generated-internal-utils_test.cc +127 -0
  102. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock-generated-matchers_test.cc +1286 -0
  103. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock-internal-utils_test.cc +699 -0
  104. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock-matchers_test.cc +5648 -0
  105. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock-more-actions_test.cc +708 -0
  106. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock-nice-strict_test.cc +424 -0
  107. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock-port_test.cc +43 -0
  108. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock-spec-builders_test.cc +2644 -0
  109. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock_all_test.cc +51 -0
  110. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock_ex_test.cc +81 -0
  111. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock_leak_test.py +108 -0
  112. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock_leak_test_.cc +100 -0
  113. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock_link2_test.cc +40 -0
  114. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock_link_test.cc +40 -0
  115. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock_link_test.h +669 -0
  116. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock_output_test.py +180 -0
  117. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock_output_test_.cc +291 -0
  118. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock_output_test_golden.txt +310 -0
  119. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock_stress_test.cc +322 -0
  120. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock_test.cc +220 -0
  121. data/ext/rj_schema/rapidjson/thirdparty/gtest/googlemock/test/gmock_test_utils.py +112 -0
  122. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/CHANGES +157 -0
  123. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/CMakeLists.txt +286 -0
  124. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/CONTRIBUTORS +37 -0
  125. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/LICENSE +28 -0
  126. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/Makefile.am +310 -0
  127. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/README.md +280 -0
  128. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/cmake/internal_utils.cmake +242 -0
  129. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/codegear/gtest.cbproj +138 -0
  130. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/codegear/gtest.groupproj +54 -0
  131. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/codegear/gtest_all.cc +38 -0
  132. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/codegear/gtest_link.cc +40 -0
  133. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/codegear/gtest_main.cbproj +82 -0
  134. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/codegear/gtest_unittest.cbproj +88 -0
  135. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/configure.ac +68 -0
  136. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/AdvancedGuide.md +2182 -0
  137. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/DevGuide.md +126 -0
  138. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/Documentation.md +14 -0
  139. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/FAQ.md +1087 -0
  140. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/Primer.md +502 -0
  141. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/PumpManual.md +177 -0
  142. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/Samples.md +14 -0
  143. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/V1_5_AdvancedGuide.md +2096 -0
  144. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/V1_5_Documentation.md +12 -0
  145. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/V1_5_FAQ.md +886 -0
  146. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/V1_5_Primer.md +497 -0
  147. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/V1_5_PumpManual.md +177 -0
  148. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/V1_5_XcodeGuide.md +93 -0
  149. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/V1_6_AdvancedGuide.md +2178 -0
  150. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/V1_6_Documentation.md +14 -0
  151. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/V1_6_FAQ.md +1038 -0
  152. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/V1_6_Primer.md +501 -0
  153. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/V1_6_PumpManual.md +177 -0
  154. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/V1_6_Samples.md +14 -0
  155. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/V1_6_XcodeGuide.md +93 -0
  156. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/V1_7_AdvancedGuide.md +2181 -0
  157. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/V1_7_Documentation.md +14 -0
  158. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/V1_7_FAQ.md +1082 -0
  159. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/V1_7_Primer.md +501 -0
  160. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/V1_7_PumpManual.md +177 -0
  161. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/V1_7_Samples.md +14 -0
  162. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/V1_7_XcodeGuide.md +93 -0
  163. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/docs/XcodeGuide.md +93 -0
  164. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest-death-test.h +294 -0
  165. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest-message.h +250 -0
  166. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest-param-test.h +1444 -0
  167. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest-param-test.h.pump +510 -0
  168. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest-printers.h +993 -0
  169. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest-spi.h +232 -0
  170. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest-test-part.h +179 -0
  171. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest-typed-test.h +263 -0
  172. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest.h +2236 -0
  173. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest_pred_impl.h +358 -0
  174. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest_prod.h +58 -0
  175. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/custom/gtest-port.h +69 -0
  176. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/custom/gtest-printers.h +42 -0
  177. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/custom/gtest.h +41 -0
  178. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-death-test-internal.h +319 -0
  179. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-filepath.h +206 -0
  180. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-internal.h +1238 -0
  181. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-linked_ptr.h +243 -0
  182. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-param-util-generated.h +5146 -0
  183. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-param-util-generated.h.pump +286 -0
  184. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-param-util.h +731 -0
  185. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-port-arch.h +93 -0
  186. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-port.h +2554 -0
  187. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-string.h +167 -0
  188. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-tuple.h +1020 -0
  189. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-tuple.h.pump +347 -0
  190. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-type-util.h +3331 -0
  191. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-type-util.h.pump +297 -0
  192. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/m4/acx_pthread.m4 +363 -0
  193. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/m4/gtest.m4 +74 -0
  194. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/make/Makefile +82 -0
  195. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/msvc/gtest-md.sln +45 -0
  196. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/msvc/gtest-md.vcproj +126 -0
  197. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/msvc/gtest.sln +45 -0
  198. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/msvc/gtest.vcproj +126 -0
  199. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/msvc/gtest_main-md.vcproj +129 -0
  200. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/msvc/gtest_main.vcproj +129 -0
  201. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/msvc/gtest_prod_test-md.vcproj +164 -0
  202. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/msvc/gtest_prod_test.vcproj +164 -0
  203. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/msvc/gtest_unittest-md.vcproj +147 -0
  204. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/msvc/gtest_unittest.vcproj +147 -0
  205. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/samples/prime_tables.h +123 -0
  206. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/samples/sample1.cc +68 -0
  207. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/samples/sample1.h +43 -0
  208. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/samples/sample10_unittest.cc +144 -0
  209. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/samples/sample1_unittest.cc +153 -0
  210. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/samples/sample2.cc +56 -0
  211. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/samples/sample2.h +85 -0
  212. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/samples/sample2_unittest.cc +109 -0
  213. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/samples/sample3-inl.h +172 -0
  214. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/samples/sample3_unittest.cc +151 -0
  215. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/samples/sample4.cc +46 -0
  216. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/samples/sample4.h +53 -0
  217. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/samples/sample4_unittest.cc +45 -0
  218. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/samples/sample5_unittest.cc +199 -0
  219. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/samples/sample6_unittest.cc +224 -0
  220. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/samples/sample7_unittest.cc +130 -0
  221. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/samples/sample8_unittest.cc +173 -0
  222. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/samples/sample9_unittest.cc +160 -0
  223. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/scripts/common.py +83 -0
  224. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/scripts/fuse_gtest_files.py +253 -0
  225. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/scripts/gen_gtest_pred_impl.py +730 -0
  226. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/scripts/gtest-config.in +274 -0
  227. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/scripts/pump.py +855 -0
  228. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/scripts/release_docs.py +158 -0
  229. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/scripts/test/Makefile +59 -0
  230. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/scripts/upload.py +1387 -0
  231. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/scripts/upload_gtest.py +78 -0
  232. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/src/gtest-all.cc +48 -0
  233. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/src/gtest-death-test.cc +1342 -0
  234. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/src/gtest-filepath.cc +387 -0
  235. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/src/gtest-internal-inl.h +1183 -0
  236. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/src/gtest-port.cc +1259 -0
  237. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/src/gtest-printers.cc +373 -0
  238. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/src/gtest-test-part.cc +110 -0
  239. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/src/gtest-typed-test.cc +118 -0
  240. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/src/gtest.cc +5388 -0
  241. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/src/gtest_main.cc +38 -0
  242. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest-death-test_ex_test.cc +93 -0
  243. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest-death-test_test.cc +1427 -0
  244. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest-filepath_test.cc +662 -0
  245. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest-linked_ptr_test.cc +154 -0
  246. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest-listener_test.cc +311 -0
  247. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest-message_test.cc +159 -0
  248. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest-options_test.cc +215 -0
  249. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest-param-test2_test.cc +65 -0
  250. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest-param-test_test.cc +1055 -0
  251. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest-param-test_test.h +57 -0
  252. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest-port_test.cc +1304 -0
  253. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest-printers_test.cc +1635 -0
  254. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest-test-part_test.cc +208 -0
  255. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest-tuple_test.cc +320 -0
  256. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest-typed-test2_test.cc +45 -0
  257. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest-typed-test_test.cc +380 -0
  258. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest-typed-test_test.h +66 -0
  259. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest-unittest-api_test.cc +341 -0
  260. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_all_test.cc +47 -0
  261. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_break_on_failure_unittest.py +212 -0
  262. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_break_on_failure_unittest_.cc +88 -0
  263. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_catch_exceptions_test.py +237 -0
  264. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_catch_exceptions_test_.cc +311 -0
  265. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_color_test.py +130 -0
  266. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_color_test_.cc +71 -0
  267. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_env_var_test.py +117 -0
  268. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_env_var_test_.cc +126 -0
  269. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_environment_test.cc +192 -0
  270. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_filter_unittest.py +636 -0
  271. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_filter_unittest_.cc +140 -0
  272. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_help_test.py +172 -0
  273. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_help_test_.cc +46 -0
  274. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_list_tests_unittest.py +207 -0
  275. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_list_tests_unittest_.cc +157 -0
  276. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_main_unittest.cc +45 -0
  277. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_no_test_unittest.cc +56 -0
  278. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_output_test.py +340 -0
  279. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_output_test_.cc +1062 -0
  280. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_output_test_golden_lin.txt +743 -0
  281. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_pred_impl_unittest.cc +2427 -0
  282. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_premature_exit_test.cc +127 -0
  283. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_prod_test.cc +57 -0
  284. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_repeat_test.cc +253 -0
  285. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_shuffle_test.py +325 -0
  286. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_shuffle_test_.cc +103 -0
  287. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_sole_header_test.cc +57 -0
  288. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_stress_test.cc +256 -0
  289. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_test_utils.py +320 -0
  290. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_throw_on_failure_ex_test.cc +92 -0
  291. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_throw_on_failure_test.py +171 -0
  292. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_throw_on_failure_test_.cc +72 -0
  293. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_uninitialized_test.py +70 -0
  294. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_uninitialized_test_.cc +43 -0
  295. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_unittest.cc +7706 -0
  296. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_xml_outfile1_test_.cc +49 -0
  297. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_xml_outfile2_test_.cc +49 -0
  298. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_xml_outfiles_test.py +132 -0
  299. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_xml_output_unittest.py +308 -0
  300. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_xml_output_unittest_.cc +181 -0
  301. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/gtest_xml_test_utils.py +194 -0
  302. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/production.cc +36 -0
  303. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/test/production.h +55 -0
  304. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/xcode/Config/DebugProject.xcconfig +30 -0
  305. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/xcode/Config/FrameworkTarget.xcconfig +17 -0
  306. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/xcode/Config/General.xcconfig +41 -0
  307. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/xcode/Config/ReleaseProject.xcconfig +32 -0
  308. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/xcode/Config/StaticLibraryTarget.xcconfig +18 -0
  309. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/xcode/Config/TestTarget.xcconfig +8 -0
  310. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/xcode/Resources/Info.plist +30 -0
  311. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/xcode/Samples/FrameworkSample/Info.plist +28 -0
  312. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/xcode/Samples/FrameworkSample/WidgetFramework.xcodeproj/project.pbxproj +457 -0
  313. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/xcode/Samples/FrameworkSample/runtests.sh +62 -0
  314. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/xcode/Samples/FrameworkSample/widget.cc +63 -0
  315. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/xcode/Samples/FrameworkSample/widget.h +59 -0
  316. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/xcode/Samples/FrameworkSample/widget_test.cc +68 -0
  317. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/xcode/Scripts/runtests.sh +65 -0
  318. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/xcode/Scripts/versiongenerate.py +100 -0
  319. data/ext/rj_schema/rapidjson/thirdparty/gtest/googletest/xcode/gtest.xcodeproj/project.pbxproj +1135 -0
  320. data/ext/rj_schema/rapidjson/thirdparty/gtest/travis.sh +15 -0
  321. data/ext/rj_schema/rj_schema.cpp +64 -41
  322. data/lib/rj_schema.rb +1 -1
  323. metadata +378 -5
@@ -0,0 +1,232 @@
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
+ &gtest_failures, ::testing::TestPartResult::kFatalFailure, (substr));\
147
+ {\
148
+ ::testing::ScopedFakeTestPartResultReporter gtest_reporter(\
149
+ ::testing::ScopedFakeTestPartResultReporter:: \
150
+ INTERCEPT_ONLY_CURRENT_THREAD, &gtest_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
+ &gtest_failures, ::testing::TestPartResult::kFatalFailure, (substr));\
164
+ {\
165
+ ::testing::ScopedFakeTestPartResultReporter gtest_reporter(\
166
+ ::testing::ScopedFakeTestPartResultReporter:: \
167
+ INTERCEPT_ALL_THREADS, &gtest_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
+ &gtest_failures, ::testing::TestPartResult::kNonFatalFailure, \
209
+ (substr));\
210
+ {\
211
+ ::testing::ScopedFakeTestPartResultReporter gtest_reporter(\
212
+ ::testing::ScopedFakeTestPartResultReporter:: \
213
+ INTERCEPT_ONLY_CURRENT_THREAD, &gtest_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
+ &gtest_failures, ::testing::TestPartResult::kNonFatalFailure, \
223
+ (substr));\
224
+ {\
225
+ ::testing::ScopedFakeTestPartResultReporter gtest_reporter(\
226
+ ::testing::ScopedFakeTestPartResultReporter::INTERCEPT_ALL_THREADS, \
227
+ &gtest_failures);\
228
+ if (::testing::internal::AlwaysTrue()) { statement; }\
229
+ }\
230
+ } while (::testing::internal::AlwaysFalse())
231
+
232
+ #endif // GTEST_INCLUDE_GTEST_GTEST_SPI_H_
@@ -0,0 +1,179 @@
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 == NULL ? "" : 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 {
77
+ return file_name_.empty() ? NULL : file_name_.c_str();
78
+ }
79
+
80
+ // Gets the line in the source file where the test part took place,
81
+ // or -1 if it's unknown.
82
+ int line_number() const { return line_number_; }
83
+
84
+ // Gets the summary of the failure message.
85
+ const char* summary() const { return summary_.c_str(); }
86
+
87
+ // Gets the message associated with the test part.
88
+ const char* message() const { return message_.c_str(); }
89
+
90
+ // Returns true iff the test part passed.
91
+ bool passed() const { return type_ == kSuccess; }
92
+
93
+ // Returns true iff the test part failed.
94
+ bool failed() const { return type_ != kSuccess; }
95
+
96
+ // Returns true iff the test part non-fatally failed.
97
+ bool nonfatally_failed() const { return type_ == kNonFatalFailure; }
98
+
99
+ // Returns true iff the test part fatally failed.
100
+ bool fatally_failed() const { return type_ == kFatalFailure; }
101
+
102
+ private:
103
+ Type type_;
104
+
105
+ // Gets the summary of the failure message by omitting the stack
106
+ // trace in it.
107
+ static std::string ExtractSummary(const char* message);
108
+
109
+ // The name of the source file where the test part took place, or
110
+ // "" if the source file is unknown.
111
+ std::string file_name_;
112
+ // The line in the source file where the test part took place, or -1
113
+ // if the line number is unknown.
114
+ int line_number_;
115
+ std::string summary_; // The test failure summary.
116
+ std::string message_; // The test failure message.
117
+ };
118
+
119
+ // Prints a TestPartResult object.
120
+ std::ostream& operator<<(std::ostream& os, const TestPartResult& result);
121
+
122
+ // An array of TestPartResult objects.
123
+ //
124
+ // Don't inherit from TestPartResultArray as its destructor is not
125
+ // virtual.
126
+ class GTEST_API_ TestPartResultArray {
127
+ public:
128
+ TestPartResultArray() {}
129
+
130
+ // Appends the given TestPartResult to the array.
131
+ void Append(const TestPartResult& result);
132
+
133
+ // Returns the TestPartResult at the given index (0-based).
134
+ const TestPartResult& GetTestPartResult(int index) const;
135
+
136
+ // Returns the number of TestPartResult objects in the array.
137
+ int size() const;
138
+
139
+ private:
140
+ std::vector<TestPartResult> array_;
141
+
142
+ GTEST_DISALLOW_COPY_AND_ASSIGN_(TestPartResultArray);
143
+ };
144
+
145
+ // This interface knows how to report a test part result.
146
+ class TestPartResultReporterInterface {
147
+ public:
148
+ virtual ~TestPartResultReporterInterface() {}
149
+
150
+ virtual void ReportTestPartResult(const TestPartResult& result) = 0;
151
+ };
152
+
153
+ namespace internal {
154
+
155
+ // This helper class is used by {ASSERT|EXPECT}_NO_FATAL_FAILURE to check if a
156
+ // statement generates new fatal failures. To do so it registers itself as the
157
+ // current test part result reporter. Besides checking if fatal failures were
158
+ // reported, it only delegates the reporting to the former result reporter.
159
+ // The original result reporter is restored in the destructor.
160
+ // INTERNAL IMPLEMENTATION - DO NOT USE IN A USER PROGRAM.
161
+ class GTEST_API_ HasNewFatalFailureHelper
162
+ : public TestPartResultReporterInterface {
163
+ public:
164
+ HasNewFatalFailureHelper();
165
+ virtual ~HasNewFatalFailureHelper();
166
+ virtual void ReportTestPartResult(const TestPartResult& result);
167
+ bool has_new_fatal_failure() const { return has_new_fatal_failure_; }
168
+ private:
169
+ bool has_new_fatal_failure_;
170
+ TestPartResultReporterInterface* original_reporter_;
171
+
172
+ GTEST_DISALLOW_COPY_AND_ASSIGN_(HasNewFatalFailureHelper);
173
+ };
174
+
175
+ } // namespace internal
176
+
177
+ } // namespace testing
178
+
179
+ #endif // GTEST_INCLUDE_GTEST_GTEST_TEST_PART_H_
@@ -0,0 +1,263 @@
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
+ "", ::testing::internal::CodeLocation(__FILE__, __LINE__), \
185
+ #CaseName, #TestName, 0); \
186
+ template <typename gtest_TypeParam_> \
187
+ void GTEST_TEST_CLASS_NAME_(CaseName, TestName)<gtest_TypeParam_>::TestBody()
188
+
189
+ #endif // GTEST_HAS_TYPED_TEST
190
+
191
+ // Implements type-parameterized tests.
192
+
193
+ #if GTEST_HAS_TYPED_TEST_P
194
+
195
+ // INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE.
196
+ //
197
+ // Expands to the namespace name that the type-parameterized tests for
198
+ // the given type-parameterized test case are defined in. The exact
199
+ // name of the namespace is subject to change without notice.
200
+ # define GTEST_CASE_NAMESPACE_(TestCaseName) \
201
+ gtest_case_##TestCaseName##_
202
+
203
+ // INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE.
204
+ //
205
+ // Expands to the name of the variable used to remember the names of
206
+ // the defined tests in the given test case.
207
+ # define GTEST_TYPED_TEST_CASE_P_STATE_(TestCaseName) \
208
+ gtest_typed_test_case_p_state_##TestCaseName##_
209
+
210
+ // INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE DIRECTLY.
211
+ //
212
+ // Expands to the name of the variable used to remember the names of
213
+ // the registered tests in the given test case.
214
+ # define GTEST_REGISTERED_TEST_NAMES_(TestCaseName) \
215
+ gtest_registered_test_names_##TestCaseName##_
216
+
217
+ // The variables defined in the type-parameterized test macros are
218
+ // static as typically these macros are used in a .h file that can be
219
+ // #included in multiple translation units linked together.
220
+ # define TYPED_TEST_CASE_P(CaseName) \
221
+ static ::testing::internal::TypedTestCasePState \
222
+ GTEST_TYPED_TEST_CASE_P_STATE_(CaseName)
223
+
224
+ # define TYPED_TEST_P(CaseName, TestName) \
225
+ namespace GTEST_CASE_NAMESPACE_(CaseName) { \
226
+ template <typename gtest_TypeParam_> \
227
+ class TestName : public CaseName<gtest_TypeParam_> { \
228
+ private: \
229
+ typedef CaseName<gtest_TypeParam_> TestFixture; \
230
+ typedef gtest_TypeParam_ TypeParam; \
231
+ virtual void TestBody(); \
232
+ }; \
233
+ static bool gtest_##TestName##_defined_ GTEST_ATTRIBUTE_UNUSED_ = \
234
+ GTEST_TYPED_TEST_CASE_P_STATE_(CaseName).AddTestName(\
235
+ __FILE__, __LINE__, #CaseName, #TestName); \
236
+ } \
237
+ template <typename gtest_TypeParam_> \
238
+ void GTEST_CASE_NAMESPACE_(CaseName)::TestName<gtest_TypeParam_>::TestBody()
239
+
240
+ # define REGISTER_TYPED_TEST_CASE_P(CaseName, ...) \
241
+ namespace GTEST_CASE_NAMESPACE_(CaseName) { \
242
+ typedef ::testing::internal::Templates<__VA_ARGS__>::type gtest_AllTests_; \
243
+ } \
244
+ static const char* const GTEST_REGISTERED_TEST_NAMES_(CaseName) = \
245
+ GTEST_TYPED_TEST_CASE_P_STATE_(CaseName).VerifyRegisteredTestNames(\
246
+ __FILE__, __LINE__, #__VA_ARGS__)
247
+
248
+ // The 'Types' template argument below must have spaces around it
249
+ // since some compilers may choke on '>>' when passing a template
250
+ // instance (e.g. Types<int>)
251
+ # define INSTANTIATE_TYPED_TEST_CASE_P(Prefix, CaseName, Types) \
252
+ bool gtest_##Prefix##_##CaseName GTEST_ATTRIBUTE_UNUSED_ = \
253
+ ::testing::internal::TypeParameterizedTestCase<CaseName, \
254
+ GTEST_CASE_NAMESPACE_(CaseName)::gtest_AllTests_, \
255
+ ::testing::internal::TypeList< Types >::type>::Register(\
256
+ #Prefix, \
257
+ ::testing::internal::CodeLocation(__FILE__, __LINE__), \
258
+ &GTEST_TYPED_TEST_CASE_P_STATE_(CaseName), \
259
+ #CaseName, GTEST_REGISTERED_TEST_NAMES_(CaseName))
260
+
261
+ #endif // GTEST_HAS_TYPED_TEST_P
262
+
263
+ #endif // GTEST_INCLUDE_GTEST_GTEST_TYPED_TEST_H_