takuya-lvm-snapshot 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (380) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +11 -0
  3. data/.rspec +4 -0
  4. data/Gemfile +10 -0
  5. data/LICENSE +674 -0
  6. data/README.md +80 -0
  7. data/Rakefile +4 -0
  8. data/bin/console +15 -0
  9. data/bin/setup +8 -0
  10. data/bundle/ruby/2.7.0/bin/htmldiff +29 -0
  11. data/bundle/ruby/2.7.0/bin/ldiff +29 -0
  12. data/bundle/ruby/2.7.0/bin/rake +27 -0
  13. data/bundle/ruby/2.7.0/bin/rspec +27 -0
  14. data/bundle/ruby/2.7.0/cache/diff-lcs-1.5.0.gem +0 -0
  15. data/bundle/ruby/2.7.0/cache/rake-13.0.3.gem +0 -0
  16. data/bundle/ruby/2.7.0/cache/rspec-3.12.0.gem +0 -0
  17. data/bundle/ruby/2.7.0/cache/rspec-core-3.12.0.gem +0 -0
  18. data/bundle/ruby/2.7.0/cache/rspec-expectations-3.12.1.gem +0 -0
  19. data/bundle/ruby/2.7.0/cache/rspec-mocks-3.12.1.gem +0 -0
  20. data/bundle/ruby/2.7.0/cache/rspec-support-3.12.0.gem +0 -0
  21. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/.rspec +1 -0
  22. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/Code-of-Conduct.md +74 -0
  23. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/Contributing.md +119 -0
  24. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/History.md +400 -0
  25. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/License.md +39 -0
  26. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/Manifest.txt +59 -0
  27. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/README.rdoc +84 -0
  28. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/Rakefile +121 -0
  29. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/bin/htmldiff +35 -0
  30. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/bin/ldiff +9 -0
  31. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/docs/COPYING.txt +339 -0
  32. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/docs/artistic.txt +127 -0
  33. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/lib/diff/lcs/array.rb +7 -0
  34. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/lib/diff/lcs/backports.rb +9 -0
  35. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/lib/diff/lcs/block.rb +37 -0
  36. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/lib/diff/lcs/callbacks.rb +325 -0
  37. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/lib/diff/lcs/change.rb +174 -0
  38. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/lib/diff/lcs/htmldiff.rb +150 -0
  39. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/lib/diff/lcs/hunk.rb +358 -0
  40. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/lib/diff/lcs/internals.rb +308 -0
  41. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/lib/diff/lcs/ldiff.rb +171 -0
  42. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/lib/diff/lcs/string.rb +5 -0
  43. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/lib/diff/lcs.rb +739 -0
  44. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/lib/diff-lcs.rb +3 -0
  45. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/change_spec.rb +89 -0
  46. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/diff_spec.rb +51 -0
  47. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/aX +1 -0
  48. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/bXaX +1 -0
  49. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/ds1.csv +50 -0
  50. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/ds2.csv +51 -0
  51. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/ldiff/output.diff +4 -0
  52. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/ldiff/output.diff-c +7 -0
  53. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/ldiff/output.diff-e +3 -0
  54. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/ldiff/output.diff-f +3 -0
  55. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/ldiff/output.diff-u +5 -0
  56. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/ldiff/output.diff.chef +4 -0
  57. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/ldiff/output.diff.chef-c +15 -0
  58. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/ldiff/output.diff.chef-e +3 -0
  59. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/ldiff/output.diff.chef-f +3 -0
  60. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/ldiff/output.diff.chef-u +9 -0
  61. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/ldiff/output.diff.chef2 +7 -0
  62. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/ldiff/output.diff.chef2-c +20 -0
  63. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/ldiff/output.diff.chef2-d +7 -0
  64. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/ldiff/output.diff.chef2-e +7 -0
  65. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/ldiff/output.diff.chef2-f +7 -0
  66. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/ldiff/output.diff.chef2-u +16 -0
  67. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/new-chef +4 -0
  68. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/new-chef2 +17 -0
  69. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/old-chef +4 -0
  70. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/fixtures/old-chef2 +14 -0
  71. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/hunk_spec.rb +83 -0
  72. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/issues_spec.rb +154 -0
  73. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/lcs_spec.rb +56 -0
  74. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/ldiff_spec.rb +87 -0
  75. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/patch_spec.rb +416 -0
  76. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/sdiff_spec.rb +214 -0
  77. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/spec_helper.rb +374 -0
  78. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/traverse_balanced_spec.rb +310 -0
  79. data/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/traverse_sequences_spec.rb +137 -0
  80. data/bundle/ruby/2.7.0/gems/rake-13.0.3/CONTRIBUTING.rdoc +43 -0
  81. data/bundle/ruby/2.7.0/gems/rake-13.0.3/Gemfile +10 -0
  82. data/bundle/ruby/2.7.0/gems/rake-13.0.3/History.rdoc +2386 -0
  83. data/bundle/ruby/2.7.0/gems/rake-13.0.3/MIT-LICENSE +21 -0
  84. data/bundle/ruby/2.7.0/gems/rake-13.0.3/README.rdoc +155 -0
  85. data/bundle/ruby/2.7.0/gems/rake-13.0.3/Rakefile +41 -0
  86. data/bundle/ruby/2.7.0/gems/rake-13.0.3/bin/bundle +105 -0
  87. data/bundle/ruby/2.7.0/gems/rake-13.0.3/bin/console +7 -0
  88. data/bundle/ruby/2.7.0/gems/rake-13.0.3/bin/rake +29 -0
  89. data/bundle/ruby/2.7.0/gems/rake-13.0.3/bin/rdoc +29 -0
  90. data/bundle/ruby/2.7.0/gems/rake-13.0.3/bin/rubocop +29 -0
  91. data/bundle/ruby/2.7.0/gems/rake-13.0.3/bin/setup +6 -0
  92. data/bundle/ruby/2.7.0/gems/rake-13.0.3/doc/command_line_usage.rdoc +158 -0
  93. data/bundle/ruby/2.7.0/gems/rake-13.0.3/doc/example/Rakefile1 +38 -0
  94. data/bundle/ruby/2.7.0/gems/rake-13.0.3/doc/example/Rakefile2 +35 -0
  95. data/bundle/ruby/2.7.0/gems/rake-13.0.3/doc/example/a.c +6 -0
  96. data/bundle/ruby/2.7.0/gems/rake-13.0.3/doc/example/b.c +6 -0
  97. data/bundle/ruby/2.7.0/gems/rake-13.0.3/doc/example/main.c +11 -0
  98. data/bundle/ruby/2.7.0/gems/rake-13.0.3/doc/glossary.rdoc +42 -0
  99. data/bundle/ruby/2.7.0/gems/rake-13.0.3/doc/jamis.rb +592 -0
  100. data/bundle/ruby/2.7.0/gems/rake-13.0.3/doc/proto_rake.rdoc +127 -0
  101. data/bundle/ruby/2.7.0/gems/rake-13.0.3/doc/rake.1 +156 -0
  102. data/bundle/ruby/2.7.0/gems/rake-13.0.3/doc/rakefile.rdoc +622 -0
  103. data/bundle/ruby/2.7.0/gems/rake-13.0.3/doc/rational.rdoc +151 -0
  104. data/bundle/ruby/2.7.0/gems/rake-13.0.3/exe/rake +27 -0
  105. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/application.rb +824 -0
  106. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/backtrace.rb +24 -0
  107. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/clean.rb +78 -0
  108. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/cloneable.rb +17 -0
  109. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/cpu_counter.rb +107 -0
  110. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/default_loader.rb +15 -0
  111. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/dsl_definition.rb +195 -0
  112. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/early_time.rb +22 -0
  113. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/ext/core.rb +26 -0
  114. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/ext/string.rb +176 -0
  115. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/file_creation_task.rb +25 -0
  116. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/file_list.rb +435 -0
  117. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/file_task.rb +54 -0
  118. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/file_utils.rb +134 -0
  119. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/file_utils_ext.rb +134 -0
  120. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/invocation_chain.rb +57 -0
  121. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/invocation_exception_mixin.rb +17 -0
  122. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/late_time.rb +18 -0
  123. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/linked_list.rb +112 -0
  124. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/loaders/makefile.rb +54 -0
  125. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/multi_task.rb +14 -0
  126. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/name_space.rb +38 -0
  127. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/packagetask.rb +222 -0
  128. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/phony.rb +16 -0
  129. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/private_reader.rb +21 -0
  130. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/promise.rb +100 -0
  131. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/pseudo_status.rb +30 -0
  132. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/rake_module.rb +67 -0
  133. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/rake_test_loader.rb +27 -0
  134. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/rule_recursion_overflow_error.rb +20 -0
  135. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/scope.rb +43 -0
  136. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/task.rb +434 -0
  137. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/task_argument_error.rb +8 -0
  138. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/task_arguments.rb +109 -0
  139. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/task_manager.rb +331 -0
  140. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/tasklib.rb +12 -0
  141. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/testtask.rb +189 -0
  142. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/thread_history_display.rb +49 -0
  143. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/thread_pool.rb +163 -0
  144. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/trace_output.rb +23 -0
  145. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/version.rb +10 -0
  146. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake/win32.rb +51 -0
  147. data/bundle/ruby/2.7.0/gems/rake-13.0.3/lib/rake.rb +71 -0
  148. data/bundle/ruby/2.7.0/gems/rake-13.0.3/rake.gemspec +43 -0
  149. data/bundle/ruby/2.7.0/gems/rspec-3.12.0/LICENSE.md +27 -0
  150. data/bundle/ruby/2.7.0/gems/rspec-3.12.0/README.md +47 -0
  151. data/bundle/ruby/2.7.0/gems/rspec-3.12.0/lib/rspec/version.rb +5 -0
  152. data/bundle/ruby/2.7.0/gems/rspec-3.12.0/lib/rspec.rb +3 -0
  153. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/.document +5 -0
  154. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/.yardopts +8 -0
  155. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/Changelog.md +2360 -0
  156. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/LICENSE.md +26 -0
  157. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/README.md +384 -0
  158. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/exe/rspec +4 -0
  159. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/autorun.rb +3 -0
  160. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/backtrace_formatter.rb +65 -0
  161. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/bisect/coordinator.rb +62 -0
  162. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/bisect/example_minimizer.rb +173 -0
  163. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/bisect/fork_runner.rb +138 -0
  164. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/bisect/server.rb +61 -0
  165. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/bisect/shell_command.rb +126 -0
  166. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/bisect/shell_runner.rb +73 -0
  167. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/bisect/utilities.rb +69 -0
  168. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/configuration.rb +2385 -0
  169. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/configuration_options.rb +233 -0
  170. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/did_you_mean.rb +46 -0
  171. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/drb.rb +120 -0
  172. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/dsl.rb +98 -0
  173. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/example.rb +666 -0
  174. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/example_group.rb +905 -0
  175. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/example_status_persister.rb +235 -0
  176. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/filter_manager.rb +231 -0
  177. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/flat_map.rb +20 -0
  178. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/base_bisect_formatter.rb +45 -0
  179. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/base_formatter.rb +70 -0
  180. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/base_text_formatter.rb +75 -0
  181. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/bisect_drb_formatter.rb +29 -0
  182. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/bisect_progress_formatter.rb +157 -0
  183. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/console_codes.rb +76 -0
  184. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/deprecation_formatter.rb +223 -0
  185. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/documentation_formatter.rb +102 -0
  186. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/exception_presenter.rb +525 -0
  187. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/failure_list_formatter.rb +23 -0
  188. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/fallback_message_formatter.rb +28 -0
  189. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/helpers.rb +118 -0
  190. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/html_formatter.rb +153 -0
  191. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/html_printer.rb +412 -0
  192. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/html_snippet_extractor.rb +120 -0
  193. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/json_formatter.rb +102 -0
  194. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/profile_formatter.rb +68 -0
  195. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/progress_formatter.rb +29 -0
  196. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/protocol.rb +182 -0
  197. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/snippet_extractor.rb +134 -0
  198. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters/syntax_highlighter.rb +91 -0
  199. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/formatters.rb +279 -0
  200. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/hooks.rb +646 -0
  201. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/invocations.rb +87 -0
  202. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/memoized_helpers.rb +580 -0
  203. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/metadata.rb +498 -0
  204. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/metadata_filter.rb +255 -0
  205. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/minitest_assertions_adapter.rb +31 -0
  206. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/mocking_adapters/flexmock.rb +31 -0
  207. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/mocking_adapters/mocha.rb +57 -0
  208. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/mocking_adapters/null.rb +14 -0
  209. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/mocking_adapters/rr.rb +31 -0
  210. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/mocking_adapters/rspec.rb +32 -0
  211. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/notifications.rb +521 -0
  212. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/option_parser.rb +323 -0
  213. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/ordering.rb +169 -0
  214. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/output_wrapper.rb +29 -0
  215. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/pending.rb +157 -0
  216. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/profiler.rb +34 -0
  217. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/project_initializer/.rspec +1 -0
  218. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/project_initializer/spec/spec_helper.rb +98 -0
  219. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/project_initializer.rb +48 -0
  220. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/rake_task.rb +188 -0
  221. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/reporter.rb +265 -0
  222. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/ruby_project.rb +53 -0
  223. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb +212 -0
  224. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/sandbox.rb +37 -0
  225. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/set.rb +54 -0
  226. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/shared_context.rb +55 -0
  227. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/shared_example_group.rb +271 -0
  228. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/shell_escape.rb +49 -0
  229. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/test_unit_assertions_adapter.rb +30 -0
  230. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/version.rb +9 -0
  231. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/warnings.rb +40 -0
  232. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core/world.rb +287 -0
  233. data/bundle/ruby/2.7.0/gems/rspec-core-3.12.0/lib/rspec/core.rb +212 -0
  234. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/.document +5 -0
  235. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/.yardopts +6 -0
  236. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/Changelog.md +1294 -0
  237. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/LICENSE.md +25 -0
  238. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/README.md +320 -0
  239. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/expectations/block_snippet_extractor.rb +253 -0
  240. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/expectations/configuration.rb +230 -0
  241. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/expectations/expectation_target.rb +163 -0
  242. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/expectations/fail_with.rb +39 -0
  243. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/expectations/failure_aggregator.rb +229 -0
  244. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/expectations/handler.rb +182 -0
  245. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/expectations/minitest_integration.rb +58 -0
  246. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/expectations/syntax.rb +132 -0
  247. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/expectations/version.rb +8 -0
  248. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/expectations.rb +82 -0
  249. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/aliased_matcher.rb +116 -0
  250. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/all.rb +86 -0
  251. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/base_matcher.rb +198 -0
  252. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/be.rb +191 -0
  253. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/be_between.rb +77 -0
  254. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/be_instance_of.rb +26 -0
  255. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/be_kind_of.rb +20 -0
  256. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/be_within.rb +72 -0
  257. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/change.rb +450 -0
  258. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/compound.rb +290 -0
  259. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/contain_exactly.rb +310 -0
  260. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/count_expectation.rb +169 -0
  261. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/cover.rb +24 -0
  262. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/eq.rb +40 -0
  263. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/eql.rb +34 -0
  264. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/equal.rb +81 -0
  265. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/exist.rb +90 -0
  266. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/has.rb +167 -0
  267. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/have_attributes.rb +114 -0
  268. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/include.rb +206 -0
  269. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/match.rb +106 -0
  270. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/operators.rb +128 -0
  271. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/output.rb +207 -0
  272. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/raise_error.rb +271 -0
  273. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/respond_to.rb +200 -0
  274. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/satisfy.rb +60 -0
  275. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/start_or_end_with.rb +94 -0
  276. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/throw_symbol.rb +138 -0
  277. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in/yield.rb +375 -0
  278. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/built_in.rb +53 -0
  279. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/composable.rb +171 -0
  280. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/dsl.rb +545 -0
  281. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/english_phrasing.rb +58 -0
  282. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/expecteds_for_multiple_diffs.rb +82 -0
  283. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/fail_matchers.rb +42 -0
  284. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/generated_descriptions.rb +41 -0
  285. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/matcher_delegator.rb +35 -0
  286. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers/matcher_protocol.rb +105 -0
  287. data/bundle/ruby/2.7.0/gems/rspec-expectations-3.12.1/lib/rspec/matchers.rb +1044 -0
  288. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/.document +5 -0
  289. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/.yardopts +6 -0
  290. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/Changelog.md +1227 -0
  291. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/LICENSE.md +25 -0
  292. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/README.md +463 -0
  293. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/any_instance/chain.rb +111 -0
  294. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/any_instance/error_generator.rb +31 -0
  295. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/any_instance/expect_chain_chain.rb +31 -0
  296. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/any_instance/expectation_chain.rb +50 -0
  297. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/any_instance/message_chains.rb +83 -0
  298. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/any_instance/proxy.rb +116 -0
  299. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/any_instance/recorder.rb +295 -0
  300. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/any_instance/stub_chain.rb +51 -0
  301. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/any_instance/stub_chain_chain.rb +23 -0
  302. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/any_instance.rb +11 -0
  303. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/argument_list_matcher.rb +115 -0
  304. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/argument_matchers.rb +322 -0
  305. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/configuration.rb +212 -0
  306. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/error_generator.rb +390 -0
  307. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/example_methods.rb +434 -0
  308. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/instance_method_stasher.rb +146 -0
  309. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/marshal_extension.rb +41 -0
  310. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/matchers/expectation_customization.rb +20 -0
  311. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/matchers/have_received.rb +134 -0
  312. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/matchers/receive.rb +133 -0
  313. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/matchers/receive_message_chain.rb +82 -0
  314. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/matchers/receive_messages.rb +77 -0
  315. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/message_chain.rb +87 -0
  316. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/message_expectation.rb +820 -0
  317. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/method_double.rb +309 -0
  318. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/method_reference.rb +214 -0
  319. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/minitest_integration.rb +68 -0
  320. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/mutate_const.rb +339 -0
  321. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/object_reference.rb +149 -0
  322. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/order_group.rb +81 -0
  323. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/proxy.rb +519 -0
  324. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/space.rb +238 -0
  325. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/standalone.rb +3 -0
  326. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/syntax.rb +325 -0
  327. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/targets.rb +124 -0
  328. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/test_double.rb +171 -0
  329. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/verifying_double.rb +121 -0
  330. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/verifying_message_expectation.rb +55 -0
  331. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/verifying_proxy.rb +220 -0
  332. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks/version.rb +9 -0
  333. data/bundle/ruby/2.7.0/gems/rspec-mocks-3.12.1/lib/rspec/mocks.rb +133 -0
  334. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/Changelog.md +364 -0
  335. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/LICENSE.md +23 -0
  336. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/README.md +40 -0
  337. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/caller_filter.rb +83 -0
  338. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/comparable_version.rb +46 -0
  339. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/differ.rb +215 -0
  340. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/directory_maker.rb +63 -0
  341. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/encoded_string.rb +161 -0
  342. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/fuzzy_matcher.rb +48 -0
  343. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/hunk_generator.rb +47 -0
  344. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/matcher_definition.rb +42 -0
  345. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/method_signature_verifier.rb +438 -0
  346. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/mutex.rb +73 -0
  347. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/object_formatter.rb +275 -0
  348. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/recursive_const_methods.rb +76 -0
  349. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/reentrant_mutex.rb +78 -0
  350. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/ruby_features.rb +198 -0
  351. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/source/location.rb +21 -0
  352. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/source/node.rb +110 -0
  353. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/source/token.rb +94 -0
  354. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/source.rb +85 -0
  355. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/spec/deprecation_helpers.rb +48 -0
  356. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/spec/diff_helpers.rb +31 -0
  357. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/spec/formatting_support.rb +9 -0
  358. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/spec/in_sub_process.rb +67 -0
  359. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/spec/library_wide_checks.rb +150 -0
  360. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/spec/shell_out.rb +105 -0
  361. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/spec/stderr_splitter.rb +75 -0
  362. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/spec/string_matcher.rb +45 -0
  363. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/spec/with_isolated_directory.rb +13 -0
  364. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/spec/with_isolated_stderr.rb +13 -0
  365. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/spec.rb +82 -0
  366. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/version.rb +7 -0
  367. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/warnings.rb +39 -0
  368. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support/with_keywords_when_needed.rb +33 -0
  369. data/bundle/ruby/2.7.0/gems/rspec-support-3.12.0/lib/rspec/support.rb +154 -0
  370. data/bundle/ruby/2.7.0/specifications/diff-lcs-1.5.0.gemspec +50 -0
  371. data/bundle/ruby/2.7.0/specifications/rake-13.0.3.gemspec +26 -0
  372. data/bundle/ruby/2.7.0/specifications/rspec-3.12.0.gemspec +39 -0
  373. data/bundle/ruby/2.7.0/specifications/rspec-core-3.12.0.gemspec +53 -0
  374. data/bundle/ruby/2.7.0/specifications/rspec-expectations-3.12.1.gemspec +44 -0
  375. data/bundle/ruby/2.7.0/specifications/rspec-mocks-3.12.1.gemspec +44 -0
  376. data/bundle/ruby/2.7.0/specifications/rspec-support-3.12.0.gemspec +36 -0
  377. data/lib/takuya/lvm_snapshot/version.rb +7 -0
  378. data/lib/takuya/lvm_snapshot.rb +111 -0
  379. data/takuya-lvm-snapshot.gemspec +34 -0
  380. metadata +424 -0
