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,146 @@
1
+ m4_include(../googletest/m4/acx_pthread.m4)
2
+
3
+ AC_INIT([Google C++ Mocking Framework],
4
+ [1.7.0],
5
+ [googlemock@googlegroups.com],
6
+ [gmock])
7
+
8
+ # Provide various options to initialize the Autoconf and configure processes.
9
+ AC_PREREQ([2.59])
10
+ AC_CONFIG_SRCDIR([./LICENSE])
11
+ AC_CONFIG_AUX_DIR([build-aux])
12
+ AC_CONFIG_HEADERS([build-aux/config.h])
13
+ AC_CONFIG_FILES([Makefile])
14
+ AC_CONFIG_FILES([scripts/gmock-config], [chmod +x scripts/gmock-config])
15
+
16
+ # Initialize Automake with various options. We require at least v1.9, prevent
17
+ # pedantic complaints about package files, and enable various distribution
18
+ # targets.
19
+ AM_INIT_AUTOMAKE([1.9 dist-bzip2 dist-zip foreign subdir-objects])
20
+
21
+ # Check for programs used in building Google Test.
22
+ AC_PROG_CC
23
+ AC_PROG_CXX
24
+ AC_LANG([C++])
25
+ AC_PROG_LIBTOOL
26
+
27
+ # TODO(chandlerc@google.com): Currently we aren't running the Python tests
28
+ # against the interpreter detected by AM_PATH_PYTHON, and so we condition
29
+ # HAVE_PYTHON by requiring "python" to be in the PATH, and that interpreter's
30
+ # version to be >= 2.3. This will allow the scripts to use a "/usr/bin/env"
31
+ # hashbang.
32
+ PYTHON= # We *do not* allow the user to specify a python interpreter
33
+ AC_PATH_PROG([PYTHON],[python],[:])
34
+ AS_IF([test "$PYTHON" != ":"],
35
+ [AM_PYTHON_CHECK_VERSION([$PYTHON],[2.3],[:],[PYTHON=":"])])
36
+ AM_CONDITIONAL([HAVE_PYTHON],[test "$PYTHON" != ":"])
37
+
38
+ # TODO(chandlerc@google.com) Check for the necessary system headers.
39
+
40
+ # Configure pthreads.
41
+ AC_ARG_WITH([pthreads],
42
+ [AS_HELP_STRING([--with-pthreads],
43
+ [use pthreads (default is yes)])],
44
+ [with_pthreads=$withval],
45
+ [with_pthreads=check])
46
+
47
+ have_pthreads=no
48
+ AS_IF([test "x$with_pthreads" != "xno"],
49
+ [ACX_PTHREAD(
50
+ [],
51
+ [AS_IF([test "x$with_pthreads" != "xcheck"],
52
+ [AC_MSG_FAILURE(
53
+ [--with-pthreads was specified, but unable to be used])])])
54
+ have_pthreads="$acx_pthread_ok"])
55
+ AM_CONDITIONAL([HAVE_PTHREADS],[test "x$have_pthreads" == "xyes"])
56
+ AC_SUBST(PTHREAD_CFLAGS)
57
+ AC_SUBST(PTHREAD_LIBS)
58
+
59
+ # GoogleMock currently has hard dependencies upon GoogleTest above and beyond
60
+ # running its own test suite, so we both provide our own version in
61
+ # a subdirectory and provide some logic to use a custom version or a system
62
+ # installed version.
63
+ AC_ARG_WITH([gtest],
64
+ [AS_HELP_STRING([--with-gtest],
65
+ [Specifies how to find the gtest package. If no
66
+ arguments are given, the default behavior, a
67
+ system installed gtest will be used if present,
68
+ and an internal version built otherwise. If a
69
+ path is provided, the gtest built or installed at
70
+ that prefix will be used.])],
71
+ [],
72
+ [with_gtest=yes])
73
+ AC_ARG_ENABLE([external-gtest],
74
+ [AS_HELP_STRING([--disable-external-gtest],
75
+ [Disables any detection or use of a system
76
+ installed or user provided gtest. Any option to
77
+ '--with-gtest' is ignored. (Default is enabled.)])
78
+ ], [], [enable_external_gtest=yes])
79
+ AS_IF([test "x$with_gtest" == "xno"],
80
+ [AC_MSG_ERROR([dnl
81
+ Support for GoogleTest was explicitly disabled. Currently GoogleMock has a hard
82
+ dependency upon GoogleTest to build, please provide a version, or allow
83
+ GoogleMock to use any installed version and fall back upon its internal
84
+ version.])])
85
+
86
+ # Setup various GTEST variables. TODO(chandlerc@google.com): When these are
87
+ # used below, they should be used such that any pre-existing values always
88
+ # trump values we set them to, so that they can be used to selectively override
89
+ # details of the detection process.
90
+ AC_ARG_VAR([GTEST_CONFIG],
91
+ [The exact path of Google Test's 'gtest-config' script.])
92
+ AC_ARG_VAR([GTEST_CPPFLAGS],
93
+ [C-like preprocessor flags for Google Test.])
94
+ AC_ARG_VAR([GTEST_CXXFLAGS],
95
+ [C++ compile flags for Google Test.])
96
+ AC_ARG_VAR([GTEST_LDFLAGS],
97
+ [Linker path and option flags for Google Test.])
98
+ AC_ARG_VAR([GTEST_LIBS],
99
+ [Library linking flags for Google Test.])
100
+ AC_ARG_VAR([GTEST_VERSION],
101
+ [The version of Google Test available.])
102
+ HAVE_BUILT_GTEST="no"
103
+
104
+ GTEST_MIN_VERSION="1.7.0"
105
+
106
+ AS_IF([test "x${enable_external_gtest}" = "xyes"],
107
+ [# Begin filling in variables as we are able.
108
+ AS_IF([test "x${with_gtest}" != "xyes"],
109
+ [AS_IF([test -x "${with_gtest}/scripts/gtest-config"],
110
+ [GTEST_CONFIG="${with_gtest}/scripts/gtest-config"],
111
+ [GTEST_CONFIG="${with_gtest}/bin/gtest-config"])
112
+ AS_IF([test -x "${GTEST_CONFIG}"], [],
113
+ [AC_MSG_ERROR([dnl
114
+ Unable to locate either a built or installed Google Test at '${with_gtest}'.])
115
+ ])])
116
+
117
+ AS_IF([test -x "${GTEST_CONFIG}"], [],
118
+ [AC_PATH_PROG([GTEST_CONFIG], [gtest-config])])
119
+ AS_IF([test -x "${GTEST_CONFIG}"],
120
+ [AC_MSG_CHECKING([for Google Test version >= ${GTEST_MIN_VERSION}])
121
+ AS_IF([${GTEST_CONFIG} --min-version=${GTEST_MIN_VERSION}],
122
+ [AC_MSG_RESULT([yes])
123
+ HAVE_BUILT_GTEST="yes"],
124
+ [AC_MSG_RESULT([no])])])])
125
+
126
+ AS_IF([test "x${HAVE_BUILT_GTEST}" = "xyes"],
127
+ [GTEST_CPPFLAGS=`${GTEST_CONFIG} --cppflags`
128
+ GTEST_CXXFLAGS=`${GTEST_CONFIG} --cxxflags`
129
+ GTEST_LDFLAGS=`${GTEST_CONFIG} --ldflags`
130
+ GTEST_LIBS=`${GTEST_CONFIG} --libs`
131
+ GTEST_VERSION=`${GTEST_CONFIG} --version`],
132
+ [AC_CONFIG_SUBDIRS([../googletest])
133
+ # GTEST_CONFIG needs to be executable both in a Makefile environmont and
134
+ # in a shell script environment, so resolve an absolute path for it here.
135
+ GTEST_CONFIG="`pwd -P`/../googletest/scripts/gtest-config"
136
+ GTEST_CPPFLAGS='-I$(top_srcdir)/../googletest/include'
137
+ GTEST_CXXFLAGS='-g'
138
+ GTEST_LDFLAGS=''
139
+ GTEST_LIBS='$(top_builddir)/../googletest/lib/libgtest.la'
140
+ GTEST_VERSION="${GTEST_MIN_VERSION}"])
141
+
142
+ # TODO(chandlerc@google.com) Check the types, structures, and other compiler
143
+ # and architecture characteristics.
144
+
145
+ # Output the generated files. No further autoconf macros may be used.
146
+ AC_OUTPUT
@@ -0,0 +1,562 @@
1
+
2
+
3
+ # Defining a Mock Class #
4
+
5
+ ## Mocking a Normal Class ##
6
+
7
+ Given
8
+ ```
9
+ class Foo {
10
+ ...
11
+ virtual ~Foo();
12
+ virtual int GetSize() const = 0;
13
+ virtual string Describe(const char* name) = 0;
14
+ virtual string Describe(int type) = 0;
15
+ virtual bool Process(Bar elem, int count) = 0;
16
+ };
17
+ ```
18
+ (note that `~Foo()` **must** be virtual) we can define its mock as
19
+ ```
20
+ #include "gmock/gmock.h"
21
+
22
+ class MockFoo : public Foo {
23
+ MOCK_CONST_METHOD0(GetSize, int());
24
+ MOCK_METHOD1(Describe, string(const char* name));
25
+ MOCK_METHOD1(Describe, string(int type));
26
+ MOCK_METHOD2(Process, bool(Bar elem, int count));
27
+ };
28
+ ```
29
+
30
+ To create a "nice" mock object which ignores all uninteresting calls,
31
+ or a "strict" mock object, which treats them as failures:
32
+ ```
33
+ NiceMock<MockFoo> nice_foo; // The type is a subclass of MockFoo.
34
+ StrictMock<MockFoo> strict_foo; // The type is a subclass of MockFoo.
35
+ ```
36
+
37
+ ## Mocking a Class Template ##
38
+
39
+ To mock
40
+ ```
41
+ template <typename Elem>
42
+ class StackInterface {
43
+ public:
44
+ ...
45
+ virtual ~StackInterface();
46
+ virtual int GetSize() const = 0;
47
+ virtual void Push(const Elem& x) = 0;
48
+ };
49
+ ```
50
+ (note that `~StackInterface()` **must** be virtual) just append `_T` to the `MOCK_*` macros:
51
+ ```
52
+ template <typename Elem>
53
+ class MockStack : public StackInterface<Elem> {
54
+ public:
55
+ ...
56
+ MOCK_CONST_METHOD0_T(GetSize, int());
57
+ MOCK_METHOD1_T(Push, void(const Elem& x));
58
+ };
59
+ ```
60
+
61
+ ## Specifying Calling Conventions for Mock Functions ##
62
+
63
+ If your mock function doesn't use the default calling convention, you
64
+ can specify it by appending `_WITH_CALLTYPE` to any of the macros
65
+ described in the previous two sections and supplying the calling
66
+ convention as the first argument to the macro. For example,
67
+ ```
68
+ MOCK_METHOD_1_WITH_CALLTYPE(STDMETHODCALLTYPE, Foo, bool(int n));
69
+ MOCK_CONST_METHOD2_WITH_CALLTYPE(STDMETHODCALLTYPE, Bar, int(double x, double y));
70
+ ```
71
+ where `STDMETHODCALLTYPE` is defined by `<objbase.h>` on Windows.
72
+
73
+ # Using Mocks in Tests #
74
+
75
+ The typical flow is:
76
+ 1. Import the Google Mock names you need to use. All Google Mock names are in the `testing` namespace unless they are macros or otherwise noted.
77
+ 1. Create the mock objects.
78
+ 1. Optionally, set the default actions of the mock objects.
79
+ 1. Set your expectations on the mock objects (How will they be called? What wil they do?).
80
+ 1. Exercise code that uses the mock objects; if necessary, check the result using [Google Test](../../googletest/) assertions.
81
+ 1. When a mock objects is destructed, Google Mock automatically verifies that all expectations on it have been satisfied.
82
+
83
+ Here is an example:
84
+ ```
85
+ using ::testing::Return; // #1
86
+
87
+ TEST(BarTest, DoesThis) {
88
+ MockFoo foo; // #2
89
+
90
+ ON_CALL(foo, GetSize()) // #3
91
+ .WillByDefault(Return(1));
92
+ // ... other default actions ...
93
+
94
+ EXPECT_CALL(foo, Describe(5)) // #4
95
+ .Times(3)
96
+ .WillRepeatedly(Return("Category 5"));
97
+ // ... other expectations ...
98
+
99
+ EXPECT_EQ("good", MyProductionFunction(&foo)); // #5
100
+ } // #6
101
+ ```
102
+
103
+ # Setting Default Actions #
104
+
105
+ Google Mock has a **built-in default action** for any function that
106
+ returns `void`, `bool`, a numeric value, or a pointer.
107
+
108
+ To customize the default action for functions with return type `T` globally:
109
+ ```
110
+ using ::testing::DefaultValue;
111
+
112
+ // Sets the default value to be returned. T must be CopyConstructible.
113
+ DefaultValue<T>::Set(value);
114
+ // Sets a factory. Will be invoked on demand. T must be MoveConstructible.
115
+ // T MakeT();
116
+ DefaultValue<T>::SetFactory(&MakeT);
117
+ // ... use the mocks ...
118
+ // Resets the default value.
119
+ DefaultValue<T>::Clear();
120
+ ```
121
+
122
+ To customize the default action for a particular method, use `ON_CALL()`:
123
+ ```
124
+ ON_CALL(mock_object, method(matchers))
125
+ .With(multi_argument_matcher) ?
126
+ .WillByDefault(action);
127
+ ```
128
+
129
+ # Setting Expectations #
130
+
131
+ `EXPECT_CALL()` sets **expectations** on a mock method (How will it be
132
+ called? What will it do?):
133
+ ```
134
+ EXPECT_CALL(mock_object, method(matchers))
135
+ .With(multi_argument_matcher) ?
136
+ .Times(cardinality) ?
137
+ .InSequence(sequences) *
138
+ .After(expectations) *
139
+ .WillOnce(action) *
140
+ .WillRepeatedly(action) ?
141
+ .RetiresOnSaturation(); ?
142
+ ```
143
+
144
+ If `Times()` is omitted, the cardinality is assumed to be:
145
+
146
+ * `Times(1)` when there is neither `WillOnce()` nor `WillRepeatedly()`;
147
+ * `Times(n)` when there are `n WillOnce()`s but no `WillRepeatedly()`, where `n` >= 1; or
148
+ * `Times(AtLeast(n))` when there are `n WillOnce()`s and a `WillRepeatedly()`, where `n` >= 0.
149
+
150
+ A method with no `EXPECT_CALL()` is free to be invoked _any number of times_, and the default action will be taken each time.
151
+
152
+ # Matchers #
153
+
154
+ A **matcher** matches a _single_ argument. You can use it inside
155
+ `ON_CALL()` or `EXPECT_CALL()`, or use it to validate a value
156
+ directly:
157
+
158
+ | `EXPECT_THAT(value, matcher)` | Asserts that `value` matches `matcher`. |
159
+ |:------------------------------|:----------------------------------------|
160
+ | `ASSERT_THAT(value, matcher)` | The same as `EXPECT_THAT(value, matcher)`, except that it generates a **fatal** failure. |
161
+
162
+ Built-in matchers (where `argument` is the function argument) are
163
+ divided into several categories:
164
+
165
+ ## Wildcard ##
166
+ |`_`|`argument` can be any value of the correct type.|
167
+ |:--|:-----------------------------------------------|
168
+ |`A<type>()` or `An<type>()`|`argument` can be any value of type `type`. |
169
+
170
+ ## Generic Comparison ##
171
+
172
+ |`Eq(value)` or `value`|`argument == value`|
173
+ |:---------------------|:------------------|
174
+ |`Ge(value)` |`argument >= value`|
175
+ |`Gt(value)` |`argument > value` |
176
+ |`Le(value)` |`argument <= value`|
177
+ |`Lt(value)` |`argument < value` |
178
+ |`Ne(value)` |`argument != value`|
179
+ |`IsNull()` |`argument` is a `NULL` pointer (raw or smart).|
180
+ |`NotNull()` |`argument` is a non-null pointer (raw or smart).|
181
+ |`Ref(variable)` |`argument` is a reference to `variable`.|
182
+ |`TypedEq<type>(value)`|`argument` has type `type` and is equal to `value`. You may need to use this instead of `Eq(value)` when the mock function is overloaded.|
183
+
184
+ Except `Ref()`, these matchers make a _copy_ of `value` in case it's
185
+ modified or destructed later. If the compiler complains that `value`
186
+ doesn't have a public copy constructor, try wrap it in `ByRef()`,
187
+ e.g. `Eq(ByRef(non_copyable_value))`. If you do that, make sure
188
+ `non_copyable_value` is not changed afterwards, or the meaning of your
189
+ matcher will be changed.
190
+
191
+ ## Floating-Point Matchers ##
192
+
193
+ |`DoubleEq(a_double)`|`argument` is a `double` value approximately equal to `a_double`, treating two NaNs as unequal.|
194
+ |:-------------------|:----------------------------------------------------------------------------------------------|
195
+ |`FloatEq(a_float)` |`argument` is a `float` value approximately equal to `a_float`, treating two NaNs as unequal. |
196
+ |`NanSensitiveDoubleEq(a_double)`|`argument` is a `double` value approximately equal to `a_double`, treating two NaNs as equal. |
197
+ |`NanSensitiveFloatEq(a_float)`|`argument` is a `float` value approximately equal to `a_float`, treating two NaNs as equal. |
198
+
199
+ The above matchers use ULP-based comparison (the same as used in
200
+ [Google Test](../../googletest/)). They
201
+ automatically pick a reasonable error bound based on the absolute
202
+ value of the expected value. `DoubleEq()` and `FloatEq()` conform to
203
+ the IEEE standard, which requires comparing two NaNs for equality to
204
+ return false. The `NanSensitive*` version instead treats two NaNs as
205
+ equal, which is often what a user wants.
206
+
207
+ |`DoubleNear(a_double, max_abs_error)`|`argument` is a `double` value close to `a_double` (absolute error <= `max_abs_error`), treating two NaNs as unequal.|
208
+ |:------------------------------------|:--------------------------------------------------------------------------------------------------------------------|
209
+ |`FloatNear(a_float, max_abs_error)` |`argument` is a `float` value close to `a_float` (absolute error <= `max_abs_error`), treating two NaNs as unequal. |
210
+ |`NanSensitiveDoubleNear(a_double, max_abs_error)`|`argument` is a `double` value close to `a_double` (absolute error <= `max_abs_error`), treating two NaNs as equal. |
211
+ |`NanSensitiveFloatNear(a_float, max_abs_error)`|`argument` is a `float` value close to `a_float` (absolute error <= `max_abs_error`), treating two NaNs as equal. |
212
+
213
+ ## String Matchers ##
214
+
215
+ The `argument` can be either a C string or a C++ string object:
216
+
217
+ |`ContainsRegex(string)`|`argument` matches the given regular expression.|
218
+ |:----------------------|:-----------------------------------------------|
219
+ |`EndsWith(suffix)` |`argument` ends with string `suffix`. |
220
+ |`HasSubstr(string)` |`argument` contains `string` as a sub-string. |
221
+ |`MatchesRegex(string)` |`argument` matches the given regular expression with the match starting at the first character and ending at the last character.|
222
+ |`StartsWith(prefix)` |`argument` starts with string `prefix`. |
223
+ |`StrCaseEq(string)` |`argument` is equal to `string`, ignoring case. |
224
+ |`StrCaseNe(string)` |`argument` is not equal to `string`, ignoring case.|
225
+ |`StrEq(string)` |`argument` is equal to `string`. |
226
+ |`StrNe(string)` |`argument` is not equal to `string`. |
227
+
228
+ `ContainsRegex()` and `MatchesRegex()` use the regular expression
229
+ syntax defined
230
+ [here](../../googletest/docs/AdvancedGuide.md#regular-expression-syntax).
231
+ `StrCaseEq()`, `StrCaseNe()`, `StrEq()`, and `StrNe()` work for wide
232
+ strings as well.
233
+
234
+ ## Container Matchers ##
235
+
236
+ Most STL-style containers support `==`, so you can use
237
+ `Eq(expected_container)` or simply `expected_container` to match a
238
+ container exactly. If you want to write the elements in-line,
239
+ match them more flexibly, or get more informative messages, you can use:
240
+
241
+ | `ContainerEq(container)` | The same as `Eq(container)` except that the failure message also includes which elements are in one container but not the other. |
242
+ |:-------------------------|:---------------------------------------------------------------------------------------------------------------------------------|
243
+ | `Contains(e)` | `argument` contains an element that matches `e`, which can be either a value or a matcher. |
244
+ | `Each(e)` | `argument` is a container where _every_ element matches `e`, which can be either a value or a matcher. |
245
+ | `ElementsAre(e0, e1, ..., en)` | `argument` has `n + 1` elements, where the i-th element matches `ei`, which can be a value or a matcher. 0 to 10 arguments are allowed. |
246
+ | `ElementsAreArray({ e0, e1, ..., en })`, `ElementsAreArray(array)`, or `ElementsAreArray(array, count)` | The same as `ElementsAre()` except that the expected element values/matchers come from an initializer list, STL-style container, or C-style array. |
247
+ | `IsEmpty()` | `argument` is an empty container (`container.empty()`). |
248
+ | `Pointwise(m, container)` | `argument` contains the same number of elements as in `container`, and for all i, (the i-th element in `argument`, the i-th element in `container`) match `m`, which is a matcher on 2-tuples. E.g. `Pointwise(Le(), upper_bounds)` verifies that each element in `argument` doesn't exceed the corresponding element in `upper_bounds`. See more detail below. |
249
+ | `SizeIs(m)` | `argument` is a container whose size matches `m`. E.g. `SizeIs(2)` or `SizeIs(Lt(2))`. |
250
+ | `UnorderedElementsAre(e0, e1, ..., en)` | `argument` has `n + 1` elements, and under some permutation each element matches an `ei` (for a different `i`), which can be a value or a matcher. 0 to 10 arguments are allowed. |
251
+ | `UnorderedElementsAreArray({ e0, e1, ..., en })`, `UnorderedElementsAreArray(array)`, or `UnorderedElementsAreArray(array, count)` | The same as `UnorderedElementsAre()` except that the expected element values/matchers come from an initializer list, STL-style container, or C-style array. |
252
+ | `WhenSorted(m)` | When `argument` is sorted using the `<` operator, it matches container matcher `m`. E.g. `WhenSorted(UnorderedElementsAre(1, 2, 3))` verifies that `argument` contains elements `1`, `2`, and `3`, ignoring order. |
253
+ | `WhenSortedBy(comparator, m)` | The same as `WhenSorted(m)`, except that the given comparator instead of `<` is used to sort `argument`. E.g. `WhenSortedBy(std::greater<int>(), ElementsAre(3, 2, 1))`. |
254
+
255
+ Notes:
256
+
257
+ * These matchers can also match:
258
+ 1. a native array passed by reference (e.g. in `Foo(const int (&a)[5])`), and
259
+ 1. an array passed as a pointer and a count (e.g. in `Bar(const T* buffer, int len)` -- see [Multi-argument Matchers](#Multiargument_Matchers.md)).
260
+ * The array being matched may be multi-dimensional (i.e. its elements can be arrays).
261
+ * `m` in `Pointwise(m, ...)` should be a matcher for `::testing::tuple<T, U>` where `T` and `U` are the element type of the actual container and the expected container, respectively. For example, to compare two `Foo` containers where `Foo` doesn't support `operator==` but has an `Equals()` method, one might write:
262
+
263
+ ```
264
+ using ::testing::get;
265
+ MATCHER(FooEq, "") {
266
+ return get<0>(arg).Equals(get<1>(arg));
267
+ }
268
+ ...
269
+ EXPECT_THAT(actual_foos, Pointwise(FooEq(), expected_foos));
270
+ ```
271
+
272
+ ## Member Matchers ##
273
+
274
+ |`Field(&class::field, m)`|`argument.field` (or `argument->field` when `argument` is a plain pointer) matches matcher `m`, where `argument` is an object of type _class_.|
275
+ |:------------------------|:---------------------------------------------------------------------------------------------------------------------------------------------|
276
+ |`Key(e)` |`argument.first` matches `e`, which can be either a value or a matcher. E.g. `Contains(Key(Le(5)))` can verify that a `map` contains a key `<= 5`.|
277
+ |`Pair(m1, m2)` |`argument` is an `std::pair` whose `first` field matches `m1` and `second` field matches `m2`. |
278
+ |`Property(&class::property, m)`|`argument.property()` (or `argument->property()` when `argument` is a plain pointer) matches matcher `m`, where `argument` is an object of type _class_.|
279
+
280
+ ## Matching the Result of a Function or Functor ##
281
+
282
+ |`ResultOf(f, m)`|`f(argument)` matches matcher `m`, where `f` is a function or functor.|
283
+ |:---------------|:---------------------------------------------------------------------|
284
+
285
+ ## Pointer Matchers ##
286
+
287
+ |`Pointee(m)`|`argument` (either a smart pointer or a raw pointer) points to a value that matches matcher `m`.|
288
+ |:-----------|:-----------------------------------------------------------------------------------------------|
289
+ |`WhenDynamicCastTo<T>(m)`| when `argument` is passed through `dynamic_cast<T>()`, it matches matcher `m`. |
290
+
291
+ ## Multiargument Matchers ##
292
+
293
+ Technically, all matchers match a _single_ value. A "multi-argument"
294
+ matcher is just one that matches a _tuple_. The following matchers can
295
+ be used to match a tuple `(x, y)`:
296
+
297
+ |`Eq()`|`x == y`|
298
+ |:-----|:-------|
299
+ |`Ge()`|`x >= y`|
300
+ |`Gt()`|`x > y` |
301
+ |`Le()`|`x <= y`|
302
+ |`Lt()`|`x < y` |
303
+ |`Ne()`|`x != y`|
304
+
305
+ You can use the following selectors to pick a subset of the arguments
306
+ (or reorder them) to participate in the matching:
307
+
308
+ |`AllArgs(m)`|Equivalent to `m`. Useful as syntactic sugar in `.With(AllArgs(m))`.|
309
+ |:-----------|:-------------------------------------------------------------------|
310
+ |`Args<N1, N2, ..., Nk>(m)`|The tuple of the `k` selected (using 0-based indices) arguments matches `m`, e.g. `Args<1, 2>(Eq())`.|
311
+
312
+ ## Composite Matchers ##
313
+
314
+ You can make a matcher from one or more other matchers:
315
+
316
+ |`AllOf(m1, m2, ..., mn)`|`argument` matches all of the matchers `m1` to `mn`.|
317
+ |:-----------------------|:---------------------------------------------------|
318
+ |`AnyOf(m1, m2, ..., mn)`|`argument` matches at least one of the matchers `m1` to `mn`.|
319
+ |`Not(m)` |`argument` doesn't match matcher `m`. |
320
+
321
+ ## Adapters for Matchers ##
322
+
323
+ |`MatcherCast<T>(m)`|casts matcher `m` to type `Matcher<T>`.|
324
+ |:------------------|:--------------------------------------|
325
+ |`SafeMatcherCast<T>(m)`| [safely casts](CookBook.md#casting-matchers) matcher `m` to type `Matcher<T>`. |
326
+ |`Truly(predicate)` |`predicate(argument)` returns something considered by C++ to be true, where `predicate` is a function or functor.|
327
+
328
+ ## Matchers as Predicates ##
329
+
330
+ |`Matches(m)(value)`|evaluates to `true` if `value` matches `m`. You can use `Matches(m)` alone as a unary functor.|
331
+ |:------------------|:---------------------------------------------------------------------------------------------|
332
+ |`ExplainMatchResult(m, value, result_listener)`|evaluates to `true` if `value` matches `m`, explaining the result to `result_listener`. |
333
+ |`Value(value, m)` |evaluates to `true` if `value` matches `m`. |
334
+
335
+ ## Defining Matchers ##
336
+
337
+ | `MATCHER(IsEven, "") { return (arg % 2) == 0; }` | Defines a matcher `IsEven()` to match an even number. |
338
+ |:-------------------------------------------------|:------------------------------------------------------|
339
+ | `MATCHER_P(IsDivisibleBy, n, "") { *result_listener << "where the remainder is " << (arg % n); return (arg % n) == 0; }` | Defines a macher `IsDivisibleBy(n)` to match a number divisible by `n`. |
340
+ | `MATCHER_P2(IsBetween, a, b, std::string(negation ? "isn't" : "is") + " between " + PrintToString(a) + " and " + PrintToString(b)) { return a <= arg && arg <= b; }` | Defines a matcher `IsBetween(a, b)` to match a value in the range [`a`, `b`]. |
341
+
342
+ **Notes:**
343
+
344
+ 1. The `MATCHER*` macros cannot be used inside a function or class.
345
+ 1. The matcher body must be _purely functional_ (i.e. it cannot have any side effect, and the result must not depend on anything other than the value being matched and the matcher parameters).
346
+ 1. You can use `PrintToString(x)` to convert a value `x` of any type to a string.
347
+
348
+ ## Matchers as Test Assertions ##
349
+
350
+ |`ASSERT_THAT(expression, m)`|Generates a [fatal failure](../../googletest/docs/Primer.md#assertions) if the value of `expression` doesn't match matcher `m`.|
351
+ |:---------------------------|:----------------------------------------------------------------------------------------------------------------------------------------------|
352
+ |`EXPECT_THAT(expression, m)`|Generates a non-fatal failure if the value of `expression` doesn't match matcher `m`. |
353
+
354
+ # Actions #
355
+
356
+ **Actions** specify what a mock function should do when invoked.
357
+
358
+ ## Returning a Value ##
359
+
360
+ |`Return()`|Return from a `void` mock function.|
361
+ |:---------|:----------------------------------|
362
+ |`Return(value)`|Return `value`. If the type of `value` is different to the mock function's return type, `value` is converted to the latter type <i>at the time the expectation is set</i>, not when the action is executed.|
363
+ |`ReturnArg<N>()`|Return the `N`-th (0-based) argument.|
364
+ |`ReturnNew<T>(a1, ..., ak)`|Return `new T(a1, ..., ak)`; a different object is created each time.|
365
+ |`ReturnNull()`|Return a null pointer. |
366
+ |`ReturnPointee(ptr)`|Return the value pointed to by `ptr`.|
367
+ |`ReturnRef(variable)`|Return a reference to `variable`. |
368
+ |`ReturnRefOfCopy(value)`|Return a reference to a copy of `value`; the copy lives as long as the action.|
369
+
370
+ ## Side Effects ##
371
+
372
+ |`Assign(&variable, value)`|Assign `value` to variable.|
373
+ |:-------------------------|:--------------------------|
374
+ | `DeleteArg<N>()` | Delete the `N`-th (0-based) argument, which must be a pointer. |
375
+ | `SaveArg<N>(pointer)` | Save the `N`-th (0-based) argument to `*pointer`. |
376
+ | `SaveArgPointee<N>(pointer)` | Save the value pointed to by the `N`-th (0-based) argument to `*pointer`. |
377
+ | `SetArgReferee<N>(value)` | Assign value to the variable referenced by the `N`-th (0-based) argument. |
378
+ |`SetArgPointee<N>(value)` |Assign `value` to the variable pointed by the `N`-th (0-based) argument.|
379
+ |`SetArgumentPointee<N>(value)`|Same as `SetArgPointee<N>(value)`. Deprecated. Will be removed in v1.7.0.|
380
+ |`SetArrayArgument<N>(first, last)`|Copies the elements in source range [`first`, `last`) to the array pointed to by the `N`-th (0-based) argument, which can be either a pointer or an iterator. The action does not take ownership of the elements in the source range.|
381
+ |`SetErrnoAndReturn(error, value)`|Set `errno` to `error` and return `value`.|
382
+ |`Throw(exception)` |Throws the given exception, which can be any copyable value. Available since v1.1.0.|
383
+
384
+ ## Using a Function or a Functor as an Action ##
385
+
386
+ |`Invoke(f)`|Invoke `f` with the arguments passed to the mock function, where `f` can be a global/static function or a functor.|
387
+ |:----------|:-----------------------------------------------------------------------------------------------------------------|
388
+ |`Invoke(object_pointer, &class::method)`|Invoke the {method on the object with the arguments passed to the mock function. |
389
+ |`InvokeWithoutArgs(f)`|Invoke `f`, which can be a global/static function or a functor. `f` must take no arguments. |
390
+ |`InvokeWithoutArgs(object_pointer, &class::method)`|Invoke the method on the object, which takes no arguments. |
391
+ |`InvokeArgument<N>(arg1, arg2, ..., argk)`|Invoke the mock function's `N`-th (0-based) argument, which must be a function or a functor, with the `k` arguments.|
392
+
393
+ The return value of the invoked function is used as the return value
394
+ of the action.
395
+
396
+ When defining a function or functor to be used with `Invoke*()`, you can declare any unused parameters as `Unused`:
397
+ ```
398
+ double Distance(Unused, double x, double y) { return sqrt(x*x + y*y); }
399
+ ...
400
+ EXPECT_CALL(mock, Foo("Hi", _, _)).WillOnce(Invoke(Distance));
401
+ ```
402
+
403
+ In `InvokeArgument<N>(...)`, if an argument needs to be passed by reference, wrap it inside `ByRef()`. For example,
404
+ ```
405
+ InvokeArgument<2>(5, string("Hi"), ByRef(foo))
406
+ ```
407
+ calls the mock function's #2 argument, passing to it `5` and `string("Hi")` by value, and `foo` by reference.
408
+
409
+ ## Default Action ##
410
+
411
+ |`DoDefault()`|Do the default action (specified by `ON_CALL()` or the built-in one).|
412
+ |:------------|:--------------------------------------------------------------------|
413
+
414
+ **Note:** due to technical reasons, `DoDefault()` cannot be used inside a composite action - trying to do so will result in a run-time error.
415
+
416
+ ## Composite Actions ##
417
+
418
+ |`DoAll(a1, a2, ..., an)`|Do all actions `a1` to `an` and return the result of `an` in each invocation. The first `n - 1` sub-actions must return void. |
419
+ |:-----------------------|:-----------------------------------------------------------------------------------------------------------------------------|
420
+ |`IgnoreResult(a)` |Perform action `a` and ignore its result. `a` must not return void. |
421
+ |`WithArg<N>(a)` |Pass the `N`-th (0-based) argument of the mock function to action `a` and perform it. |
422
+ |`WithArgs<N1, N2, ..., Nk>(a)`|Pass the selected (0-based) arguments of the mock function to action `a` and perform it. |
423
+ |`WithoutArgs(a)` |Perform action `a` without any arguments. |
424
+
425
+ ## Defining Actions ##
426
+
427
+ | `ACTION(Sum) { return arg0 + arg1; }` | Defines an action `Sum()` to return the sum of the mock function's argument #0 and #1. |
428
+ |:--------------------------------------|:---------------------------------------------------------------------------------------|
429
+ | `ACTION_P(Plus, n) { return arg0 + n; }` | Defines an action `Plus(n)` to return the sum of the mock function's argument #0 and `n`. |
430
+ | `ACTION_Pk(Foo, p1, ..., pk) { statements; }` | Defines a parameterized action `Foo(p1, ..., pk)` to execute the given `statements`. |
431
+
432
+ The `ACTION*` macros cannot be used inside a function or class.
433
+
434
+ # Cardinalities #
435
+
436
+ These are used in `Times()` to specify how many times a mock function will be called:
437
+
438
+ |`AnyNumber()`|The function can be called any number of times.|
439
+ |:------------|:----------------------------------------------|
440
+ |`AtLeast(n)` |The call is expected at least `n` times. |
441
+ |`AtMost(n)` |The call is expected at most `n` times. |
442
+ |`Between(m, n)`|The call is expected between `m` and `n` (inclusive) times.|
443
+ |`Exactly(n) or n`|The call is expected exactly `n` times. In particular, the call should never happen when `n` is 0.|
444
+
445
+ # Expectation Order #
446
+
447
+ By default, the expectations can be matched in _any_ order. If some
448
+ or all expectations must be matched in a given order, there are two
449
+ ways to specify it. They can be used either independently or
450
+ together.
451
+
452
+ ## The After Clause ##
453
+
454
+ ```
455
+ using ::testing::Expectation;
456
+ ...
457
+ Expectation init_x = EXPECT_CALL(foo, InitX());
458
+ Expectation init_y = EXPECT_CALL(foo, InitY());
459
+ EXPECT_CALL(foo, Bar())
460
+ .After(init_x, init_y);
461
+ ```
462
+ says that `Bar()` can be called only after both `InitX()` and
463
+ `InitY()` have been called.
464
+
465
+ If you don't know how many pre-requisites an expectation has when you
466
+ write it, you can use an `ExpectationSet` to collect them:
467
+
468
+ ```
469
+ using ::testing::ExpectationSet;
470
+ ...
471
+ ExpectationSet all_inits;
472
+ for (int i = 0; i < element_count; i++) {
473
+ all_inits += EXPECT_CALL(foo, InitElement(i));
474
+ }
475
+ EXPECT_CALL(foo, Bar())
476
+ .After(all_inits);
477
+ ```
478
+ says that `Bar()` can be called only after all elements have been
479
+ initialized (but we don't care about which elements get initialized
480
+ before the others).
481
+
482
+ Modifying an `ExpectationSet` after using it in an `.After()` doesn't
483
+ affect the meaning of the `.After()`.
484
+
485
+ ## Sequences ##
486
+
487
+ When you have a long chain of sequential expectations, it's easier to
488
+ specify the order using **sequences**, which don't require you to given
489
+ each expectation in the chain a different name. <i>All expected<br>
490
+ calls</i> in the same sequence must occur in the order they are
491
+ specified.
492
+
493
+ ```
494
+ using ::testing::Sequence;
495
+ Sequence s1, s2;
496
+ ...
497
+ EXPECT_CALL(foo, Reset())
498
+ .InSequence(s1, s2)
499
+ .WillOnce(Return(true));
500
+ EXPECT_CALL(foo, GetSize())
501
+ .InSequence(s1)
502
+ .WillOnce(Return(1));
503
+ EXPECT_CALL(foo, Describe(A<const char*>()))
504
+ .InSequence(s2)
505
+ .WillOnce(Return("dummy"));
506
+ ```
507
+ says that `Reset()` must be called before _both_ `GetSize()` _and_
508
+ `Describe()`, and the latter two can occur in any order.
509
+
510
+ To put many expectations in a sequence conveniently:
511
+ ```
512
+ using ::testing::InSequence;
513
+ {
514
+ InSequence dummy;
515
+
516
+ EXPECT_CALL(...)...;
517
+ EXPECT_CALL(...)...;
518
+ ...
519
+ EXPECT_CALL(...)...;
520
+ }
521
+ ```
522
+ says that all expected calls in the scope of `dummy` must occur in
523
+ strict order. The name `dummy` is irrelevant.)
524
+
525
+ # Verifying and Resetting a Mock #
526
+
527
+ Google Mock will verify the expectations on a mock object when it is destructed, or you can do it earlier:
528
+ ```
529
+ using ::testing::Mock;
530
+ ...
531
+ // Verifies and removes the expectations on mock_obj;
532
+ // returns true iff successful.
533
+ Mock::VerifyAndClearExpectations(&mock_obj);
534
+ ...
535
+ // Verifies and removes the expectations on mock_obj;
536
+ // also removes the default actions set by ON_CALL();
537
+ // returns true iff successful.
538
+ Mock::VerifyAndClear(&mock_obj);
539
+ ```
540
+
541
+ You can also tell Google Mock that a mock object can be leaked and doesn't
542
+ need to be verified:
543
+ ```
544
+ Mock::AllowLeak(&mock_obj);
545
+ ```
546
+
547
+ # Mock Classes #
548
+
549
+ Google Mock defines a convenient mock class template
550
+ ```
551
+ class MockFunction<R(A1, ..., An)> {
552
+ public:
553
+ MOCK_METHODn(Call, R(A1, ..., An));
554
+ };
555
+ ```
556
+ See this [recipe](CookBook.md#using-check-points) for one application of it.
557
+
558
+ # Flags #
559
+
560
+ | `--gmock_catch_leaked_mocks=0` | Don't report leaked mock objects as failures. |
561
+ |:-------------------------------|:----------------------------------------------|
562
+ | `--gmock_verbose=LEVEL` | Sets the default verbosity level (`info`, `warning`, or `error`) of Google Mock messages. |