@@ -0,0 +1,2385 @@
1
+ RSpec::Support.require_rspec_core "backtrace_formatter"
2
+ RSpec::Support.require_rspec_core "ruby_project"
3
+ RSpec::Support.require_rspec_core "formatters/deprecation_formatter"
4
+ RSpec::Support.require_rspec_core "output_wrapper"
5
+
6
+ module RSpec
7
+ module Core
8
+ # rubocop:disable Metrics/ClassLength
9
+
10
+ # Stores runtime configuration information.
11
+ #
12
+ # Configuration options are loaded from multiple files and joined together
13
+ # with command-line switches and the `SPEC_OPTS` environment variable.
14
+ #
15
+ # Precedence order (where later entries overwrite earlier entries on
16
+ # conflicts):
17
+ #
18
+ # * Global (`$XDG_CONFIG_HOME/rspec/options`, or `~/.rspec` if it does
19
+ # not exist)
20
+ # * Project-specific (`./.rspec`)
21
+ # * Local (`./.rspec-local`)
22
+ # * Command-line options
23
+ # * `SPEC_OPTS`
24
+ #
25
+ # For example, an option set in the local file will override an option set
26
+ # in your global file.
27
+ #
28
+ # The global, project-specific and local files can all be overridden with a
29
+ # separate custom file using the --options command-line parameter.
30
+ #
31
+ # @example Standard settings
32
+ # RSpec.configure do |c|
33
+ # c.drb = true
34
+ # c.drb_port = 1234
35
+ # c.default_path = 'behavior'
36
+ # end
37
+ #
38
+ # @example Hooks
39
+ # RSpec.configure do |c|
40
+ # c.before(:suite) { establish_connection }
41
+ # c.before(:example) { log_in_as :authorized }
42
+ # c.around(:example) { |ex| Database.transaction(&ex) }
43
+ # end
44
+ #
45
+ # @see RSpec.configure
46
+ # @see Hooks
47
+ class Configuration
48
+ include RSpec::Core::Hooks
49
+
50
+ # Module that holds `attr_reader` declarations. It's in a separate
51
+ # module to allow us to override those methods and use `super`.
52
+ # @private
53
+ Readers = Module.new
54
+ include Readers
55
+
56
+ # @private
57
+ class MustBeConfiguredBeforeExampleGroupsError < StandardError; end
58
+
59
+ # @private
60
+ def self.define_reader(name)
61
+ Readers.class_eval do
62
+ remove_method name if method_defined?(name)
63
+ attr_reader name
64
+ end
65
+
66
+ define_method(name) { value_for(name) { super() } }
67
+ end
68
+
69
+ # @private
70
+ def self.define_alias(name, alias_name)
71
+ alias_method alias_name, name
72
+ alias_method "#{alias_name}=", "#{name}="
73
+ define_predicate alias_name
74
+ end
75
+
76
+ # @private
77
+ def self.define_predicate(name)
78
+ define_method "#{name}?" do
79
+ !!send(name)
80
+ end
81
+ end
82
+
83
+ # @private
84
+ #
85
+ # Invoked by the `add_setting` instance method. Use that method on a
86
+ # `Configuration` instance rather than this class method.
87
+ def self.add_setting(name, opts={})
88
+ raise "Use the instance add_setting method if you want to set a default" if opts.key?(:default)
89
+ attr_writer name
90
+ add_read_only_setting name
91
+
92
+ Array(opts[:alias_with]).each do |alias_name|
93
+ define_alias(name, alias_name)
94
+ end
95
+ end
96
+
97
+ # @private
98
+ #
99
+ # As `add_setting` but only add the reader.
100
+ def self.add_read_only_setting(name, opts={})
101
+ raise "Use the instance add_setting method if you want to set a default" if opts.key?(:default)
102
+ define_reader name
103
+ define_predicate name
104
+ end
105
+
106
+ # @macro [attach] add_setting
107
+ # @!attribute [rw] $1
108
+ #
109
+ # @macro [attach] define_reader
110
+ # @!attribute [r] $1
111
+
112
+ # @macro add_setting
113
+ # Path to use if no path is provided to the `rspec` command (default:
114
+ # `"spec"`). Allows you to just type `rspec` instead of `rspec spec` to
115
+ # run all the examples in the `spec` directory.
116
+ #
117
+ # @note Other scripts invoking `rspec` indirectly will ignore this
118
+ # setting.
119
+ # @return [String]
120
+ add_read_only_setting :default_path
121
+ def default_path=(path)
122
+ project_source_dirs << path
123
+ @default_path = path
124
+ end
125
+
126
+ # @macro add_setting
127
+ # Run examples over DRb (default: `false`). RSpec doesn't supply the DRb
128
+ # server, but you can use tools like spork.
129
+ # @return [Boolean]
130
+ add_setting :drb
131
+
132
+ # @macro add_setting
133
+ # The drb_port (default: nil).
134
+ add_setting :drb_port
135
+
136
+ # @macro add_setting
137
+ # Default: `$stderr`.
138
+ add_setting :error_stream
139
+
140
+ # Indicates if the DSL has been exposed off of modules and `main`.
141
+ # Default: true
142
+ # @return [Boolean]
143
+ def expose_dsl_globally?
144
+ Core::DSL.exposed_globally?
145
+ end
146
+
147
+ # Use this to expose the core RSpec DSL via `Module` and the `main`
148
+ # object. It will be set automatically but you can override it to
149
+ # remove the DSL.
150
+ # Default: true
151
+ def expose_dsl_globally=(value)
152
+ if value
153
+ Core::DSL.expose_globally!
154
+ Core::SharedExampleGroup::TopLevelDSL.expose_globally!
155
+ else
156
+ Core::DSL.remove_globally!
157
+ Core::SharedExampleGroup::TopLevelDSL.remove_globally!
158
+ end
159
+ end
160
+
161
+ # Determines where deprecation warnings are printed.
162
+ # Defaults to `$stderr`.
163
+ # @return [IO, String] IO or filename to write to
164
+ define_reader :deprecation_stream
165
+
166
+ # Determines where deprecation warnings are printed.
167
+ # @param value [IO, String] IO to write to or filename to write to
168
+ def deprecation_stream=(value)
169
+ if @reporter && !value.equal?(@deprecation_stream)
170
+ warn "RSpec's reporter has already been initialized with " \
171
+ "#{deprecation_stream.inspect} as the deprecation stream, so your change to "\
172
+ "`deprecation_stream` will be ignored. You should configure it earlier for " \
173
+ "it to take effect, or use the `--deprecation-out` CLI option. " \
174
+ "(Called from #{CallerFilter.first_non_rspec_line})"
175
+ else
176
+ @deprecation_stream = value
177
+ end
178
+ end
179
+
180
+ # @macro define_reader
181
+ # The file path to use for persisting example statuses. Necessary for the
182
+ # `--only-failures` and `--next-failure` CLI options.
183
+ #
184
+ # @overload example_status_persistence_file_path
185
+ # @return [String] the file path
186
+ # @overload example_status_persistence_file_path=(value)
187
+ # @param value [String] the file path
188
+ define_reader :example_status_persistence_file_path
189
+
190
+ # Sets the file path to use for persisting example statuses. Necessary for the
191
+ # `--only-failures` and `--next-failure` CLI options.
192
+ def example_status_persistence_file_path=(value)
193
+ @example_status_persistence_file_path = value
194
+ clear_values_derived_from_example_status_persistence_file_path
195
+ end
196
+
197
+ # @macro define_reader
198
+ # Indicates if the `--only-failures` (or `--next-failure`) flag is being used.
199
+ define_reader :only_failures
200
+ alias_method :only_failures?, :only_failures
201
+
202
+ # @private
203
+ def only_failures_but_not_configured?
204
+ only_failures? && !example_status_persistence_file_path
205
+ end
206
+
207
+ # @macro define_reader
208
+ # If specified, indicates the number of failures required before cleaning
209
+ # up and exit (default: `nil`). Can also be `true` to fail and exit on first
210
+ # failure
211
+ define_reader :fail_fast
212
+
213
+ # @see fail_fast
214
+ def fail_fast=(value)
215
+ case value
216
+ when true, 'true'
217
+ @fail_fast = true
218
+ when false, 'false', 0
219
+ @fail_fast = false
220
+ when nil
221
+ @fail_fast = nil
222
+ else
223
+ @fail_fast = value.to_i
224
+
225
+ if value.to_i == 0
226
+ # TODO: in RSpec 4, consider raising an error here.
227
+ RSpec.warning "Cannot set `RSpec.configuration.fail_fast`" \
228
+ " to `#{value.inspect}`. Only `true`, `false`, `nil` and integers" \
229
+ " are valid values."
230
+ @fail_fast = true
231
+ end
232
+ end
233
+ end
234
+
235
+ # @macro add_setting
236
+ # Prints the formatter output of your suite without running any
237
+ # examples or hooks.
238
+ add_setting :dry_run
239
+
240
+ # @macro add_setting
241
+ # The exit code to return if there are any failures (default: 1).
242
+ # @return [Integer]
243
+ add_setting :failure_exit_code
244
+
245
+ # @macro add_setting
246
+ # The exit code to return if there are any errors outside examples (default: failure_exit_code)
247
+ # @return [Integer]
248
+ add_setting :error_exit_code
249
+
250
+ # @macro add_setting
251
+ # Whether or not to fail when there are no RSpec examples (default: false).
252
+ # @return [Boolean]
253
+ add_setting :fail_if_no_examples
254
+
255
+ # @macro define_reader
256
+ # Indicates files configured to be required.
257
+ # @return [Array<String>]
258
+ define_reader :requires
259
+
260
+ # @macro define_reader
261
+ # Returns dirs that have been prepended to the load path by the `-I`
262
+ # command line option.
263
+ # @return [Array<String>]
264
+ define_reader :libs
265
+
266
+ # @macro add_setting
267
+ # Determines where RSpec will send its output.
268
+ # Default: `$stdout`.
269
+ # @return [IO, String]
270
+ define_reader :output_stream
271
+
272
+ # Set the output stream for reporter.
273
+ # @attr value [IO, String] IO to write to or filename to write to, defaults to $stdout
274
+ def output_stream=(value)
275
+ if @reporter && !value.equal?(@output_stream)
276
+ warn "RSpec's reporter has already been initialized with " \
277
+ "#{output_stream.inspect} as the output stream, so your change to "\
278
+ "`output_stream` will be ignored. You should configure it earlier for " \
279
+ "it to take effect. (Called from #{CallerFilter.first_non_rspec_line})"
280
+ else
281
+ @output_stream = value
282
+ output_wrapper.output = @output_stream
283
+ end
284
+ end
285
+
286
+ # @macro define_reader
287
+ # Load files matching this pattern (default: `'**{,/*/**}/*_spec.rb'`).
288
+ # @return [String]
289
+ define_reader :pattern
290
+
291
+ # Set pattern to match files to load.
292
+ # @attr value [String] the filename pattern to filter spec files by
293
+ def pattern=(value)
294
+ update_pattern_attr :pattern, value
295
+ end
296
+
297
+ # @macro define_reader
298
+ # Exclude files matching this pattern.
299
+ # @return [String]
300
+ define_reader :exclude_pattern
301
+
302
+ # Set pattern to match files to exclude.
303
+ # @attr value [String] the filename pattern to exclude spec files by
304
+ def exclude_pattern=(value)
305
+ update_pattern_attr :exclude_pattern, value
306
+ end
307
+
308
+ # @macro add_setting
309
+ # Specifies which directories contain the source code for your project.
310
+ # When a failure occurs, RSpec looks through the backtrace to find a
311
+ # a line of source to print. It first looks for a line coming from
312
+ # one of the project source directories so that, for example, it prints
313
+ # the expectation or assertion call rather than the source code from
314
+ # the expectation or assertion framework.
315
+ # @return [Array<String>]
316
+ add_setting :project_source_dirs
317
+
318
+ # @macro add_setting
319
+ # Report the times for the slowest examples (default: `false`).
320
+ # Use this to specify the number of examples to include in the profile.
321
+ # @return [Boolean]
322
+ attr_writer :profile_examples
323
+ define_predicate :profile_examples
324
+
325
+ # @macro add_setting
326
+ # Run all examples if none match the configured filters
327
+ # (default: `false`).
328
+ # @deprecated Use {#filter_run_when_matching} instead for the specific
329
+ # filters that you want to be ignored if none match.
330
+ add_setting :run_all_when_everything_filtered
331
+
332
+ # @macro add_setting
333
+ # Color to use to indicate success. Defaults to `:green` but can be set
334
+ # to one of the following: `[:black, :white, :red, :green, :yellow,
335
+ # :blue, :magenta, :cyan]`
336
+ # @return [Symbol]
337
+ add_setting :success_color
338
+
339
+ # @macro add_setting
340
+ # Color to use to print pending examples. Defaults to `:yellow` but can
341
+ # be set to one of the following: `[:black, :white, :red, :green,
342
+ # :yellow, :blue, :magenta, :cyan]`
343
+ # @return [Symbol]
344
+ add_setting :pending_color
345
+
346
+ # @macro add_setting
347
+ # Color to use to indicate failure. Defaults to `:red` but can be set to
348
+ # one of the following: `[:black, :white, :red, :green, :yellow, :blue,
349
+ # :magenta, :cyan]`
350
+ # @return [Symbol]
351
+ add_setting :failure_color
352
+
353
+ # @macro add_setting
354
+ # The default output color. Defaults to `:white` but can be set to one of
355
+ # the following: `[:black, :white, :red, :green, :yellow, :blue,
356
+ # :magenta, :cyan]`
357
+ # @return [Symbol]
358
+ add_setting :default_color
359
+
360
+ # @macro add_setting
361
+ # Color used when a pending example is fixed. Defaults to `:blue` but can
362
+ # be set to one of the following: `[:black, :white, :red, :green,
363
+ # :yellow, :blue, :magenta, :cyan]`
364
+ # @return [Symbol]
365
+ add_setting :fixed_color
366
+
367
+ # @macro add_setting
368
+ # Color used to print details. Defaults to `:cyan` but can be set to one
369
+ # of the following: `[:black, :white, :red, :green, :yellow, :blue,
370
+ # :magenta, :cyan]`
371
+ # @return [Symbol]
372
+ add_setting :detail_color
373
+
374
+ # @macro add_setting
375
+ # Don't print filter info i.e. "Run options: include {:focus=>true}"
376
+ # (default `false`).
377
+ # return [Boolean]
378
+ add_setting :silence_filter_announcements
379
+
380
+ # @deprecated This config option was added in RSpec 2 to pave the way
381
+ # for this being the default behavior in RSpec 3. Now this option is
382
+ # a no-op.
383
+ def treat_symbols_as_metadata_keys_with_true_values=(_value)
384
+ RSpec.deprecate(
385
+ "RSpec::Core::Configuration#treat_symbols_as_metadata_keys_with_true_values=",
386
+ :message => "RSpec::Core::Configuration#treat_symbols_as_metadata_keys_with_true_values= " \
387
+ "is deprecated, it is now set to true as default and " \
388
+ "setting it to false has no effect."
389
+ )
390
+ end
391
+
392
+ # @macro define_reader
393
+ # Configures how RSpec treats metadata passed as part of a shared example
394
+ # group definition. For example, given this shared example group definition:
395
+ #
396
+ # RSpec.shared_context "uses DB", :db => true do
397
+ # around(:example) do |ex|
398
+ # MyORM.transaction(:rollback => true, &ex)
399
+ # end
400
+ # end
401
+ #
402
+ # ...there are two ways RSpec can treat the `:db => true` metadata, each
403
+ # of which has a corresponding config option:
404
+ #
405
+ # 1. `:trigger_inclusion`: this shared context will be implicitly included
406
+ # in any groups (or examples) that have `:db => true` metadata.
407
+ # 2. `:apply_to_host_groups`: the metadata will be inherited by the metadata
408
+ # hash of all host groups and examples.
409
+ #
410
+ # `:trigger_inclusion` is the legacy behavior from before RSpec 3.5 but should
411
+ # be considered deprecated. Instead, you can explicitly include a group with
412
+ # `include_context`:
413
+ #
414
+ # RSpec.describe "My model" do
415
+ # include_context "uses DB"
416
+ # end
417
+ #
418
+ # ...or you can configure RSpec to include the context based on matching metadata
419
+ # using an API that mirrors configured module inclusion:
420
+ #
421
+ # RSpec.configure do |rspec|
422
+ # rspec.include_context "uses DB", :db => true
423
+ # end
424
+ #
425
+ # `:apply_to_host_groups` is a new feature of RSpec 3.5 and will be the only
426
+ # supported behavior in RSpec 4.
427
+ #
428
+ # @overload shared_context_metadata_behavior
429
+ # @return [:trigger_inclusion, :apply_to_host_groups] the configured behavior
430
+ # @overload shared_context_metadata_behavior=(value)
431
+ # @param value [:trigger_inclusion, :apply_to_host_groups] sets the configured behavior
432
+ define_reader :shared_context_metadata_behavior
433
+ # @see shared_context_metadata_behavior
434
+ def shared_context_metadata_behavior=(value)
435
+ case value
436
+ when :trigger_inclusion, :apply_to_host_groups
437
+ @shared_context_metadata_behavior = value
438
+ else
439
+ raise ArgumentError, "Cannot set `RSpec.configuration." \
440
+ "shared_context_metadata_behavior` to `#{value.inspect}`. Only " \
441
+ "`:trigger_inclusion` and `:apply_to_host_groups` are valid values."
442
+ end
443
+ end
444
+
445
+ # Record the start time of the spec suite to measure load time.
446
+ # return [Time]
447
+ add_setting :start_time
448
+
449
+ # @macro add_setting
450
+ # Use threadsafe options where available.
451
+ # Currently this will place a mutex around memoized values such as let blocks.
452
+ # return [Boolean]
453
+ add_setting :threadsafe
454
+
455
+ # @macro add_setting
456
+ # Maximum count of failed source lines to display in the failure reports.
457
+ # (default `10`).
458
+ # return [Integer]
459
+ add_setting :max_displayed_failure_line_count
460
+
461
+ # Determines which bisect runner implementation gets used to run subsets
462
+ # of the suite during a bisection. Your choices are:
463
+ #
464
+ # - `:shell`: Performs a spec run by shelling out, booting RSpec and your
465
+ # application environment each time. This runner is the most widely
466
+ # compatible runner, but is not as fast. On platforms that do not
467
+ # support forking, this is the default.
468
+ # - `:fork`: Pre-boots RSpec and your application environment in a parent
469
+ # process, and then forks a child process for each spec run. This runner
470
+ # tends to be significantly faster than the `:shell` runner but cannot
471
+ # be used in some situations. On platforms that support forking, this
472
+ # is the default. If you use this runner, you should ensure that all
473
+ # of your one-time setup logic goes in a `before(:suite)` hook instead
474
+ # of getting run at the top-level of a file loaded by `--require`.
475
+ #
476
+ # @note This option will only be used by `--bisect` if you set it in a file
477
+ # loaded via `--require`.
478
+ #
479
+ # @return [Symbol]
480
+ attr_reader :bisect_runner
481
+ def bisect_runner=(value)
482
+ if @bisect_runner_class && value != @bisect_runner
483
+ raise "`config.bisect_runner = #{value.inspect}` can no longer take " \
484
+ "effect as the #{@bisect_runner.inspect} bisect runnner is already " \
485
+ "in use. This config setting must be set in a file loaded by a " \
486
+ "`--require` option (passed at the CLI or in a `.rspec` file) for " \
487
+ "it to have any effect."
488
+ end
489
+
490
+ @bisect_runner = value
491
+ end
492
+
493
+ # @private
494
+ # @deprecated Use {#color_mode} = :on, instead of {#color} with {#tty}
495
+ add_setting :tty
496
+ # @private
497
+ attr_writer :files_to_run
498
+ # @private
499
+ attr_accessor :filter_manager, :world
500
+ # @private
501
+ attr_accessor :static_config_filter_manager
502
+ # @private
503
+ attr_reader :backtrace_formatter, :ordering_manager, :loaded_spec_files
504
+
505
+ # rubocop:disable Metrics/AbcSize
506
+ # rubocop:disable Metrics/MethodLength
507
+
508
+ # Build an object to store runtime configuration options and set defaults
509
+ def initialize
510
+ # rubocop:disable Style/GlobalVars
511
+ @start_time = $_rspec_core_load_started_at || ::RSpec::Core::Time.now
512
+ # rubocop:enable Style/GlobalVars
513
+ @expectation_frameworks = []
514
+ @include_modules = FilterableItemRepository::QueryOptimized.new(:any?)
515
+ @extend_modules = FilterableItemRepository::QueryOptimized.new(:any?)
516
+ @prepend_modules = FilterableItemRepository::QueryOptimized.new(:any?)
517
+
518
+ @bisect_runner = RSpec::Support::RubyFeatures.fork_supported? ? :fork : :shell
519
+ @bisect_runner_class = nil
520
+
521
+ @before_suite_hooks = []
522
+ @after_suite_hooks = []
523
+
524
+ @mock_framework = nil
525
+ @files_or_directories_to_run = []
526
+ @loaded_spec_files = Set.new
527
+ @color = false
528
+ @color_mode = :automatic
529
+ @pattern = '**{,/*/**}/*_spec.rb'
530
+ @exclude_pattern = ''
531
+ @failure_exit_code = 1
532
+ @error_exit_code = nil # so it can be overridden by failure exit code
533
+ @fail_if_no_examples = false
534
+ @spec_files_loaded = false
535
+
536
+ @backtrace_formatter = BacktraceFormatter.new
537
+
538
+ @default_path = 'spec'
539
+ @project_source_dirs = %w[ spec lib app ]
540
+ @deprecation_stream = $stderr
541
+ @output_stream = $stdout
542
+ @reporter = nil
543
+ @reporter_buffer = nil
544
+ @filter_manager = FilterManager.new
545
+ @static_config_filter_manager = FilterManager.new
546
+ @ordering_manager = Ordering::ConfigurationManager.new
547
+ @preferred_options = {}
548
+ @failure_color = :red
549
+ @success_color = :green
550
+ @pending_color = :yellow
551
+ @default_color = :white
552
+ @fixed_color = :blue
553
+ @detail_color = :cyan
554
+ @profile_examples = false
555
+ @requires = []
556
+ @libs = []
557
+ @derived_metadata_blocks = FilterableItemRepository::QueryOptimized.new(:any?)
558
+ @threadsafe = true
559
+ @max_displayed_failure_line_count = 10
560
+ @world = World::Null
561
+ @shared_context_metadata_behavior = :trigger_inclusion
562
+
563
+ define_built_in_hooks
564
+ end
565
+ # rubocop:enable Metrics/AbcSize
566
+ # rubocop:enable Metrics/MethodLength
567
+
568
+ # @private
569
+ #
570
+ # Used to set higher priority option values from the command line.
571
+ def force(hash)
572
+ ordering_manager.force(hash)
573
+ @preferred_options.merge!(hash)
574
+
575
+ return unless hash.key?(:example_status_persistence_file_path)
576
+ clear_values_derived_from_example_status_persistence_file_path
577
+ end
578
+
579
+ # @private
580
+ def reset
581
+ @spec_files_loaded = false
582
+ reset_reporter
583
+ end
584
+
585
+ # @private
586
+ def reset_reporter
587
+ @reporter = nil
588
+ @formatter_loader = nil
589
+ @output_wrapper = nil
590
+ end
591
+
592
+ # @private
593
+ def reset_filters
594
+ self.filter_manager = FilterManager.new
595
+ filter_manager.include_only(
596
+ Metadata.deep_hash_dup(static_config_filter_manager.inclusions.rules)
597
+ )
598
+ filter_manager.exclude_only(
599
+ Metadata.deep_hash_dup(static_config_filter_manager.exclusions.rules)
600
+ )
601
+ end
602
+
603
+ # @overload add_setting(name)
604
+ # @overload add_setting(name, opts)
605
+ # @option opts [Symbol] :default
606
+ #
607
+ # Set a default value for the generated getter and predicate methods:
608
+ #
609
+ # add_setting(:foo, :default => "default value")
610
+ #
611
+ # @option opts [Symbol] :alias_with
612
+ #
613
+ # Use `:alias_with` to alias the setter, getter, and predicate to
614
+ # another name, or names:
615
+ #
616
+ # add_setting(:foo, :alias_with => :bar)
617
+ # add_setting(:foo, :alias_with => [:bar, :baz])
618
+ #
619
+ # Adds a custom setting to the RSpec.configuration object.
620
+ #
621
+ # RSpec.configuration.add_setting :foo
622
+ #
623
+ # Used internally and by extension frameworks like rspec-rails, so they
624
+ # can add config settings that are domain specific. For example:
625
+ #
626
+ # RSpec.configure do |c|
627
+ # c.add_setting :use_transactional_fixtures,
628
+ # :default => true,
629
+ # :alias_with => :use_transactional_examples
630
+ # end
631
+ #
632
+ # `add_setting` creates three methods on the configuration object, a
633
+ # setter, a getter, and a predicate:
634
+ #
635
+ # RSpec.configuration.foo=(value)
636
+ # RSpec.configuration.foo
637
+ # RSpec.configuration.foo? # Returns true if foo returns anything but nil or false.
638
+ def add_setting(name, opts={})
639
+ default = opts.delete(:default)
640
+ (class << self; self; end).class_exec do
641
+ add_setting(name, opts)
642
+ end
643
+ __send__("#{name}=", default) if default
644
+ end
645
+
646
+ # Returns the configured mock framework adapter module.
647
+ # @return [Symbol]
648
+ def mock_framework
649
+ if @mock_framework.nil?
650
+ begin
651
+ mock_with :rspec
652
+ rescue LoadError
653
+ mock_with :nothing
654
+ end
655
+ end
656
+ @mock_framework
657
+ end
658
+
659
+ # Delegates to mock_framework=(framework).
660
+ def mock_framework=(framework)
661
+ mock_with framework
662
+ end
663
+
664
+ # Regexps used to exclude lines from backtraces.
665
+ #
666
+ # Excludes lines from ruby (and jruby) source, installed gems, anything
667
+ # in any "bin" directory, and any of the RSpec libs (outside gem
668
+ # installs) by default.
669
+ #
670
+ # You can modify the list via the getter, or replace it with the setter.
671
+ #
672
+ # To override this behaviour and display a full backtrace, use
673
+ # `--backtrace` on the command line, in a `.rspec` file, or in the
674
+ # `rspec_options` attribute of RSpec's rake task.
675
+ # @return [Array<Regexp>]
676
+ def backtrace_exclusion_patterns
677
+ @backtrace_formatter.exclusion_patterns
678
+ end
679
+
680
+ # Set regular expressions used to exclude lines in backtrace.
681
+ # @param patterns [Array<Regexp>] set backtrace_formatter exlusion_patterns
682
+ def backtrace_exclusion_patterns=(patterns)
683
+ @backtrace_formatter.exclusion_patterns = patterns
684
+ end
685
+
686
+ # Regexps used to include lines in backtraces.
687
+ #
688
+ # Defaults to [Regexp.new Dir.getwd].
689
+ #
690
+ # Lines that match an exclusion _and_ an inclusion pattern
691
+ # will be included.
692
+ #
693
+ # You can modify the list via the getter, or replace it with the setter.
694
+ # @return [Array<Regexp>]
695
+ def backtrace_inclusion_patterns
696
+ @backtrace_formatter.inclusion_patterns
697
+ end
698
+
699
+ # Set regular expressions used to include lines in backtrace.
700
+ # @attr patterns [Array<Regexp>] set backtrace_formatter inclusion_patterns
701
+ def backtrace_inclusion_patterns=(patterns)
702
+ @backtrace_formatter.inclusion_patterns = patterns
703
+ end
704
+
705
+ # Adds {#backtrace_exclusion_patterns} that will filter lines from
706
+ # the named gems from backtraces.
707
+ #
708
+ # @param gem_names [Array<String>] Names of the gems to filter
709
+ #
710
+ # @example
711
+ # RSpec.configure do |config|
712
+ # config.filter_gems_from_backtrace "rack", "rake"
713
+ # end
714
+ #
715
+ # @note The patterns this adds will match the named gems in their common
716
+ # locations (e.g. system gems, vendored with bundler, installed as a
717
+ # :git dependency with bundler, etc) but is not guaranteed to work for
718
+ # all possible gem locations. For example, if you have the gem source
719
+ # in a directory with a completely unrelated name, and use bundler's
720
+ # :path option, this will not filter it.
721
+ def filter_gems_from_backtrace(*gem_names)
722
+ gem_names.each do |name|
723
+ @backtrace_formatter.filter_gem(name)
724
+ end
725
+ end
726
+
727
+ # @private
728
+ MOCKING_ADAPTERS = {
729
+ :rspec => :RSpec,
730
+ :flexmock => :Flexmock,
731
+ :rr => :RR,
732
+ :mocha => :Mocha,
733
+ :nothing => :Null
734
+ }
735
+
736
+ # Sets the mock framework adapter module.
737
+ #
738
+ # `framework` can be a Symbol or a Module.
739
+ #
740
+ # Given any of `:rspec`, `:mocha`, `:flexmock`, or `:rr`, configures the
741
+ # named framework.
742
+ #
743
+ # Given `:nothing`, configures no framework. Use this if you don't use
744
+ # any mocking framework to save a little bit of overhead.
745
+ #
746
+ # Given a Module, includes that module in every example group. The module
747
+ # should adhere to RSpec's mock framework adapter API:
748
+ #
749
+ # setup_mocks_for_rspec
750
+ # - called before each example
751
+ #
752
+ # verify_mocks_for_rspec
753
+ # - called after each example if the example hasn't yet failed.
754
+ # Framework should raise an exception when expectations fail
755
+ #
756
+ # teardown_mocks_for_rspec
757
+ # - called after verify_mocks_for_rspec (even if there are errors)
758
+ #
759
+ # If the module responds to `configuration` and `mock_with` receives a
760
+ # block, it will yield the configuration object to the block e.g.
761
+ #
762
+ # config.mock_with OtherMockFrameworkAdapter do |mod_config|
763
+ # mod_config.custom_setting = true
764
+ # end
765
+ def mock_with(framework)
766
+ framework_module =
767
+ if framework.is_a?(Module)
768
+ framework
769
+ else
770
+ const_name = MOCKING_ADAPTERS.fetch(framework) do
771
+ raise ArgumentError,
772
+ "Unknown mocking framework: #{framework.inspect}. " \
773
+ "Pass a module or one of #{MOCKING_ADAPTERS.keys.inspect}"
774
+ end
775
+
776
+ RSpec::Support.require_rspec_core "mocking_adapters/#{const_name.to_s.downcase}"
777
+ RSpec::Core::MockingAdapters.const_get(const_name)
778
+ end
779
+
780
+ new_name, old_name = [framework_module, @mock_framework].map do |mod|
781
+ mod.respond_to?(:framework_name) ? mod.framework_name : :unnamed
782
+ end
783
+
784
+ unless new_name == old_name
785
+ assert_no_example_groups_defined(:mock_framework)
786
+ end
787
+
788
+ if block_given?
789
+ raise "#{framework_module} must respond to `configuration` so that " \
790
+ "mock_with can yield it." unless framework_module.respond_to?(:configuration)
791
+ yield framework_module.configuration
792
+ end
793
+
794
+ @mock_framework = framework_module
795
+ end
796
+
797
+ # Returns the configured expectation framework adapter module(s)
798
+ def expectation_frameworks
799
+ if @expectation_frameworks.empty?
800
+ begin
801
+ expect_with :rspec
802
+ rescue LoadError
803
+ expect_with Module.new
804
+ end
805
+ end
806
+ @expectation_frameworks
807
+ end
808
+
809
+ # Delegates to expect_with(framework).
810
+ def expectation_framework=(framework)
811
+ expect_with(framework)
812
+ end
813
+
814
+ # Sets the expectation framework module(s) to be included in each example
815
+ # group.
816
+ #
817
+ # `frameworks` can be `:rspec`, `:test_unit`, `:minitest`, a custom
818
+ # module, or any combination thereof:
819
+ #
820
+ # config.expect_with :rspec
821
+ # config.expect_with :test_unit
822
+ # config.expect_with :minitest
823
+ # config.expect_with :rspec, :minitest
824
+ # config.expect_with OtherExpectationFramework
825
+ #
826
+ # RSpec will translate `:rspec`, `:minitest`, and `:test_unit` into the
827
+ # appropriate modules.
828
+ #
829
+ # ## Configuration
830
+ #
831
+ # If the module responds to `configuration`, `expect_with` will
832
+ # yield the `configuration` object if given a block:
833
+ #
834
+ # config.expect_with OtherExpectationFramework do |custom_config|
835
+ # custom_config.custom_setting = true
836
+ # end
837
+ def expect_with(*frameworks)
838
+ modules = frameworks.map do |framework|
839
+ case framework
840
+ when Module
841
+ framework
842
+ when :rspec
843
+ require 'rspec/expectations'
844
+
845
+ # Tag this exception class so our exception formatting logic knows
846
+ # that it satisfies the `MultipleExceptionError` interface.
847
+ ::RSpec::Expectations::MultipleExpectationsNotMetError.__send__(
848
+ :include, MultipleExceptionError::InterfaceTag
849
+ )
850
+
851
+ ::RSpec::Matchers
852
+ when :test_unit
853
+ require 'rspec/core/test_unit_assertions_adapter'
854
+ ::RSpec::Core::TestUnitAssertionsAdapter
855
+ when :minitest
856
+ require 'rspec/core/minitest_assertions_adapter'
857
+ ::RSpec::Core::MinitestAssertionsAdapter
858
+ else
859
+ raise ArgumentError, "#{framework.inspect} is not supported"
860
+ end
861
+ end
862
+
863
+ if (modules - @expectation_frameworks).any?
864
+ assert_no_example_groups_defined(:expect_with)
865
+ end
866
+
867
+ if block_given?
868
+ raise "expect_with only accepts a block with a single argument. " \
869
+ "Call expect_with #{modules.length} times, " \
870
+ "once with each argument, instead." if modules.length > 1
871
+ raise "#{modules.first} must respond to `configuration` so that " \
872
+ "expect_with can yield it." unless modules.first.respond_to?(:configuration)
873
+ yield modules.first.configuration
874
+ end
875
+
876
+ @expectation_frameworks.push(*modules)
877
+ end
878
+
879
+ # Check if full backtrace is enabled.
880
+ # @return [Boolean] is full backtrace enabled
881
+ def full_backtrace?
882
+ @backtrace_formatter.full_backtrace?
883
+ end
884
+
885
+ # Toggle full backtrace.
886
+ # @attr true_or_false [Boolean] toggle full backtrace display
887
+ def full_backtrace=(true_or_false)
888
+ @backtrace_formatter.full_backtrace = true_or_false
889
+ end
890
+
891
+ # Enables color output if the output is a TTY. As of RSpec 3.6, this is
892
+ # the default behavior and this option is retained only for backwards
893
+ # compatibility.
894
+ #
895
+ # @deprecated No longer recommended because of complex behavior. Instead,
896
+ # rely on the fact that TTYs will display color by default, or set
897
+ # {#color_mode} to :on to display color on a non-TTY output.
898
+ # @see color_mode
899
+ # @see color_enabled?
900
+ # @return [Boolean]
901
+ def color
902
+ value_for(:color) { @color }
903
+ end
904
+
905
+ # The mode for determining whether to display output in color. One of:
906
+ #
907
+ # - :automatic - the output will be in color if the output is a TTY (the
908
+ # default)
909
+ # - :on - the output will be in color, whether or not the output is a TTY
910
+ # - :off - the output will not be in color
911
+ #
912
+ # @see color_enabled?
913
+ # @return [Boolean]
914
+ def color_mode
915
+ value_for(:color_mode) { @color_mode }
916
+ end
917
+
918
+ # Check if color is enabled for a particular output.
919
+ # @param output [IO] an output stream to use, defaults to the current
920
+ # `output_stream`
921
+ # @return [Boolean]
922
+ def color_enabled?(output=output_stream)
923
+ case color_mode
924
+ when :on then true
925
+ when :off then false
926
+ else # automatic
927
+ output_to_tty?(output) || (color && tty?)
928
+ end
929
+ end
930
+
931
+ # Set the color mode.
932
+ attr_writer :color_mode
933
+
934
+ # Toggle output color.
935
+ #
936
+ # @deprecated No longer recommended because of complex behavior. Instead,
937
+ # rely on the fact that TTYs will display color by default, or set
938
+ # {:color_mode} to :on to display color on a non-TTY output.
939
+ attr_writer :color
940
+
941
+ # @private
942
+ def libs=(libs)
943
+ libs.map do |lib|
944
+ @libs.unshift lib
945
+ $LOAD_PATH.unshift lib
946
+ end
947
+ end
948
+
949
+ # Run examples matching on `description` in all files to run.
950
+ # @param description [String, Regexp] the pattern to filter on
951
+ def full_description=(description)
952
+ filter_run :full_description => Regexp.union(*Array(description).map { |d| Regexp.new(d) })
953
+ end
954
+
955
+ # @return [Array] full description filter
956
+ def full_description
957
+ filter.fetch :full_description, nil
958
+ end
959
+
960
+ # @overload add_formatter(formatter)
961
+ # @overload add_formatter(formatter, output)
962
+ #
963
+ # @param formatter [Class, String, Object] formatter to use. Can be any of the
964
+ # string values supported from the CLI (`p`/`progress`,
965
+ # `d`/`doc`/`documentation`, `h`/`html`, or `j`/`json`), any
966
+ # class that implements the formatter protocol and has registered
967
+ # itself with RSpec as a formatter, or a formatter instance.
968
+ # @param output [String, IO] where the formatter will write its output.
969
+ # Can be an IO object or a string path to a file. If not provided,
970
+ # the configured `output_stream` (`$stdout`, by default) will be used.
971
+ #
972
+ # Adds a formatter to the set RSpec will use for this run.
973
+ #
974
+ # @see RSpec::Core::Formatters::Protocol
975
+ def add_formatter(formatter, output=output_wrapper)
976
+ formatter_loader.add(formatter, output)
977
+ end
978
+ alias_method :formatter=, :add_formatter
979
+
980
+ # The formatter that will be used if no formatter has been set.
981
+ # Defaults to 'progress'.
982
+ def default_formatter
983
+ formatter_loader.default_formatter
984
+ end
985
+
986
+ # Sets a fallback formatter to use if none other has been set.
987
+ #
988
+ # @example
989
+ #
990
+ # RSpec.configure do |rspec|
991
+ # rspec.default_formatter = 'doc'
992
+ # end
993
+ def default_formatter=(value)
994
+ formatter_loader.default_formatter = value
995
+ end
996
+
997
+ # Returns a duplicate of the formatters currently loaded in
998
+ # the `FormatterLoader` for introspection.
999
+ #
1000
+ # Note as this is a duplicate, any mutations will be disregarded.
1001
+ #
1002
+ # @return [Array] the formatters currently loaded
1003
+ def formatters
1004
+ formatter_loader.formatters.dup
1005
+ end
1006
+
1007
+ # @private
1008
+ def formatter_loader
1009
+ @formatter_loader ||= Formatters::Loader.new(Reporter.new(self))
1010
+ end
1011
+
1012
+ # @private
1013
+ #
1014
+ # This buffer is used to capture all messages sent to the reporter during
1015
+ # reporter initialization. It can then replay those messages after the
1016
+ # formatter is correctly initialized. Otherwise, deprecation warnings
1017
+ # during formatter initialization can cause an infinite loop.
1018
+ class DeprecationReporterBuffer
1019
+ def initialize
1020
+ @calls = []
1021
+ end
1022
+
1023
+ def deprecation(*args)
1024
+ @calls << args
1025
+ end
1026
+
1027
+ def play_onto(reporter)
1028
+ @calls.each do |args|
1029
+ reporter.deprecation(*args)
1030
+ end
1031
+ end
1032
+ end
1033
+
1034
+ # @return [RSpec::Core::Reporter] the currently configured reporter
1035
+ def reporter
1036
+ # @reporter_buffer should only ever be set in this method to cover
1037
+ # initialization of @reporter.
1038
+ @reporter_buffer || @reporter ||=
1039
+ begin
1040
+ @reporter_buffer = DeprecationReporterBuffer.new
1041
+ formatter_loader.prepare_default output_wrapper, deprecation_stream
1042
+ @reporter_buffer.play_onto(formatter_loader.reporter)
1043
+ @reporter_buffer = nil
1044
+ formatter_loader.reporter
1045
+ end
1046
+ end
1047
+
1048
+ # @api private
1049
+ #
1050
+ # Defaults `profile_examples` to 10 examples when `@profile_examples` is
1051
+ # `true`.
1052
+ def profile_examples
1053
+ profile = value_for(:profile_examples) { @profile_examples }
1054
+ if profile && !profile.is_a?(Integer)
1055
+ 10
1056
+ else
1057
+ profile
1058
+ end
1059
+ end
1060
+
1061
+ # @private
1062
+ def files_or_directories_to_run=(*files)
1063
+ files = files.flatten
1064
+
1065
+ if (command == 'rspec' || Runner.running_in_drb?) && default_path && files.empty?
1066
+ files << default_path
1067
+ end
1068
+
1069
+ @files_or_directories_to_run = files
1070
+ @files_to_run = nil
1071
+ end
1072
+
1073
+ # The spec files RSpec will run.
1074
+ # @return [Array] specified files about to run
1075
+ def files_to_run
1076
+ @files_to_run ||= get_files_to_run(@files_or_directories_to_run)
1077
+ end
1078
+
1079
+ # @private
1080
+ def last_run_statuses
1081
+ @last_run_statuses ||= Hash.new(UNKNOWN_STATUS).tap do |statuses|
1082
+ if (path = example_status_persistence_file_path)
1083
+ begin
1084
+ ExampleStatusPersister.load_from(path).inject(statuses) do |hash, example|
1085
+ status = example[:status]
1086
+ status = UNKNOWN_STATUS unless VALID_STATUSES.include?(status)
1087
+ hash[example.fetch(:example_id)] = status
1088
+ hash
1089
+ end
1090
+ rescue SystemCallError => e
1091
+ RSpec.warning "Could not read from #{path.inspect} (configured as " \
1092
+ "`config.example_status_persistence_file_path`) due " \
1093
+ "to a system error: #{e.inspect}. Please check that " \
1094
+ "the config option is set to an accessible, valid " \
1095
+ "file path", :call_site => nil
1096
+ end
1097
+ end
1098
+ end
1099
+ end
1100
+
1101
+ # @private
1102
+ UNKNOWN_STATUS = "unknown".freeze
1103
+
1104
+ # @private
1105
+ FAILED_STATUS = "failed".freeze
1106
+
1107
+ # @private
1108
+ PASSED_STATUS = "passed".freeze
1109
+
1110
+ # @private
1111
+ PENDING_STATUS = "pending".freeze
1112
+
1113
+ # @private
1114
+ VALID_STATUSES = [UNKNOWN_STATUS, FAILED_STATUS, PASSED_STATUS, PENDING_STATUS]
1115
+
1116
+ # @private
1117
+ def spec_files_with_failures
1118
+ @spec_files_with_failures ||= last_run_statuses.inject(Set.new) do |files, (id, status)|
1119
+ files << Example.parse_id(id).first if status == FAILED_STATUS
1120
+ files
1121
+ end.to_a
1122
+ end
1123
+
1124
+ # Creates a method that delegates to `example` including the submitted
1125
+ # `args`. Used internally to add variants of `example` like `pending`:
1126
+ # @param name [String] example name alias
1127
+ # @param args [Array<Symbol>, Hash] metadata for the generated example
1128
+ #
1129
+ # @note The specific example alias below (`pending`) is already
1130
+ # defined for you.
1131
+ # @note Use with caution. This extends the language used in your
1132
+ # specs, but does not add any additional documentation. We use this
1133
+ # in RSpec to define methods like `focus` and `xit`, but we also add
1134
+ # docs for those methods.
1135
+ #
1136
+ # @example
1137
+ # RSpec.configure do |config|
1138
+ # config.alias_example_to :pending, :pending => true
1139
+ # end
1140
+ #
1141
+ # # This lets you do this:
1142
+ #
1143
+ # RSpec.describe Thing do
1144
+ # pending "does something" do
1145
+ # thing = Thing.new
1146
+ # end
1147
+ # end
1148
+ #
1149
+ # # ... which is the equivalent of
1150
+ #
1151
+ # RSpec.describe Thing do
1152
+ # it "does something", :pending => true do
1153
+ # thing = Thing.new
1154
+ # end
1155
+ # end
1156
+ def alias_example_to(name, *args)
1157
+ extra_options = Metadata.build_hash_from(args)
1158
+ RSpec::Core::ExampleGroup.define_example_method(name, extra_options)
1159
+ end
1160
+
1161
+ # Creates a method that defines an example group with the provided
1162
+ # metadata. Can be used to define example group/metadata shortcuts.
1163
+ #
1164
+ # @example
1165
+ # RSpec.configure do |config|
1166
+ # config.alias_example_group_to :describe_model, :type => :model
1167
+ # end
1168
+ #
1169
+ # shared_context_for "model tests", :type => :model do
1170
+ # # define common model test helper methods, `let` declarations, etc
1171
+ # end
1172
+ #
1173
+ # # This lets you do this:
1174
+ #
1175
+ # RSpec.describe_model User do
1176
+ # end
1177
+ #
1178
+ # # ... which is the equivalent of
1179
+ #
1180
+ # RSpec.describe User, :type => :model do
1181
+ # end
1182
+ #
1183
+ # @note The defined aliased will also be added to the top level
1184
+ # (e.g. `main` and from within modules) if
1185
+ # `expose_dsl_globally` is set to true.
1186
+ # @see #alias_example_to
1187
+ # @see #expose_dsl_globally=
1188
+ def alias_example_group_to(new_name, *args)
1189
+ extra_options = Metadata.build_hash_from(args)
1190
+ RSpec::Core::ExampleGroup.define_example_group_method(new_name, extra_options)
1191
+ end
1192
+
1193
+ # Define an alias for it_should_behave_like that allows different
1194
+ # language (like "it_has_behavior" or "it_behaves_like") to be
1195
+ # employed when including shared examples.
1196
+ #
1197
+ # @example
1198
+ # RSpec.configure do |config|
1199
+ # config.alias_it_behaves_like_to(:it_has_behavior, 'has behavior:')
1200
+ # end
1201
+ #
1202
+ # # allows the user to include a shared example group like:
1203
+ #
1204
+ # RSpec.describe Entity do
1205
+ # it_has_behavior 'sortability' do
1206
+ # let(:sortable) { Entity.new }
1207
+ # end
1208
+ # end
1209
+ #
1210
+ # # which is reported in the output as:
1211
+ # # Entity
1212
+ # # has behavior: sortability
1213
+ # # ...sortability examples here
1214
+ #
1215
+ # @note Use with caution. This extends the language used in your
1216
+ # specs, but does not add any additional documentation. We use this
1217
+ # in RSpec to define `it_should_behave_like` (for backward
1218
+ # compatibility), but we also add docs for that method.
1219
+ def alias_it_behaves_like_to(new_name, report_label='')
1220
+ RSpec::Core::ExampleGroup.define_nested_shared_group_method(new_name, report_label)
1221
+ end
1222
+ alias_method :alias_it_should_behave_like_to, :alias_it_behaves_like_to
1223
+
1224
+ # Adds key/value pairs to the `inclusion_filter`. If `args`
1225
+ # includes any symbols that are not part of the hash, each symbol
1226
+ # is treated as a key in the hash with the value `true`.
1227
+ #
1228
+ # ### Note
1229
+ #
1230
+ # Filters set using this method can be overridden from the command line
1231
+ # or config files (e.g. `.rspec`).
1232
+ #
1233
+ # @example
1234
+ # # Given this declaration.
1235
+ # describe "something", :foo => 'bar' do
1236
+ # # ...
1237
+ # end
1238
+ #
1239
+ # # Any of the following will include that group.
1240
+ # config.filter_run_including :foo => 'bar'
1241
+ # config.filter_run_including :foo => /^ba/
1242
+ # config.filter_run_including :foo => lambda {|v| v == 'bar'}
1243
+ # config.filter_run_including :foo => lambda {|v,m| m[:foo] == 'bar'}
1244
+ #
1245
+ # # Given a proc with an arity of 1, the lambda is passed the value
1246
+ # # related to the key, e.g.
1247
+ # config.filter_run_including :foo => lambda {|v| v == 'bar'}
1248
+ #
1249
+ # # Given a proc with an arity of 2, the lambda is passed the value
1250
+ # # related to the key, and the metadata itself e.g.
1251
+ # config.filter_run_including :foo => lambda {|v,m| m[:foo] == 'bar'}
1252
+ #
1253
+ # filter_run_including :foo # same as filter_run_including :foo => true
1254
+ def filter_run_including(*args)
1255
+ meta = Metadata.build_hash_from(args, :warn_about_example_group_filtering)
1256
+ filter_manager.include_with_low_priority meta
1257
+ static_config_filter_manager.include_with_low_priority Metadata.deep_hash_dup(meta)
1258
+ end
1259
+ alias_method :filter_run, :filter_run_including
1260
+
1261
+ # Applies the provided filter only if any of examples match, in constrast
1262
+ # to {#filter_run}, which always applies even if no examples match, in
1263
+ # which case no examples will be run. This allows you to leave configured
1264
+ # filters in place that are intended only for temporary use. The most common
1265
+ # example is focus filtering: `config.filter_run_when_matching :focus`.
1266
+ # With that configured, you can temporarily focus an example or group
1267
+ # by tagging it with `:focus` metadata, or prefixing it with an `f`
1268
+ # (as in `fdescribe`, `fcontext` and `fit`) since those are aliases for
1269
+ # `describe`/`context`/`it` with `:focus` metadata.
1270
+ def filter_run_when_matching(*args)
1271
+ when_first_matching_example_defined(*args) do
1272
+ filter_run(*args)
1273
+ end
1274
+ end
1275
+
1276
+ # Clears and reassigns the `inclusion_filter`. Set to `nil` if you don't
1277
+ # want any inclusion filter at all.
1278
+ #
1279
+ # ### Warning
1280
+ #
1281
+ # This overrides any inclusion filters/tags set on the command line or in
1282
+ # configuration files.
1283
+ def inclusion_filter=(filter)
1284
+ meta = Metadata.build_hash_from([filter], :warn_about_example_group_filtering)
1285
+ filter_manager.include_only meta
1286
+ end
1287
+
1288
+ alias_method :filter=, :inclusion_filter=
1289
+
1290
+ # Returns the `inclusion_filter`. If none has been set, returns an empty
1291
+ # hash.
1292
+ def inclusion_filter
1293
+ filter_manager.inclusions
1294
+ end
1295
+
1296
+ alias_method :filter, :inclusion_filter
1297
+
1298
+ # Adds key/value pairs to the `exclusion_filter`. If `args`
1299
+ # includes any symbols that are not part of the hash, each symbol
1300
+ # is treated as a key in the hash with the value `true`.
1301
+ #
1302
+ # ### Note
1303
+ #
1304
+ # Filters set using this method can be overridden from the command line
1305
+ # or config files (e.g. `.rspec`).
1306
+ #
1307
+ # @example
1308
+ # # Given this declaration.
1309
+ # describe "something", :foo => 'bar' do
1310
+ # # ...
1311
+ # end
1312
+ #
1313
+ # # Any of the following will exclude that group.
1314
+ # config.filter_run_excluding :foo => 'bar'
1315
+ # config.filter_run_excluding :foo => /^ba/
1316
+ # config.filter_run_excluding :foo => lambda {|v| v == 'bar'}
1317
+ # config.filter_run_excluding :foo => lambda {|v,m| m[:foo] == 'bar'}
1318
+ #
1319
+ # # Given a proc with an arity of 1, the lambda is passed the value
1320
+ # # related to the key, e.g.
1321
+ # config.filter_run_excluding :foo => lambda {|v| v == 'bar'}
1322
+ #
1323
+ # # Given a proc with an arity of 2, the lambda is passed the value
1324
+ # # related to the key, and the metadata itself e.g.
1325
+ # config.filter_run_excluding :foo => lambda {|v,m| m[:foo] == 'bar'}
1326
+ #
1327
+ # filter_run_excluding :foo # same as filter_run_excluding :foo => true
1328
+ def filter_run_excluding(*args)
1329
+ meta = Metadata.build_hash_from(args, :warn_about_example_group_filtering)
1330
+ filter_manager.exclude_with_low_priority meta
1331
+ static_config_filter_manager.exclude_with_low_priority Metadata.deep_hash_dup(meta)
1332
+ end
1333
+
1334
+ # Clears and reassigns the `exclusion_filter`. Set to `nil` if you don't
1335
+ # want any exclusion filter at all.
1336
+ #
1337
+ # ### Warning
1338
+ #
1339
+ # This overrides any exclusion filters/tags set on the command line or in
1340
+ # configuration files.
1341
+ def exclusion_filter=(filter)
1342
+ meta = Metadata.build_hash_from([filter], :warn_about_example_group_filtering)
1343
+ filter_manager.exclude_only meta
1344
+ end
1345
+
1346
+ # Returns the `exclusion_filter`. If none has been set, returns an empty
1347
+ # hash.
1348
+ def exclusion_filter
1349
+ filter_manager.exclusions
1350
+ end
1351
+
1352
+ # Tells RSpec to include `mod` in example groups. Methods defined in
1353
+ # `mod` are exposed to examples (not example groups). Use `filters` to
1354
+ # constrain the groups or examples in which to include the module.
1355
+ #
1356
+ # @example
1357
+ #
1358
+ # module AuthenticationHelpers
1359
+ # def login_as(user)
1360
+ # # ...
1361
+ # end
1362
+ # end
1363
+ #
1364
+ # module PreferencesHelpers
1365
+ # def preferences(user, preferences = {})
1366
+ # # ...
1367
+ # end
1368
+ # end
1369
+ #
1370
+ # module UserHelpers
1371
+ # def users(username)
1372
+ # # ...
1373
+ # end
1374
+ # end
1375
+ #
1376
+ # RSpec.configure do |config|
1377
+ # config.include(UserHelpers) # included in all groups
1378
+ #
1379
+ # # included in examples with `:preferences` metadata
1380
+ # config.include(PreferenceHelpers, :preferences)
1381
+ #
1382
+ # # included in examples with `:type => :request` metadata
1383
+ # config.include(AuthenticationHelpers, :type => :request)
1384
+ # end
1385
+ #
1386
+ # describe "edit profile", :preferences, :type => :request do
1387
+ # it "can be viewed by owning user" do
1388
+ # login_as preferences(users(:jdoe), :lang => 'es')
1389
+ # get "/profiles/jdoe"
1390
+ # assert_select ".username", :text => 'jdoe'
1391
+ # end
1392
+ # end
1393
+ #
1394
+ # @note Filtered module inclusions can also be applied to
1395
+ # individual examples that have matching metadata. Just like
1396
+ # Ruby's object model is that every object has a singleton class
1397
+ # which has only a single instance, RSpec's model is that every
1398
+ # example has a singleton example group containing just the one
1399
+ # example.
1400
+ #
1401
+ # @see #include_context
1402
+ # @see #extend
1403
+ # @see #prepend
1404
+ def include(mod, *filters)
1405
+ define_mixed_in_module(mod, filters, @include_modules, :include) do |group|
1406
+ safe_include(mod, group)
1407
+ end
1408
+ end
1409
+
1410
+ # Tells RSpec to include the named shared example group in example groups.
1411
+ # Use `filters` to constrain the groups or examples in which to include
1412
+ # the example group.
1413
+ #
1414
+ # @example
1415
+ #
1416
+ # RSpec.shared_context "example admin user" do
1417
+ # let(:admin_user) { create_user(:admin) }
1418
+ # end
1419
+ #
1420
+ # RSpec.shared_context "example guest user" do
1421
+ # let(:guest_user) { create_user(:guest) }
1422
+ # end
1423
+ #
1424
+ # RSpec.configure do |config|
1425
+ # config.include_context "example guest user", :type => :request
1426
+ # config.include_context "example admin user", :admin, :type => :request
1427
+ # end
1428
+ #
1429
+ # RSpec.describe "The admin page", :type => :request do
1430
+ # it "can be viewed by admins", :admin do
1431
+ # login_with admin_user
1432
+ # get "/admin"
1433
+ # expect(response).to be_ok
1434
+ # end
1435
+ #
1436
+ # it "cannot be viewed by guests" do
1437
+ # login_with guest_user
1438
+ # get "/admin"
1439
+ # expect(response).to be_forbidden
1440
+ # end
1441
+ # end
1442
+ #
1443
+ # @note Filtered context inclusions can also be applied to
1444
+ # individual examples that have matching metadata. Just like
1445
+ # Ruby's object model is that every object has a singleton class
1446
+ # which has only a single instance, RSpec's model is that every
1447
+ # example has a singleton example group containing just the one
1448
+ # example.
1449
+ #
1450
+ # @see #include
1451
+ def include_context(shared_group_name, *filters)
1452
+ shared_module = world.shared_example_group_registry.find([:main], shared_group_name)
1453
+ include shared_module, *filters
1454
+ end
1455
+
1456
+ # Tells RSpec to extend example groups with `mod`. Methods defined in
1457
+ # `mod` are exposed to example groups (not examples). Use `filters` to
1458
+ # constrain the groups to extend.
1459
+ #
1460
+ # Similar to `include`, but behavior is added to example groups, which
1461
+ # are classes, rather than the examples, which are instances of those
1462
+ # classes.
1463
+ #
1464
+ # @example
1465
+ #
1466
+ # module UiHelpers
1467
+ # def run_in_browser
1468
+ # # ...
1469
+ # end
1470
+ # end
1471
+ #
1472
+ # module PermissionHelpers
1473
+ # def define_permissions
1474
+ # # ...
1475
+ # end
1476
+ # end
1477
+ #
1478
+ # RSpec.configure do |config|
1479
+ # config.extend(UiHelpers, :type => :request)
1480
+ # config.extend(PermissionHelpers, :with_permissions, :type => :request)
1481
+ # end
1482
+ #
1483
+ # describe "edit profile", :with_permissions, :type => :request do
1484
+ # run_in_browser
1485
+ # define_permissions
1486
+ #
1487
+ # it "does stuff in the client" do
1488
+ # # ...
1489
+ # end
1490
+ # end
1491
+ #
1492
+ # @see #include
1493
+ # @see #prepend
1494
+ def extend(mod, *filters)
1495
+ define_mixed_in_module(mod, filters, @extend_modules, :extend) do |group|
1496
+ safe_extend(mod, group)
1497
+ end
1498
+ end
1499
+
1500
+ if RSpec::Support::RubyFeatures.module_prepends_supported?
1501
+ # Tells RSpec to prepend example groups with `mod`. Methods defined in
1502
+ # `mod` are exposed to examples (not example groups). Use `filters` to
1503
+ # constrain the groups in which to prepend the module.
1504
+ #
1505
+ # Similar to `include`, but module is included before the example group's class
1506
+ # in the ancestor chain.
1507
+ #
1508
+ # @example
1509
+ #
1510
+ # module OverrideMod
1511
+ # def override_me
1512
+ # "overridden"
1513
+ # end
1514
+ # end
1515
+ #
1516
+ # RSpec.configure do |config|
1517
+ # config.prepend(OverrideMod, :method => :prepend)
1518
+ # end
1519
+ #
1520
+ # describe "overriding example's class", :method => :prepend do
1521
+ # it "finds the user" do
1522
+ # self.class.class_eval do
1523
+ # def override_me
1524
+ # end
1525
+ # end
1526
+ # override_me # => "overridden"
1527
+ # # ...
1528
+ # end
1529
+ # end
1530
+ #
1531
+ # @see #include
1532
+ # @see #extend
1533
+ def prepend(mod, *filters)
1534
+ define_mixed_in_module(mod, filters, @prepend_modules, :prepend) do |group|
1535
+ safe_prepend(mod, group)
1536
+ end
1537
+ end
1538
+ end
1539
+
1540
+ # @private
1541
+ #
1542
+ # Used internally to extend a group with modules using `include`, `prepend` and/or
1543
+ # `extend`.
1544
+ def configure_group(group)
1545
+ group.hooks.register_globals(group, hooks)
1546
+
1547
+ configure_group_with group, @include_modules, :safe_include
1548
+ configure_group_with group, @extend_modules, :safe_extend
1549
+ configure_group_with group, @prepend_modules, :safe_prepend
1550
+ end
1551
+
1552
+ # @private
1553
+ #
1554
+ # Used internally to extend the singleton class of a single example's
1555
+ # example group instance with modules using `include` and/or `extend`.
1556
+ def configure_example(example, example_hooks)
1557
+ example_hooks.register_global_singleton_context_hooks(example, hooks)
1558
+ singleton_group = example.example_group_instance.singleton_class
1559
+
1560
+ # We replace the metadata so that SharedExampleGroupModule#included
1561
+ # has access to the example's metadata[:location].
1562
+ singleton_group.with_replaced_metadata(example.metadata) do
1563
+ modules = @include_modules.items_for(example.metadata)
1564
+ modules.each do |mod|
1565
+ safe_include(mod, example.example_group_instance.singleton_class)
1566
+ end
1567
+
1568
+ MemoizedHelpers.define_helpers_on(singleton_group) unless modules.empty?
1569
+ end
1570
+ end
1571
+
1572
+ # @private
1573
+ def requires=(paths)
1574
+ directories = ['lib', default_path].select { |p| File.directory? p }
1575
+ RSpec::Core::RubyProject.add_to_load_path(*directories)
1576
+ paths.each { |path| load_file_handling_errors(:require, path) }
1577
+ @requires += paths
1578
+ end
1579
+
1580
+ # @private
1581
+ def in_project_source_dir_regex
1582
+ regexes = project_source_dirs.map do |dir|
1583
+ /\A#{Regexp.escape(File.expand_path(dir))}\//
1584
+ end
1585
+
1586
+ Regexp.union(regexes)
1587
+ end
1588
+
1589
+ # @private
1590
+ def configure_mock_framework
1591
+ RSpec::Core::ExampleGroup.__send__(:include, mock_framework)
1592
+ conditionally_disable_mocks_monkey_patching
1593
+ end
1594
+
1595
+ # @private
1596
+ def configure_expectation_framework
1597
+ expectation_frameworks.each do |framework|
1598
+ RSpec::Core::ExampleGroup.__send__(:include, framework)
1599
+ end
1600
+ conditionally_disable_expectations_monkey_patching
1601
+ end
1602
+
1603
+ # @private
1604
+ def load_spec_files
1605
+ # Note which spec files world is already aware of.
1606
+ # This is generally only needed for when the user runs
1607
+ # `ruby path/to/spec.rb` (and loads `rspec/autorun`) --
1608
+ # in that case, the spec file was loaded by `ruby` and
1609
+ # isn't loaded by us here so we only know about it because
1610
+ # of an example group being registered in it.
1611
+ world.registered_example_group_files.each do |f|
1612
+ loaded_spec_files << f # the registered files are already expended absolute paths
1613
+ end
1614
+
1615
+ files_to_run.uniq.each do |f|
1616
+ file = File.expand_path(f)
1617
+ load_file_handling_errors(:load, file)
1618
+ loaded_spec_files << file
1619
+ end
1620
+
1621
+ @spec_files_loaded = true
1622
+ end
1623
+
1624
+ # @private
1625
+ DEFAULT_FORMATTER = lambda { |string| string }
1626
+
1627
+ # Formats the docstring output using the block provided.
1628
+ #
1629
+ # @example
1630
+ # # This will strip the descriptions of both examples and example
1631
+ # # groups.
1632
+ # RSpec.configure do |config|
1633
+ # config.format_docstrings { |s| s.strip }
1634
+ # end
1635
+ def format_docstrings(&block)
1636
+ @format_docstrings_block = block_given? ? block : DEFAULT_FORMATTER
1637
+ end
1638
+
1639
+ # @private
1640
+ def format_docstrings_block
1641
+ @format_docstrings_block ||= DEFAULT_FORMATTER
1642
+ end
1643
+
1644
+ # @private
1645
+ def self.delegate_to_ordering_manager(*methods)
1646
+ methods.each do |method|
1647
+ define_method method do |*args, &block|
1648
+ ordering_manager.__send__(method, *args, &block)
1649
+ end
1650
+ end
1651
+ end
1652
+
1653
+ # @!method seed=(value)
1654
+ #
1655
+ # Sets the seed value and sets the default global ordering to random.
1656
+ delegate_to_ordering_manager :seed=
1657
+
1658
+ # @!method seed
1659
+ # Seed for random ordering (default: generated randomly each run).
1660
+ #
1661
+ # When you run specs with `--order random`, RSpec generates a random seed
1662
+ # for the randomization and prints it to the `output_stream` (assuming
1663
+ # you're using RSpec's built-in formatters). If you discover an ordering
1664
+ # dependency (i.e. examples fail intermittently depending on order), set
1665
+ # this (on Configuration or on the command line with `--seed`) to run
1666
+ # using the same seed while you debug the issue.
1667
+ #
1668
+ # We recommend, actually, that you use the command line approach so you
1669
+ # don't accidentally leave the seed encoded.
1670
+ delegate_to_ordering_manager :seed
1671
+
1672
+ # @!method order=(value)
1673
+ #
1674
+ # Sets the default global ordering strategy. By default this can be one
1675
+ # of `:defined`, `:random`, but is customizable through the
1676
+ # `register_ordering` API. If order is set to `'rand:<seed>'`,
1677
+ # the seed will also be set.
1678
+ #
1679
+ # @see #register_ordering
1680
+ delegate_to_ordering_manager :order=
1681
+
1682
+ # @!method register_ordering(name)
1683
+ #
1684
+ # Registers a named ordering strategy that can later be
1685
+ # used to order an example group's subgroups by adding
1686
+ # `:order => <name>` metadata to the example group.
1687
+ #
1688
+ # @param name [Symbol] The name of the ordering.
1689
+ # @yield Block that will order the given examples or example groups
1690
+ # @yieldparam list [Array<RSpec::Core::Example>,
1691
+ # Array<RSpec::Core::ExampleGroup>] The examples or groups to order
1692
+ # @yieldreturn [Array<RSpec::Core::Example>,
1693
+ # Array<RSpec::Core::ExampleGroup>] The re-ordered examples or groups
1694
+ #
1695
+ # @example
1696
+ # RSpec.configure do |rspec|
1697
+ # rspec.register_ordering :reverse do |list|
1698
+ # list.reverse
1699
+ # end
1700
+ # end
1701
+ #
1702
+ # RSpec.describe 'MyClass', :order => :reverse do
1703
+ # # ...
1704
+ # end
1705
+ #
1706
+ # @note Pass the symbol `:global` to set the ordering strategy that
1707
+ # will be used to order the top-level example groups and any example
1708
+ # groups that do not have declared `:order` metadata.
1709
+ #
1710
+ # @example
1711
+ # RSpec.configure do |rspec|
1712
+ # rspec.register_ordering :global do |examples|
1713
+ # acceptance, other = examples.partition do |example|
1714
+ # example.metadata[:type] == :acceptance
1715
+ # end
1716
+ # other + acceptance
1717
+ # end
1718
+ # end
1719
+ #
1720
+ # RSpec.describe 'MyClass', :type => :acceptance do
1721
+ # # will run last
1722
+ # end
1723
+ #
1724
+ # RSpec.describe 'MyClass' do
1725
+ # # will run first
1726
+ # end
1727
+ #
1728
+ delegate_to_ordering_manager :register_ordering
1729
+
1730
+ # @private
1731
+ delegate_to_ordering_manager :seed_used?, :ordering_registry
1732
+
1733
+ # Set Ruby warnings on or off.
1734
+ def warnings=(value)
1735
+ $VERBOSE = !!value
1736
+ end
1737
+
1738
+ # @return [Boolean] Whether or not ruby warnings are enabled.
1739
+ def warnings?
1740
+ $VERBOSE
1741
+ end
1742
+
1743
+ # @private
1744
+ RAISE_ERROR_WARNING_NOTIFIER = lambda { |message| raise message }
1745
+
1746
+ # Turns warnings into errors. This can be useful when
1747
+ # you want RSpec to run in a 'strict' no warning situation.
1748
+ #
1749
+ # @example
1750
+ #
1751
+ # RSpec.configure do |rspec|
1752
+ # rspec.raise_on_warning = true
1753
+ # end
1754
+ def raise_on_warning=(value)
1755
+ if value
1756
+ RSpec::Support.warning_notifier = RAISE_ERROR_WARNING_NOTIFIER
1757
+ else
1758
+ RSpec::Support.warning_notifier = RSpec::Support::DEFAULT_WARNING_NOTIFIER
1759
+ end
1760
+ end
1761
+
1762
+ # Exposes the current running example via the named
1763
+ # helper method. RSpec 2.x exposed this via `example`,
1764
+ # but in RSpec 3.0, the example is instead exposed via
1765
+ # an arg yielded to `it`, `before`, `let`, etc. However,
1766
+ # some extension gems (such as Capybara) depend on the
1767
+ # RSpec 2.x's `example` method, so this config option
1768
+ # can be used to maintain compatibility.
1769
+ #
1770
+ # @param method_name [Symbol] the name of the helper method
1771
+ #
1772
+ # @example
1773
+ #
1774
+ # RSpec.configure do |rspec|
1775
+ # rspec.expose_current_running_example_as :example
1776
+ # end
1777
+ #
1778
+ # RSpec.describe MyClass do
1779
+ # before do
1780
+ # # `example` can be used here because of the above config.
1781
+ # do_something if example.metadata[:type] == "foo"
1782
+ # end
1783
+ # end
1784
+ def expose_current_running_example_as(method_name)
1785
+ ExposeCurrentExample.module_exec do
1786
+ extend RSpec::SharedContext
1787
+ let(method_name) { |ex| ex }
1788
+ end
1789
+
1790
+ include ExposeCurrentExample
1791
+ end
1792
+
1793
+ # @private
1794
+ module ExposeCurrentExample; end
1795
+
1796
+ # Turns deprecation warnings into errors, in order to surface
1797
+ # the full backtrace of the call site. This can be useful when
1798
+ # you need more context to address a deprecation than the
1799
+ # single-line call site normally provided.
1800
+ #
1801
+ # @example
1802
+ #
1803
+ # RSpec.configure do |rspec|
1804
+ # rspec.raise_errors_for_deprecations!
1805
+ # end
1806
+ def raise_errors_for_deprecations!
1807
+ self.deprecation_stream = Formatters::DeprecationFormatter::RaiseErrorStream.new
1808
+ end
1809
+
1810
+ # Enables zero monkey patching mode for RSpec. It removes monkey
1811
+ # patching of the top-level DSL methods (`describe`,
1812
+ # `shared_examples_for`, etc) onto `main` and `Module`, instead
1813
+ # requiring you to prefix these methods with `RSpec.`. It enables
1814
+ # expect-only syntax for rspec-mocks and rspec-expectations. It
1815
+ # simply disables monkey patching on whatever pieces of RSpec
1816
+ # the user is using.
1817
+ #
1818
+ # @note It configures rspec-mocks and rspec-expectations only
1819
+ # if the user is using those (either explicitly or implicitly
1820
+ # by not setting `mock_with` or `expect_with` to anything else).
1821
+ #
1822
+ # @note If the user uses this options with `mock_with :mocha`
1823
+ # (or similiar) they will still have monkey patching active
1824
+ # in their test environment from mocha.
1825
+ #
1826
+ # @example
1827
+ #
1828
+ # # It disables all monkey patching.
1829
+ # RSpec.configure do |config|
1830
+ # config.disable_monkey_patching!
1831
+ # end
1832
+ #
1833
+ # # Is an equivalent to
1834
+ # RSpec.configure do |config|
1835
+ # config.expose_dsl_globally = false
1836
+ #
1837
+ # config.mock_with :rspec do |mocks|
1838
+ # mocks.syntax = :expect
1839
+ # mocks.patch_marshal_to_support_partial_doubles = false
1840
+ # end
1841
+ #
1842
+ # config.expect_with :rspec do |expectations|
1843
+ # expectations.syntax = :expect
1844
+ # end
1845
+ # end
1846
+ def disable_monkey_patching!
1847
+ self.expose_dsl_globally = false
1848
+ self.disable_monkey_patching = true
1849
+ conditionally_disable_mocks_monkey_patching
1850
+ conditionally_disable_expectations_monkey_patching
1851
+ end
1852
+
1853
+ # @private
1854
+ attr_accessor :disable_monkey_patching
1855
+
1856
+ # Defines a callback that can assign derived metadata values.
1857
+ #
1858
+ # @param filters [Array<Symbol>, Hash] metadata filters that determine
1859
+ # which example or group metadata hashes the callback will be triggered
1860
+ # for. If none are given, the callback will be run against the metadata
1861
+ # hashes of all groups and examples.
1862
+ # @yieldparam metadata [Hash] original metadata hash from an example or
1863
+ # group. Mutate this in your block as needed.
1864
+ #
1865
+ # @example
1866
+ # RSpec.configure do |config|
1867
+ # # Tag all groups and examples in the spec/unit directory with
1868
+ # # :type => :unit
1869
+ # config.define_derived_metadata(:file_path => %r{/spec/unit/}) do |metadata|
1870
+ # metadata[:type] = :unit
1871
+ # end
1872
+ # end
1873
+ def define_derived_metadata(*filters, &block)
1874
+ meta = Metadata.build_hash_from(filters, :warn_about_example_group_filtering)
1875
+ @derived_metadata_blocks.append(block, meta)
1876
+ end
1877
+
1878
+ # Defines a callback that runs after the first example with matching
1879
+ # metadata is defined. If no examples are defined with matching metadata,
1880
+ # it will not get called at all.
1881
+ #
1882
+ # This can be used to ensure some setup is performed (such as bootstrapping
1883
+ # a DB or loading a specific file that adds significantly to the boot time)
1884
+ # if needed (as indicated by the presence of an example with matching metadata)
1885
+ # but avoided otherwise.
1886
+ #
1887
+ # @example
1888
+ # RSpec.configure do |config|
1889
+ # config.when_first_matching_example_defined(:db) do
1890
+ # # Load a support file that does some heavyweight setup,
1891
+ # # including bootstrapping the DB, but only if we have loaded
1892
+ # # any examples tagged with `:db`.
1893
+ # require 'support/db'
1894
+ # end
1895
+ # end
1896
+ def when_first_matching_example_defined(*filters)
1897
+ specified_meta = Metadata.build_hash_from(filters, :warn_about_example_group_filtering)
1898
+
1899
+ callback = lambda do |example_or_group_meta|
1900
+ # Example groups do not have `:example_group` metadata
1901
+ # (instead they have `:parent_example_group` metadata).
1902
+ return unless example_or_group_meta.key?(:example_group)
1903
+
1904
+ # Ensure the callback only fires once.
1905
+ @derived_metadata_blocks.delete(callback, specified_meta)
1906
+
1907
+ yield
1908
+ end
1909
+
1910
+ @derived_metadata_blocks.append(callback, specified_meta)
1911
+ end
1912
+
1913
+ # @private
1914
+ def apply_derived_metadata_to(metadata)
1915
+ already_run_blocks = Set.new
1916
+
1917
+ # We loop and attempt to re-apply metadata blocks to support cascades
1918
+ # (e.g. where a derived bit of metadata triggers the application of
1919
+ # another piece of derived metadata, etc)
1920
+ #
1921
+ # We limit our looping to 200 times as a way to detect infinitely recursing derived metadata blocks.
1922
+ # It's hard to imagine a valid use case for a derived metadata cascade greater than 200 iterations.
1923
+ 200.times do
1924
+ return if @derived_metadata_blocks.items_for(metadata).all? do |block|
1925
+ already_run_blocks.include?(block).tap do |skip_block|
1926
+ block.call(metadata) unless skip_block
1927
+ already_run_blocks << block
1928
+ end
1929
+ end
1930
+ end
1931
+
1932
+ # If we got here, then `@derived_metadata_blocks.items_for(metadata).all?` never returned
1933
+ # `true` above and we treat this as an attempt to recurse infinitely. It's better to fail
1934
+ # with a clear # error than hang indefinitely, which is what would happen if we didn't limit
1935
+ # the looping above.
1936
+ raise SystemStackError, "Attempted to recursively derive metadata indefinitely."
1937
+ end
1938
+
1939
+ # Defines a `before` hook. See {Hooks#before} for full docs.
1940
+ #
1941
+ # This method differs from {Hooks#before} in only one way: it supports
1942
+ # the `:suite` scope. Hooks with the `:suite` scope will be run once before
1943
+ # the first example of the entire suite is executed. Conditions passed along
1944
+ # with `:suite` are effectively ignored.
1945
+ #
1946
+ # @see #prepend_before
1947
+ # @see #after
1948
+ # @see #append_after
1949
+ def before(scope=nil, *meta, &block)
1950
+ handle_suite_hook(scope, meta) do
1951
+ @before_suite_hooks << Hooks::BeforeHook.new(block, {})
1952
+ end || begin
1953
+ # defeat Ruby 2.5 lazy proc allocation to ensure
1954
+ # the methods below are passed the same proc instances
1955
+ # so `Hook` equality is preserved. For more info, see:
1956
+ # https://bugs.ruby-lang.org/issues/14045#note-5
1957
+ block.__id__
1958
+
1959
+ add_hook_to_existing_matching_groups(meta, scope) { |g| g.before(scope, *meta, &block) }
1960
+ super(scope, *meta, &block)
1961
+ end
1962
+ end
1963
+ alias_method :append_before, :before
1964
+
1965
+ # Adds `block` to the start of the list of `before` blocks in the same
1966
+ # scope (`:example`, `:context`, or `:suite`), in contrast to {#before},
1967
+ # which adds the hook to the end of the list.
1968
+ #
1969
+ # See {Hooks#before} for full `before` hook docs.
1970
+ #
1971
+ # This method differs from {Hooks#prepend_before} in only one way: it supports
1972
+ # the `:suite` scope. Hooks with the `:suite` scope will be run once before
1973
+ # the first example of the entire suite is executed. Conditions passed along
1974
+ # with `:suite` are effectively ignored.
1975
+ #
1976
+ # @see #before
1977
+ # @see #after
1978
+ # @see #append_after
1979
+ def prepend_before(scope=nil, *meta, &block)
1980
+ handle_suite_hook(scope, meta) do
1981
+ @before_suite_hooks.unshift Hooks::BeforeHook.new(block, {})
1982
+ end || begin
1983
+ # defeat Ruby 2.5 lazy proc allocation to ensure
1984
+ # the methods below are passed the same proc instances
1985
+ # so `Hook` equality is preserved. For more info, see:
1986
+ # https://bugs.ruby-lang.org/issues/14045#note-5
1987
+ block.__id__
1988
+
1989
+ add_hook_to_existing_matching_groups(meta, scope) { |g| g.prepend_before(scope, *meta, &block) }
1990
+ super(scope, *meta, &block)
1991
+ end
1992
+ end
1993
+
1994
+ # Defines a `after` hook. See {Hooks#after} for full docs.
1995
+ #
1996
+ # This method differs from {Hooks#after} in only one way: it supports
1997
+ # the `:suite` scope. Hooks with the `:suite` scope will be run once after
1998
+ # the last example of the entire suite is executed. Conditions passed along
1999
+ # with `:suite` are effectively ignored.
2000
+ #
2001
+ # @see #append_after
2002
+ # @see #before
2003
+ # @see #prepend_before
2004
+ def after(scope=nil, *meta, &block)
2005
+ handle_suite_hook(scope, meta) do
2006
+ @after_suite_hooks.unshift Hooks::AfterHook.new(block, {})
2007
+ end || begin
2008
+ # defeat Ruby 2.5 lazy proc allocation to ensure
2009
+ # the methods below are passed the same proc instances
2010
+ # so `Hook` equality is preserved. For more info, see:
2011
+ # https://bugs.ruby-lang.org/issues/14045#note-5
2012
+ block.__id__
2013
+
2014
+ add_hook_to_existing_matching_groups(meta, scope) { |g| g.after(scope, *meta, &block) }
2015
+ super(scope, *meta, &block)
2016
+ end
2017
+ end
2018
+ alias_method :prepend_after, :after
2019
+
2020
+ # Adds `block` to the end of the list of `after` blocks in the same
2021
+ # scope (`:example`, `:context`, or `:suite`), in contrast to {#after},
2022
+ # which adds the hook to the start of the list.
2023
+ #
2024
+ # See {Hooks#after} for full `after` hook docs.
2025
+ #
2026
+ # This method differs from {Hooks#append_after} in only one way: it supports
2027
+ # the `:suite` scope. Hooks with the `:suite` scope will be run once after
2028
+ # the last example of the entire suite is executed. Conditions passed along
2029
+ # with `:suite` are effectively ignored.
2030
+ #
2031
+ # @see #append_after
2032
+ # @see #before
2033
+ # @see #prepend_before
2034
+ def append_after(scope=nil, *meta, &block)
2035
+ handle_suite_hook(scope, meta) do
2036
+ @after_suite_hooks << Hooks::AfterHook.new(block, {})
2037
+ end || begin
2038
+ # defeat Ruby 2.5 lazy proc allocation to ensure
2039
+ # the methods below are passed the same proc instances
2040
+ # so `Hook` equality is preserved. For more info, see:
2041
+ # https://bugs.ruby-lang.org/issues/14045#note-5
2042
+ block.__id__
2043
+
2044
+ add_hook_to_existing_matching_groups(meta, scope) { |g| g.append_after(scope, *meta, &block) }
2045
+ super(scope, *meta, &block)
2046
+ end
2047
+ end
2048
+
2049
+ # Registers `block` as an `around` hook.
2050
+ #
2051
+ # See {Hooks#around} for full `around` hook docs.
2052
+ def around(scope=nil, *meta, &block)
2053
+ # defeat Ruby 2.5 lazy proc allocation to ensure
2054
+ # the methods below are passed the same proc instances
2055
+ # so `Hook` equality is preserved. For more info, see:
2056
+ # https://bugs.ruby-lang.org/issues/14045#note-5
2057
+ block.__id__
2058
+
2059
+ add_hook_to_existing_matching_groups(meta, scope) { |g| g.around(scope, *meta, &block) }
2060
+ super(scope, *meta, &block)
2061
+ end
2062
+
2063
+ # @private
2064
+ def with_suite_hooks
2065
+ return yield if dry_run?
2066
+
2067
+ begin
2068
+ RSpec.current_scope = :before_suite_hook
2069
+ run_suite_hooks("a `before(:suite)` hook", @before_suite_hooks)
2070
+ yield
2071
+ ensure
2072
+ RSpec.current_scope = :after_suite_hook
2073
+ run_suite_hooks("an `after(:suite)` hook", @after_suite_hooks)
2074
+ RSpec.current_scope = :suite
2075
+ end
2076
+ end
2077
+
2078
+ # @private
2079
+ # Holds the various registered hooks. Here we use a FilterableItemRepository
2080
+ # implementation that is specifically optimized for the read/write patterns
2081
+ # of the config object.
2082
+ def hooks
2083
+ @hooks ||= HookCollections.new(self, FilterableItemRepository::QueryOptimized)
2084
+ end
2085
+
2086
+ # Invokes block before defining an example group
2087
+ def on_example_group_definition(&block)
2088
+ on_example_group_definition_callbacks << block
2089
+ end
2090
+
2091
+ # @api private
2092
+ # Returns an array of blocks to call before defining an example group
2093
+ def on_example_group_definition_callbacks
2094
+ @on_example_group_definition_callbacks ||= []
2095
+ end
2096
+
2097
+ # @private
2098
+ def bisect_runner_class
2099
+ @bisect_runner_class ||= begin
2100
+ case bisect_runner
2101
+ when :fork
2102
+ RSpec::Support.require_rspec_core 'bisect/fork_runner'
2103
+ Bisect::ForkRunner
2104
+ when :shell
2105
+ RSpec::Support.require_rspec_core 'bisect/shell_runner'
2106
+ Bisect::ShellRunner
2107
+ else
2108
+ raise "Unsupported value for `bisect_runner` (#{bisect_runner.inspect}). " \
2109
+ "Only `:fork` and `:shell` are supported."
2110
+ end
2111
+ end
2112
+ end
2113
+
2114
+ private
2115
+
2116
+ def load_file_handling_errors(method, file)
2117
+ __send__(method, file)
2118
+ rescue LoadError => ex
2119
+ relative_file = Metadata.relative_path(file)
2120
+ suggestions = DidYouMean.new(relative_file).call
2121
+ reporter.notify_non_example_exception(ex, "An error occurred while loading #{relative_file}.#{suggestions}")
2122
+ RSpec.world.wants_to_quit = true
2123
+ rescue Support::AllExceptionsExceptOnesWeMustNotRescue => ex
2124
+ relative_file = Metadata.relative_path(file)
2125
+ reporter.notify_non_example_exception(ex, "An error occurred while loading #{relative_file}.")
2126
+ RSpec.world.wants_to_quit = true
2127
+ rescue SystemExit => ex
2128
+ relative_file = Metadata.relative_path(file)
2129
+ reporter.notify_non_example_exception(
2130
+ ex,
2131
+ "While loading #{relative_file} an `exit` / `raise SystemExit` occurred, RSpec will now quit."
2132
+ )
2133
+ RSpec.world.rspec_is_quitting = true
2134
+ raise ex
2135
+ end
2136
+
2137
+ def handle_suite_hook(scope, meta)
2138
+ return nil unless scope == :suite
2139
+
2140
+ unless meta.empty?
2141
+ # TODO: in RSpec 4, consider raising an error here.
2142
+ # We warn only for backwards compatibility.
2143
+ RSpec.warn_with "WARNING: `:suite` hooks do not support metadata since " \
2144
+ "they apply to the suite as a whole rather than " \
2145
+ "any individual example or example group that has metadata. " \
2146
+ "The metadata you have provided (#{meta.inspect}) will be ignored."
2147
+ end
2148
+
2149
+ yield
2150
+ end
2151
+
2152
+ def run_suite_hooks(hook_description, hooks)
2153
+ context = SuiteHookContext.new(hook_description, reporter)
2154
+
2155
+ hooks.each do |hook|
2156
+ begin
2157
+ hook.run(context)
2158
+ rescue Support::AllExceptionsExceptOnesWeMustNotRescue => ex
2159
+ context.set_exception(ex)
2160
+
2161
+ # Do not run subsequent `before` hooks if one fails.
2162
+ # But for `after` hooks, we run them all so that all
2163
+ # cleanup bits get a chance to complete, minimizing the
2164
+ # chance that resources get left behind.
2165
+ break if hooks.equal?(@before_suite_hooks)
2166
+ end
2167
+ end
2168
+ end
2169
+
2170
+ def get_files_to_run(paths)
2171
+ files = FlatMap.flat_map(paths_to_check(paths)) do |path|
2172
+ path = path.gsub(File::ALT_SEPARATOR, File::SEPARATOR) if File::ALT_SEPARATOR
2173
+ File.directory?(path) ? gather_directories(path) : extract_location(path)
2174
+ end.uniq
2175
+
2176
+ return files unless only_failures?
2177
+ relative_files = files.map { |f| Metadata.relative_path(File.expand_path f) }
2178
+ intersection = (relative_files & spec_files_with_failures.to_a)
2179
+ intersection.empty? ? files : intersection
2180
+ end
2181
+
2182
+ def paths_to_check(paths)
2183
+ return paths if pattern_might_load_specs_from_vendored_dirs?
2184
+ paths + [Dir.getwd]
2185
+ end
2186
+
2187
+ def pattern_might_load_specs_from_vendored_dirs?
2188
+ pattern.split(File::SEPARATOR).first.include?('**')
2189
+ end
2190
+
2191
+ def gather_directories(path)
2192
+ include_files = get_matching_files(path, pattern)
2193
+ exclude_files = get_matching_files(path, exclude_pattern)
2194
+ (include_files - exclude_files).uniq
2195
+ end
2196
+
2197
+ def get_matching_files(path, pattern)
2198
+ raw_files = Dir[file_glob_from(path, pattern)]
2199
+ raw_files.map { |file| File.expand_path(file) }.sort
2200
+ end
2201
+
2202
+ def file_glob_from(path, pattern)
2203
+ stripped = "{#{pattern.gsub(/\s*,\s*/, ',')}}"
2204
+ return stripped if pattern =~ /^(\.\/)?#{Regexp.escape path}/ || absolute_pattern?(pattern)
2205
+ File.join(path, stripped)
2206
+ end
2207
+
2208
+ if RSpec::Support::OS.windows?
2209
+ # :nocov:
2210
+ def absolute_pattern?(pattern)
2211
+ pattern =~ /\A[A-Z]:\\/ || windows_absolute_network_path?(pattern)
2212
+ end
2213
+
2214
+ def windows_absolute_network_path?(pattern)
2215
+ return false unless ::File::ALT_SEPARATOR
2216
+ pattern.start_with?(::File::ALT_SEPARATOR + ::File::ALT_SEPARATOR)
2217
+ end
2218
+ # :nocov:
2219
+ else
2220
+ def absolute_pattern?(pattern)
2221
+ pattern.start_with?(File::Separator)
2222
+ end
2223
+ end
2224
+
2225
+ def extract_location(path)
2226
+ match = /^(.*?)((?:\:\d+)+)$/.match(path)
2227
+
2228
+ if match
2229
+ captures = match.captures
2230
+ path = captures[0]
2231
+ lines = captures[1][1..-1].split(":").map(&:to_i)
2232
+ filter_manager.add_location path, lines
2233
+ else
2234
+ path, scoped_ids = Example.parse_id(path)
2235
+ filter_manager.add_ids(path, scoped_ids.split(/\s*,\s*/)) if scoped_ids
2236
+ end
2237
+
2238
+ return [] if path == default_path
2239
+ File.expand_path(path)
2240
+ end
2241
+
2242
+ def command
2243
+ $0.split(File::SEPARATOR).last
2244
+ end
2245
+
2246
+ def value_for(key)
2247
+ @preferred_options.fetch(key) { yield }
2248
+ end
2249
+
2250
+ def define_built_in_hooks
2251
+ around(:example, :aggregate_failures => true) do |procsy|
2252
+ begin
2253
+ aggregate_failures(nil, :hide_backtrace => true, &procsy)
2254
+ rescue Support::AllExceptionsExceptOnesWeMustNotRescue => exception
2255
+ procsy.example.set_aggregate_failures_exception(exception)
2256
+ end
2257
+ end
2258
+ end
2259
+
2260
+ def assert_no_example_groups_defined(config_option)
2261
+ return unless world.example_groups.any?
2262
+
2263
+ raise MustBeConfiguredBeforeExampleGroupsError.new(
2264
+ "RSpec's #{config_option} configuration option must be configured before " \
2265
+ "any example groups are defined, but you have already defined a group."
2266
+ )
2267
+ end
2268
+
2269
+ def output_wrapper
2270
+ @output_wrapper ||= OutputWrapper.new(output_stream)
2271
+ end
2272
+
2273
+ def output_to_tty?(output=output_stream)
2274
+ output.respond_to?(:tty?) && output.tty?
2275
+ end
2276
+
2277
+ def conditionally_disable_mocks_monkey_patching
2278
+ return unless disable_monkey_patching && rspec_mocks_loaded?
2279
+
2280
+ RSpec::Mocks.configuration.tap do |config|
2281
+ config.syntax = :expect
2282
+ config.patch_marshal_to_support_partial_doubles = false
2283
+ end
2284
+ end
2285
+
2286
+ def conditionally_disable_expectations_monkey_patching
2287
+ return unless disable_monkey_patching && rspec_expectations_loaded?
2288
+
2289
+ RSpec::Expectations.configuration.syntax = :expect
2290
+ end
2291
+
2292
+ def rspec_mocks_loaded?
2293
+ defined?(RSpec::Mocks.configuration)
2294
+ end
2295
+
2296
+ def rspec_expectations_loaded?
2297
+ defined?(RSpec::Expectations.configuration)
2298
+ end
2299
+
2300
+ def update_pattern_attr(name, value)
2301
+ if @spec_files_loaded
2302
+ RSpec.warning "Configuring `#{name}` to #{value} has no effect since " \
2303
+ "RSpec has already loaded the spec files."
2304
+ end
2305
+
2306
+ instance_variable_set(:"@#{name}", value)
2307
+ @files_to_run = nil
2308
+ end
2309
+
2310
+ def clear_values_derived_from_example_status_persistence_file_path
2311
+ @last_run_statuses = nil
2312
+ @spec_files_with_failures = nil
2313
+ end
2314
+
2315
+ def configure_group_with(group, module_list, application_method)
2316
+ module_list.items_for(group.metadata).each do |mod|
2317
+ __send__(application_method, mod, group)
2318
+ end
2319
+ end
2320
+
2321
+ def add_hook_to_existing_matching_groups(meta, scope, &block)
2322
+ # For example hooks, we have to apply it to each of the top level
2323
+ # groups, even if the groups do not match. When we apply it, we
2324
+ # apply it with the metadata, so it will only apply to examples
2325
+ # in the group that match the metadata.
2326
+ # #2280 for background and discussion.
2327
+ if scope == :example || scope == :each || scope.nil?
2328
+ world.example_groups.each(&block)
2329
+ else
2330
+ meta = Metadata.build_hash_from(meta.dup)
2331
+ on_existing_matching_groups(meta, &block)
2332
+ end
2333
+ end
2334
+
2335
+ def on_existing_matching_groups(meta)
2336
+ world.traverse_example_group_trees_until do |group|
2337
+ metadata_applies_to_group?(meta, group).tap do |applies|
2338
+ yield group if applies
2339
+ end
2340
+ end
2341
+ end
2342
+
2343
+ def metadata_applies_to_group?(meta, group)
2344
+ meta.empty? || MetadataFilter.apply?(:any?, meta, group.metadata)
2345
+ end
2346
+
2347
+ if RSpec::Support::RubyFeatures.module_prepends_supported?
2348
+ def safe_prepend(mod, host)
2349
+ host.__send__(:prepend, mod) unless host < mod
2350
+ end
2351
+ end
2352
+
2353
+ if RUBY_VERSION.to_f >= 1.9
2354
+ def safe_include(mod, host)
2355
+ host.__send__(:include, mod) unless host < mod
2356
+ end
2357
+
2358
+ def safe_extend(mod, host)
2359
+ host.extend(mod) unless host.singleton_class < mod
2360
+ end
2361
+ else # for 1.8.7
2362
+ # :nocov:
2363
+ def safe_include(mod, host)
2364
+ host.__send__(:include, mod) unless host.included_modules.include?(mod)
2365
+ end
2366
+
2367
+ def safe_extend(mod, host)
2368
+ host.extend(mod) unless (class << host; self; end).included_modules.include?(mod)
2369
+ end
2370
+ # :nocov:
2371
+ end
2372
+
2373
+ def define_mixed_in_module(mod, filters, mod_list, config_method, &block)
2374
+ unless Module === mod
2375
+ raise TypeError, "`RSpec.configuration.#{config_method}` expects a module but got: #{mod.inspect}"
2376
+ end
2377
+
2378
+ meta = Metadata.build_hash_from(filters, :warn_about_example_group_filtering)
2379
+ mod_list.append(mod, meta)
2380
+ on_existing_matching_groups(meta, &block)
2381
+ end
2382
+ end
2383
+ # rubocop:enable Metrics/ClassLength
2384
+ end
2385
+ end