cucumber 1.3.20 → 2.0.0.beta.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (404) hide show
  1. checksums.yaml +7 -0
  2. data/.coveralls.yml +1 -0
  3. data/.rspec +1 -1
  4. data/.travis.yml +1 -2
  5. data/CONTRIBUTING.md +9 -0
  6. data/Gemfile +9 -2
  7. data/History.md +26 -17
  8. data/LICENSE +2 -2
  9. data/README.md +4 -4
  10. data/Rakefile +12 -0
  11. data/bin/cucumber +1 -5
  12. data/bin/cuke +60 -0
  13. data/cucumber.gemspec +10 -15
  14. data/cucumber.yml +14 -26
  15. data/examples/i18n/ar/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  16. data/examples/i18n/bg/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  17. data/examples/i18n/ca/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  18. data/examples/i18n/cs/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  19. data/examples/i18n/da/features/{step_definitons → step_definitions}/lommeregner_steps.rb +0 -0
  20. data/examples/i18n/de/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  21. data/examples/{ramaze → i18n/el}/Rakefile +1 -1
  22. data/examples/i18n/el/features/addition.feature +17 -0
  23. data/examples/i18n/el/features/division.feature +10 -0
  24. data/examples/i18n/el/features/step_definitions/calculator_steps.rb +24 -0
  25. data/examples/i18n/el/lib/calculator.rb +14 -0
  26. data/examples/i18n/en/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  27. data/examples/i18n/eo/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  28. data/examples/i18n/es/features/{step_definitons → step_definitions}/calculador_steps.rb +0 -0
  29. data/examples/i18n/fi/features/{step_definitons → step_definitions}/laskin_steps.rb +0 -0
  30. data/examples/i18n/fr/Rakefile +3 -1
  31. data/examples/i18n/fr/features/step_definitions/calculatrice_steps.rb +2 -2
  32. data/examples/i18n/he/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  33. data/examples/i18n/hi/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  34. data/examples/i18n/hu/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  35. data/examples/i18n/id/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  36. data/examples/i18n/it/features/{step_definitons → step_definitions}/calcolatrice_steps.rb +0 -0
  37. data/examples/i18n/ja/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  38. data/examples/i18n/ko/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  39. data/examples/i18n/lt/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  40. data/examples/i18n/lv/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  41. data/examples/i18n/no/features/{step_definitons → step_definitions}/kalkulator_steps.rb +0 -0
  42. data/examples/i18n/pl/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  43. data/examples/i18n/ro/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  44. data/examples/i18n/ru/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  45. data/examples/i18n/sk/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  46. data/examples/i18n/sr-Cyrl/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  47. data/examples/i18n/sr-Latn/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  48. data/examples/i18n/sv/features/{step_definitons → step_definitions}/kalkulator_steps.rb +0 -0
  49. data/examples/i18n/tr/features/{step_definitons → step_definitions}/hesap_makinesi_adimlari.rb +0 -0
  50. data/examples/i18n/uk/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  51. data/examples/i18n/uz/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  52. data/examples/i18n/zh-CN/features/{step_definitons → step_definitions}/calculator_steps.rb +4 -4
  53. data/examples/i18n/zh-TW/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
  54. data/{legacy_features → features/docs}/api/list_step_defs_as_json.feature +14 -14
  55. data/{legacy_features → features/docs}/api/run_cli_main_with_existing_runtime.feature +5 -10
  56. data/features/{backtraces.feature → docs/cli/backtraces.feature} +2 -2
  57. data/features/docs/cli/dry_run.feature +25 -0
  58. data/features/docs/cli/exclude_files.feature +19 -0
  59. data/features/docs/cli/execute_with_tag_filter.feature +117 -0
  60. data/features/docs/cli/randomize.feature +46 -0
  61. data/features/docs/cli/require.feature +27 -0
  62. data/features/docs/cli/run_scenarios_matching_name.feature +104 -0
  63. data/features/docs/cli/run_specific_scenarios.feature +113 -0
  64. data/features/docs/cli/showing_differences.feature +43 -0
  65. data/features/docs/cli/specifying_multiple_formatters.feature +44 -0
  66. data/features/docs/cli/strict_mode.feature +41 -0
  67. data/features/{nested_steps.feature → docs/defining_steps/nested_steps.feature} +3 -5
  68. data/features/{nested_steps_i18n.feature → docs/defining_steps/nested_steps_i18n.feature} +0 -2
  69. data/features/{nested_steps_with_second_arg.feature → docs/defining_steps/nested_steps_with_second_arg.feature} +0 -0
  70. data/features/{step_definitions.feature → docs/defining_steps/one_line_step_definitions.feature} +3 -3
  71. data/features/docs/defining_steps/printing_messages.feature +147 -0
  72. data/features/docs/defining_steps/skip_scenario.feature +33 -0
  73. data/features/docs/defining_steps/snippets.feature +41 -0
  74. data/{legacy_features → features/docs/defining_steps}/table_diffing.feature +15 -15
  75. data/features/{transforms.feature → docs/defining_steps/transforms.feature} +2 -2
  76. data/{legacy_features/exception_in_after_block.feature → features/docs/exception_in_after_hook.feature} +25 -26
  77. data/{legacy_features/exception_in_after_step_block.feature → features/docs/exception_in_after_step_hook.feature} +21 -24
  78. data/{legacy_features/exception_in_before_block.feature → features/docs/exception_in_before_hook.feature} +18 -20
  79. data/features/{custom_formatter.feature → docs/extending_cucumber/custom_formatter.feature} +3 -8
  80. data/features/{formatter_callbacks.feature → docs/extending_cucumber/formatter_callbacks.feature} +185 -4
  81. data/{legacy_features/listener_debugger_formatter.feature → features/docs/formatters/debug_formatter.feature} +13 -15
  82. data/features/{formatter_step_file_colon_line.feature → docs/formatters/formatter_step_file_colon_line.feature} +2 -4
  83. data/features/{html_formatter.feature → docs/formatters/html_formatter.feature} +10 -14
  84. data/features/{json_formatter.feature → docs/formatters/json_formatter.feature} +109 -247
  85. data/features/docs/formatters/junit_formatter.feature +275 -0
  86. data/features/{pretty_formatter.feature → docs/formatters/pretty_formatter.feature} +1 -1
  87. data/features/{progress_formatter.feature → docs/formatters/progress_formatter.feature} +1 -1
  88. data/features/docs/formatters/rerun_formatter.feature +135 -0
  89. data/features/docs/formatters/usage_formatter.feature +102 -0
  90. data/features/docs/getting_started.feature +27 -0
  91. data/features/{background.feature → docs/gherkin/background.feature} +149 -91
  92. data/features/{doc_strings.feature → docs/gherkin/doc_strings.feature} +1 -0
  93. data/features/docs/gherkin/expand_option_for_outlines.feature +46 -0
  94. data/features/docs/gherkin/language_from_header.feature +32 -0
  95. data/features/docs/gherkin/outlines.feature +154 -0
  96. data/features/docs/gherkin/unicode_table.feature +32 -0
  97. data/features/docs/gherkin/using_descriptions.feature +88 -0
  98. data/features/docs/gherkin/using_star_notation.feature +37 -0
  99. data/features/{iso-8859-1.feature → docs/iso-8859-1.feature} +0 -0
  100. data/{legacy_features → features/docs}/post_configuration_hook.feature +17 -18
  101. data/{legacy_features → features/docs}/profiles.feature +30 -36
  102. data/{legacy_features → features/docs}/rake_task.feature +30 -41
  103. data/features/{raketask.feature → docs/raketask.feature} +6 -13
  104. data/features/docs/report_called_undefined_steps.feature +57 -0
  105. data/{legacy_features → features/docs}/wire_protocol.feature +36 -31
  106. data/{legacy_features → features/docs}/wire_protocol_erb.feature +5 -6
  107. data/{legacy_features → features/docs}/wire_protocol_table_diffing.feature +14 -12
  108. data/{legacy_features → features/docs}/wire_protocol_tags.feature +6 -7
  109. data/{legacy_features → features/docs}/wire_protocol_timeouts.feature +6 -6
  110. data/{legacy_features → features/docs}/work_in_progress.feature +52 -54
  111. data/{legacy_features → features/docs/writing_support_code}/around_hooks.feature +25 -28
  112. data/features/docs/writing_support_code/before_hook.feature +61 -0
  113. data/features/docs/writing_support_code/hook_order.feature +61 -0
  114. data/features/{load_path.feature → docs/writing_support_code/load_path.feature} +3 -0
  115. data/features/docs/writing_support_code/state.feature +32 -0
  116. data/features/{tagged_hooks.feature → docs/writing_support_code/tagged_hooks.feature} +11 -13
  117. data/features/lib/step_definitions/aruba_steps.rb +22 -0
  118. data/features/lib/step_definitions/cucumber_steps.rb +50 -0
  119. data/features/{step_definitions → lib/step_definitions}/iso-8859-1_steps.rb +3 -15
  120. data/features/lib/step_definitions/json_steps.rb +7 -0
  121. data/features/lib/step_definitions/junit_steps.rb +13 -0
  122. data/features/lib/step_definitions/language_steps.rb +4 -5
  123. data/features/lib/step_definitions/profile_steps.rb +15 -0
  124. data/features/lib/step_definitions/ruby_steps.rb +3 -0
  125. data/{legacy_features → features/lib}/step_definitions/wire_steps.rb +16 -9
  126. data/features/lib/support/env.rb +21 -0
  127. data/{legacy_features → features/lib}/support/fake_wire_server.rb +0 -0
  128. data/features/{support → lib/support}/feature_factory.rb +1 -1
  129. data/features/lib/support/normalise_output.rb +33 -0
  130. data/gem_tasks/cov.rake +5 -0
  131. data/gem_tasks/cucumber.rake +1 -10
  132. data/gem_tasks/rspec.rake +0 -2
  133. data/gem_tasks/yard.rake +4 -1
  134. data/lib/cucumber.rb +1 -3
  135. data/lib/cucumber/cli/configuration.rb +30 -25
  136. data/lib/cucumber/cli/main.rb +13 -25
  137. data/lib/cucumber/cli/options.rb +15 -57
  138. data/lib/cucumber/configuration.rb +4 -0
  139. data/lib/cucumber/constantize.rb +7 -6
  140. data/lib/cucumber/core_ext/instance_exec.rb +7 -38
  141. data/lib/cucumber/core_ext/proc.rb +1 -1
  142. data/lib/cucumber/errors.rb +3 -1
  143. data/lib/cucumber/file_specs.rb +35 -0
  144. data/lib/cucumber/formatter/console.rb +32 -21
  145. data/lib/cucumber/formatter/debug.rb +5 -0
  146. data/lib/cucumber/formatter/gherkin_formatter_adapter.rb +8 -38
  147. data/lib/cucumber/formatter/html.rb +29 -21
  148. data/lib/cucumber/formatter/junit.rb +10 -7
  149. data/lib/cucumber/formatter/pretty.rb +2 -8
  150. data/lib/cucumber/formatter/rerun.rb +2 -3
  151. data/lib/cucumber/formatter/unicode.rb +8 -21
  152. data/lib/cucumber/formatter/usage.rb +65 -2
  153. data/lib/cucumber/language_support/language_methods.rb +1 -1
  154. data/lib/cucumber/mappings.rb +212 -0
  155. data/lib/cucumber/multiline_argument.rb +115 -0
  156. data/lib/cucumber/platform.rb +21 -22
  157. data/lib/cucumber/rake/task.rb +3 -54
  158. data/lib/cucumber/rb_support/rb_language.rb +2 -5
  159. data/lib/cucumber/rb_support/rb_world.rb +14 -19
  160. data/lib/cucumber/rb_support/snippet.rb +60 -19
  161. data/lib/cucumber/reports/legacy_formatter.rb +1279 -0
  162. data/lib/cucumber/runtime.rb +176 -26
  163. data/lib/cucumber/runtime/for_programming_languages.rb +10 -4
  164. data/lib/cucumber/runtime/gated_receiver.rb +21 -0
  165. data/lib/cucumber/runtime/support_code.rb +9 -7
  166. data/lib/cucumber/runtime/tag_limits.rb +15 -0
  167. data/lib/cucumber/runtime/tag_limits/filter.rb +31 -0
  168. data/lib/cucumber/runtime/tag_limits/test_case_index.rb +29 -0
  169. data/lib/cucumber/runtime/tag_limits/verifier.rb +57 -0
  170. data/lib/cucumber/runtime/user_interface.rb +4 -0
  171. data/lib/cucumber/step_match.rb +3 -3
  172. data/lib/cucumber/term/ansicolor.rb +1 -9
  173. data/lib/cucumber/wire_support/wire_language.rb +23 -9
  174. data/lib/cucumber/wire_support/wire_packet.rb +1 -1
  175. data/lib/cucumber/wire_support/wire_protocol/requests.rb +13 -5
  176. data/lib/cucumber/wire_support/wire_step_definition.rb +1 -8
  177. data/spec/cucumber/cli/configuration_spec.rb +151 -150
  178. data/spec/cucumber/cli/main_spec.rb +36 -99
  179. data/spec/cucumber/cli/options_spec.rb +238 -272
  180. data/spec/cucumber/cli/profile_loader_spec.rb +9 -8
  181. data/spec/cucumber/configuration_spec.rb +3 -3
  182. data/spec/cucumber/constantize_spec.rb +2 -1
  183. data/spec/cucumber/core_ext/proc_spec.rb +32 -43
  184. data/spec/cucumber/file_specs_spec.rb +41 -0
  185. data/spec/cucumber/formatter/ansicolor_spec.rb +11 -10
  186. data/spec/cucumber/formatter/debug_spec.rb +569 -0
  187. data/spec/cucumber/formatter/duration_spec.rb +6 -6
  188. data/spec/cucumber/formatter/html_spec.rb +53 -62
  189. data/spec/cucumber/formatter/interceptor_spec.rb +38 -31
  190. data/spec/cucumber/formatter/junit_spec.rb +34 -28
  191. data/spec/cucumber/formatter/pretty_spec.rb +238 -52
  192. data/spec/cucumber/formatter/progress_spec.rb +2 -2
  193. data/spec/cucumber/formatter/spec_helper.rb +23 -17
  194. data/spec/cucumber/rake/forked_spec.rb +13 -22
  195. data/spec/cucumber/rb_support/rb_language_spec.rb +76 -67
  196. data/spec/cucumber/rb_support/rb_step_definition_spec.rb +63 -42
  197. data/spec/cucumber/rb_support/rb_transform_spec.rb +4 -3
  198. data/spec/cucumber/rb_support/regexp_argument_matcher_spec.rb +6 -4
  199. data/spec/cucumber/rb_support/snippet_spec.rb +42 -33
  200. data/spec/cucumber/reports/legacy_formatter_spec.rb +1750 -0
  201. data/spec/cucumber/runtime/for_programming_languages_spec.rb +11 -10
  202. data/spec/cucumber/runtime/gated_receiver_spec.rb +47 -0
  203. data/spec/cucumber/runtime/results_spec.rb +33 -26
  204. data/spec/cucumber/runtime/support_code_spec.rb +29 -29
  205. data/spec/cucumber/runtime/tag_limits/filter_spec.rb +59 -0
  206. data/spec/cucumber/runtime/tag_limits/test_case_index_spec.rb +38 -0
  207. data/spec/cucumber/runtime/tag_limits/verifier_spec.rb +57 -0
  208. data/spec/cucumber/runtime_spec.rb +39 -34
  209. data/spec/cucumber/step_match_spec.rb +30 -20
  210. data/spec/cucumber/wire_support/configuration_spec.rb +8 -5
  211. data/spec/cucumber/wire_support/connection_spec.rb +12 -8
  212. data/spec/cucumber/wire_support/wire_exception_spec.rb +14 -8
  213. data/spec/cucumber/wire_support/wire_language_spec.rb +8 -9
  214. data/spec/cucumber/wire_support/wire_packet_spec.rb +17 -13
  215. data/spec/cucumber/world/pending_spec.rb +36 -36
  216. data/spec/simplecov_setup.rb +18 -0
  217. data/spec/spec_helper.rb +3 -9
  218. metadata +298 -507
  219. data/.gitattributes +0 -1
  220. data/.ruby-version +0 -1
  221. data/examples/python/README.textile +0 -8
  222. data/examples/python/Rakefile +0 -4
  223. data/examples/python/features/fibonacci.feature +0 -19
  224. data/examples/python/features/step_definitions/fib_steps.py +0 -11
  225. data/examples/python/lib/fib.py +0 -7
  226. data/examples/ramaze/README.textile +0 -7
  227. data/examples/ramaze/app.rb +0 -21
  228. data/examples/ramaze/features/add.feature +0 -11
  229. data/examples/ramaze/features/step_definitions/add_steps.rb +0 -15
  230. data/examples/ramaze/features/support/env.rb +0 -32
  231. data/examples/ramaze/layout/default.html.erb +0 -8
  232. data/examples/ramaze/view/index.html.erb +0 -5
  233. data/examples/ruby2python/README.textile +0 -8
  234. data/examples/ruby2python/Rakefile +0 -4
  235. data/examples/ruby2python/features/fibonacci.feature +0 -19
  236. data/examples/ruby2python/features/step_definitions/fib_steps.rb +0 -7
  237. data/examples/ruby2python/features/support/env.rb +0 -21
  238. data/examples/ruby2python/lib/fib.py +0 -7
  239. data/examples/v8/Rakefile +0 -6
  240. data/examples/v8/features/fibonacci.feature +0 -43
  241. data/examples/v8/features/step_definitions/fib_steps.js +0 -49
  242. data/examples/v8/features/support/env.js +0 -14
  243. data/examples/v8/lib/fibonacci.js +0 -19
  244. data/features/.cucumber/stepdefs.json +0 -722
  245. data/features/assertions.feature +0 -73
  246. data/features/autoformat_profile_output.feature +0 -23
  247. data/features/before_hook.feature +0 -43
  248. data/features/bootstrap.feature +0 -26
  249. data/features/drb_server_integration.feature +0 -63
  250. data/features/execute_with_tag_filter.feature +0 -63
  251. data/features/parsing.feature +0 -18
  252. data/features/rerun_formatter.feature +0 -99
  253. data/features/run_specific_scenarios.feature +0 -47
  254. data/features/stats_formatters.feature +0 -73
  255. data/features/step_definitions/cucumber-features/cucumber_ruby_mappings.rb +0 -197
  256. data/features/step_definitions/cucumber_steps.rb +0 -57
  257. data/features/step_definitions/drb_steps.rb +0 -3
  258. data/features/support/env.rb +0 -57
  259. data/fixtures/json/features/background.feature +0 -7
  260. data/fixtures/json/features/embed.feature +0 -4
  261. data/fixtures/json/features/one_passing_one_failing.feature +0 -11
  262. data/fixtures/json/features/step_definitions/steps.rb +0 -32
  263. data/fixtures/json/features/tables.feature +0 -13
  264. data/fixtures/junit/features/one_passing_one_failing.feature +0 -8
  265. data/fixtures/junit/features/pending.feature +0 -7
  266. data/fixtures/junit/features/scenario_outline.feature +0 -9
  267. data/fixtures/junit/features/some_subdirectory/one_passing_one_failing.feature +0 -8
  268. data/fixtures/junit/features/step_definitions/steps.rb +0 -11
  269. data/fixtures/self_test/README.textile +0 -6
  270. data/fixtures/self_test/Rakefile +0 -6
  271. data/fixtures/self_test/features/call_undefined_step_from_step_def.feature +0 -7
  272. data/fixtures/self_test/features/failing_expectation.feature +0 -4
  273. data/fixtures/self_test/features/lots_of_undefined.feature +0 -8
  274. data/fixtures/self_test/features/multiline_name.feature +0 -27
  275. data/fixtures/self_test/features/outline_sample.feature +0 -15
  276. data/fixtures/self_test/features/sample.feature +0 -21
  277. data/fixtures/self_test/features/search_sample.feature +0 -32
  278. data/fixtures/self_test/features/step_definitions/sample_steps.rb +0 -84
  279. data/fixtures/self_test/features/support/bubble_256x256.png +0 -0
  280. data/fixtures/self_test/features/support/env.rb +0 -26
  281. data/fixtures/self_test/features/tags_sample.feature +0 -17
  282. data/fixtures/self_test/features/tons_of_cukes.feature +0 -52
  283. data/fixtures/self_test/features/undefined_multiline_args.feature +0 -12
  284. data/fixtures/self_test/list-of-features.txt +0 -1
  285. data/fixtures/steps_library/features/step_definitions/steps_lib1.rb +0 -8
  286. data/fixtures/steps_library/features/step_definitions/steps_lib2.rb +0 -8
  287. data/fixtures/tickets/Rakefile +0 -20
  288. data/fixtures/tickets/features.html +0 -138
  289. data/fixtures/tickets/features/172.feature +0 -28
  290. data/fixtures/tickets/features/177/1.feature +0 -28
  291. data/fixtures/tickets/features/177/2.feature +0 -20
  292. data/fixtures/tickets/features/177/3.feature +0 -18
  293. data/fixtures/tickets/features/180.feature +0 -7
  294. data/fixtures/tickets/features/229/tagged_hooks.feature +0 -8
  295. data/fixtures/tickets/features/229/tagged_hooks.rb +0 -14
  296. data/fixtures/tickets/features/236.feature +0 -13
  297. data/fixtures/tickets/features/241.feature +0 -12
  298. data/fixtures/tickets/features/246.feature +0 -4
  299. data/fixtures/tickets/features/248.feature +0 -11
  300. data/fixtures/tickets/features/270/back.feature +0 -14
  301. data/fixtures/tickets/features/270/back.steps.rb +0 -14
  302. data/fixtures/tickets/features/272/hooks.feature +0 -26
  303. data/fixtures/tickets/features/272/hooks_steps.rb +0 -53
  304. data/fixtures/tickets/features/279/py_string_indent.feature +0 -25
  305. data/fixtures/tickets/features/279/py_string_indent.steps.rb +0 -12
  306. data/fixtures/tickets/features/279/wrong.feature_ +0 -11
  307. data/fixtures/tickets/features/301/filter_background_tagged_hooks.feature +0 -6
  308. data/fixtures/tickets/features/301/filter_background_tagged_hooks_steps.rb +0 -12
  309. data/fixtures/tickets/features/306/only_background.feature +0 -4
  310. data/fixtures/tickets/features/around_timeout.feature +0 -6
  311. data/fixtures/tickets/features/gherkin_67.feature +0 -12
  312. data/fixtures/tickets/features/gherkin_68.feature +0 -4
  313. data/fixtures/tickets/features/half_manual.feature +0 -11
  314. data/fixtures/tickets/features/lib/eatting_machine.rb +0 -18
  315. data/fixtures/tickets/features/lib/pantry.rb +0 -20
  316. data/fixtures/tickets/features/scenario_outline.feature +0 -95
  317. data/fixtures/tickets/features/step_definitons/246_steps.rb +0 -3
  318. data/fixtures/tickets/features/step_definitons/248_steps.rb +0 -15
  319. data/fixtures/tickets/features/step_definitons/around_timeout_steps.rb +0 -9
  320. data/fixtures/tickets/features/step_definitons/half_manual_steps.rb +0 -11
  321. data/fixtures/tickets/features/step_definitons/scenario_outline_steps.rb +0 -42
  322. data/fixtures/tickets/features/step_definitons/tickets_steps.rb +0 -88
  323. data/fixtures/tickets/features/table_diffing.feature +0 -13
  324. data/fixtures/tickets/features/tickets.feature +0 -28
  325. data/legacy_features/README.md +0 -14
  326. data/legacy_features/announce.feature +0 -152
  327. data/legacy_features/bug_371.feature +0 -32
  328. data/legacy_features/bug_464.feature +0 -16
  329. data/legacy_features/bug_475.feature +0 -42
  330. data/legacy_features/bug_585_tab_indentation.feature +0 -22
  331. data/legacy_features/bug_600.feature +0 -73
  332. data/legacy_features/cucumber_cli.feature +0 -584
  333. data/legacy_features/cucumber_cli_outlines.feature +0 -117
  334. data/legacy_features/default_snippets.feature +0 -43
  335. data/legacy_features/diffing.feature +0 -25
  336. data/legacy_features/drb_server_integration.feature +0 -174
  337. data/legacy_features/exclude_files.feature +0 -20
  338. data/legacy_features/expand.feature +0 -60
  339. data/legacy_features/junit_formatter.feature +0 -214
  340. data/legacy_features/language_from_header.feature +0 -30
  341. data/legacy_features/multiline_names.feature +0 -44
  342. data/legacy_features/report_called_undefined_steps.feature +0 -35
  343. data/legacy_features/rerun_formatter.feature +0 -52
  344. data/legacy_features/simplest.feature +0 -11
  345. data/legacy_features/snippet.feature +0 -23
  346. data/legacy_features/snippets_when_using_star_keyword.feature +0 -38
  347. data/legacy_features/step_definitions/cucumber_steps.rb +0 -179
  348. data/legacy_features/step_definitions/extra_steps.rb +0 -2
  349. data/legacy_features/step_definitions/simplest_steps.rb +0 -3
  350. data/legacy_features/support/env.rb +0 -161
  351. data/legacy_features/support/env.rb.simplest +0 -7
  352. data/legacy_features/table_mapping.feature +0 -34
  353. data/legacy_features/transform.feature +0 -245
  354. data/legacy_features/unicode_table.feature +0 -35
  355. data/lib/README.rdoc +0 -12
  356. data/lib/cucumber/ast.rb +0 -30
  357. data/lib/cucumber/ast/background.rb +0 -116
  358. data/lib/cucumber/ast/comment.rb +0 -31
  359. data/lib/cucumber/ast/doc_string.rb +0 -61
  360. data/lib/cucumber/ast/empty_background.rb +0 -33
  361. data/lib/cucumber/ast/examples.rb +0 -49
  362. data/lib/cucumber/ast/feature.rb +0 -99
  363. data/lib/cucumber/ast/features.rb +0 -38
  364. data/lib/cucumber/ast/has_steps.rb +0 -74
  365. data/lib/cucumber/ast/location.rb +0 -41
  366. data/lib/cucumber/ast/multiline_argument.rb +0 -30
  367. data/lib/cucumber/ast/names.rb +0 -13
  368. data/lib/cucumber/ast/outline_table.rb +0 -194
  369. data/lib/cucumber/ast/scenario.rb +0 -103
  370. data/lib/cucumber/ast/scenario_outline.rb +0 -146
  371. data/lib/cucumber/ast/step.rb +0 -122
  372. data/lib/cucumber/ast/step_collection.rb +0 -92
  373. data/lib/cucumber/ast/step_invocation.rb +0 -196
  374. data/lib/cucumber/ast/table.rb +0 -738
  375. data/lib/cucumber/ast/tags.rb +0 -28
  376. data/lib/cucumber/ast/tree_walker.rb +0 -191
  377. data/lib/cucumber/ast/visitor.rb +0 -11
  378. data/lib/cucumber/broadcaster.rb +0 -13
  379. data/lib/cucumber/cli/drb_client.rb +0 -43
  380. data/lib/cucumber/feature_file.rb +0 -101
  381. data/lib/cucumber/formatter/ordered_xml_markup.rb +0 -24
  382. data/lib/cucumber/js_support/js_dsl.js +0 -57
  383. data/lib/cucumber/js_support/js_language.rb +0 -185
  384. data/lib/cucumber/js_support/js_snippets.rb +0 -27
  385. data/lib/cucumber/parser.rb +0 -2
  386. data/lib/cucumber/parser/gherkin_builder.rb +0 -284
  387. data/lib/cucumber/py_support/py_dsl.py +0 -10
  388. data/lib/cucumber/py_support/py_language.py +0 -10
  389. data/lib/cucumber/py_support/py_language.rb +0 -80
  390. data/lib/cucumber/step_mother.rb +0 -10
  391. data/spec/cucumber/ast/background_spec.rb +0 -122
  392. data/spec/cucumber/ast/doc_string_spec.rb +0 -40
  393. data/spec/cucumber/ast/feature_factory.rb +0 -72
  394. data/spec/cucumber/ast/feature_spec.rb +0 -63
  395. data/spec/cucumber/ast/features_spec.rb +0 -51
  396. data/spec/cucumber/ast/outline_table_spec.rb +0 -21
  397. data/spec/cucumber/ast/scenario_outline_spec.rb +0 -74
  398. data/spec/cucumber/ast/step_spec.rb +0 -68
  399. data/spec/cucumber/ast/table_spec.rb +0 -594
  400. data/spec/cucumber/ast/tree_walker_spec.rb +0 -19
  401. data/spec/cucumber/broadcaster_spec.rb +0 -15
  402. data/spec/cucumber/cli/drb_client_spec.rb +0 -76
  403. data/spec/cucumber/rake/rcov_spec.rb +0 -71
  404. data/spec/cucumber/wire_support/wire_step_definition_spec.rb +0 -20
@@ -0,0 +1,57 @@
1
+ module Cucumber
2
+ class Runtime
3
+ module TagLimits
4
+ class Verifier
5
+ def initialize(tag_limits)
6
+ @tag_limits = tag_limits
7
+ end
8
+
9
+ def verify!(test_case_index)
10
+ breaches = collect_breaches(test_case_index)
11
+ raise TagLimitExceededError.new(*breaches) unless breaches.empty?
12
+ end
13
+
14
+ private
15
+
16
+ def collect_breaches(test_case_index)
17
+ tag_limits.reduce([]) do |breaches, (tag_name, limit)|
18
+ breaches.tap do |breaches|
19
+ if test_case_index.count_by_tag_name(tag_name) > limit
20
+ breaches << Breach.new(tag_name, limit, test_case_index.locations_of_tag_name(tag_name))
21
+ end
22
+ end
23
+ end
24
+ end
25
+
26
+ attr_reader :tag_limits
27
+
28
+ class Breach
29
+ INDENT = (" " * 2).freeze
30
+
31
+ def initialize(tag_name, limit, locations)
32
+ @tag_name = tag_name
33
+ @limit = limit
34
+ @locations = locations
35
+ end
36
+
37
+ def to_s
38
+ [
39
+ "#{tag_name} occurred #{tag_count} times, but the limit was set to #{limit}",
40
+ *locations.map(&:to_s)
41
+ ].join("\n#{INDENT}")
42
+ end
43
+
44
+ private
45
+
46
+ def tag_count
47
+ locations.count
48
+ end
49
+
50
+ attr_reader :tag_name
51
+ attr_reader :limit
52
+ attr_reader :locations
53
+ end
54
+ end
55
+ end
56
+ end
57
+ end
@@ -6,6 +6,10 @@ module Cucumber
6
6
  module UserInterface
7
7
  attr_writer :visitor
8
8
 
9
+ def visitor=(visitor)
10
+ @visitor = visitor
11
+ end
12
+
9
13
  # Output +messages+ alongside the formatted output.
10
14
  # This is an alternative to using Kernel#puts - it will display
11
15
  # nicer, and in all outputs (in case you use several formatters)
@@ -12,7 +12,7 @@ module Cucumber
12
12
  end
13
13
 
14
14
  def args
15
- @step_arguments.map{|g| g.val}
15
+ @step_arguments.map{|g| g.val.freeze }
16
16
  end
17
17
 
18
18
  def name
@@ -20,8 +20,8 @@ module Cucumber
20
20
  end
21
21
 
22
22
  def invoke(multiline_arg)
23
- all_args = args
24
- all_args << multiline_arg.to_step_definition_arg if multiline_arg
23
+ all_args = args.dup
24
+ multiline_arg.append_to(all_args)
25
25
  @step_definition.invoke(all_args)
26
26
  end
27
27
 
@@ -78,7 +78,7 @@ module Cucumber
78
78
 
79
79
 
80
80
  def self.included(klass)
81
- if version_is_greater_than_18? and klass == String
81
+ if klass == String
82
82
  ATTRIBUTES.delete(:clear)
83
83
  ATTRIBUTE_NAMES.delete(:clear)
84
84
  end
@@ -105,14 +105,6 @@ module Cucumber
105
105
  ATTRIBUTE_NAMES
106
106
  end
107
107
  extend self
108
-
109
- private
110
-
111
- def version_is_greater_than_18?
112
- version = RUBY_VERSION.split('.')
113
- version.map! &:to_i
114
- version[0] >= 1 && version[1] > 8
115
- end
116
108
  end
117
109
  end
118
110
  end
@@ -9,26 +9,23 @@ require 'cucumber/wire_support/wire_step_definition'
9
9
  module Cucumber
10
10
  module WireSupport
11
11
 
12
- # The wire-protocol (lanugage independent) implementation of the programming
12
+ # The wire-protocol (language independent) implementation of the programming
13
13
  # language API.
14
14
  class WireLanguage
15
15
  include LanguageSupport::LanguageMethods
16
16
 
17
- def initialize(runtime)
17
+ def initialize(_=nil)
18
18
  @connections = []
19
19
  end
20
20
 
21
- def alias_adverbs(adverbs)
22
- end
23
-
24
21
  def load_code_file(wire_file)
25
22
  config = Configuration.from_file(wire_file)
26
23
  @connections << Connection.new(config)
27
24
  end
28
25
 
29
- def snippet_text(code_keyword, step_name, multiline_arg_class, snippet_type)
26
+ def snippet_text(code_keyword, step_name, multiline_arg, snippet_type)
30
27
  snippets = @connections.map do |remote|
31
- remote.snippet_text(code_keyword, step_name, multiline_arg_class.to_s)
28
+ remote.snippet_text(code_keyword, step_name, MultilineArgClassName.new(multiline_arg).to_s)
32
29
  end
33
30
  snippets.flatten.join("\n")
34
31
  end
@@ -37,8 +34,6 @@ module Cucumber
37
34
  @connections.map{ |c| c.step_matches(step_name, formatted_step_name)}.flatten
38
35
  end
39
36
 
40
- protected
41
-
42
37
  def begin_scenario(scenario)
43
38
  @connections.each { |c| c.begin_scenario(scenario) }
44
39
  @current_scenario = scenario
@@ -49,6 +44,25 @@ module Cucumber
49
44
  @connections.each { |c| c.end_scenario(scenario) }
50
45
  @current_scenario = nil
51
46
  end
47
+
48
+ class MultilineArgClassName
49
+ def initialize(arg)
50
+ arg.describe_to(self)
51
+ @result = ""
52
+ end
53
+
54
+ def data_table(*)
55
+ @result = "Cucumber::MultilineArgument::DataTable"
56
+ end
57
+
58
+ def doc_string(*)
59
+ @result = "Cucumber::MultilineArgument::DocString"
60
+ end
61
+
62
+ def to_s
63
+ @result
64
+ end
65
+ end
52
66
  end
53
67
  end
54
68
  end
@@ -23,7 +23,7 @@ module Cucumber
23
23
  def to_json
24
24
  packet = [@message]
25
25
  packet << @params if @params
26
- packet.to_json
26
+ MultiJson.dump(packet)
27
27
  end
28
28
 
29
29
  def handle_with(handler)
@@ -68,21 +68,29 @@ module Cucumber
68
68
  end
69
69
 
70
70
  def handle_diff!(tables)
71
- table1 = Ast::Table.new(tables[0])
72
- table2 = Ast::Table.new(tables[1])
71
+ # TODO: figure out if / how we could get a location for a table from the wire (or make a null location)
72
+ location = Core::Ast::Location.new('??', '??')
73
+ table1 = table(tables[0], location)
74
+ table2 = table(tables[1], location)
73
75
  table1.diff!(table2)
74
76
  end
75
77
 
76
78
  def handle_diff(tables)
77
79
  begin
78
80
  handle_diff!(tables)
79
- rescue Cucumber::Ast::Table::Different
81
+ rescue Cucumber::MultilineArgument::DataTable::Different
80
82
  @connection.diff_failed
81
83
  end
82
84
  @connection.diff_ok
83
85
  end
84
86
 
85
87
  alias :handle_step_failed :handle_fail
88
+
89
+ private
90
+
91
+ def table(data, location)
92
+ Cucumber::MultilineArgument.from(Core::Ast::DataTable.new(data, location))
93
+ end
86
94
  end
87
95
 
88
96
  class DiffFailed < RequestHandler
@@ -95,11 +103,11 @@ module Cucumber
95
103
 
96
104
  module Tags
97
105
  def clean_tag_names(scenario)
98
- scenario.source_tags.map { |tag| tag.name.gsub(/^@/, '') }.sort
106
+ scenario.tags.map { |tag| tag.name.gsub(/^@/, '') }.sort
99
107
  end
100
108
 
101
109
  def request_params(scenario)
102
- return nil unless scenario.source_tags.any?
110
+ return nil unless scenario.tags.any?
103
111
  { "tags" => clean_tag_names(scenario) }
104
112
  end
105
113
  end
@@ -11,16 +11,9 @@ module Cucumber
11
11
  end
12
12
 
13
13
  def invoke(args)
14
- prepared_args = args.map{ |arg| prepare(arg) }
15
- @connection.invoke(@id, prepared_args)
14
+ @connection.invoke(@id, args)
16
15
  end
17
16
 
18
- private
19
-
20
- def prepare(arg)
21
- return arg unless arg.is_a?(Cucumber::Ast::Table)
22
- arg.raw
23
- end
24
17
  end
25
18
  end
26
19
  end
@@ -9,20 +9,22 @@ module Cli
9
9
  end
10
10
 
11
11
  def given_cucumber_yml_defined_as(hash_or_string)
12
- File.stub(:exist?).and_return(true)
12
+ allow(File).to receive(:exist?) { true }
13
+
13
14
  cucumber_yml = hash_or_string.is_a?(Hash) ? hash_or_string.to_yaml : hash_or_string
14
- IO.stub(:read).with('cucumber.yml').and_return(cucumber_yml)
15
+
16
+ allow(IO).to receive(:read).with('cucumber.yml') { cucumber_yml }
15
17
  end
16
18
 
17
19
  def given_the_following_files(*files)
18
- File.stub(:directory?).and_return(true)
19
- File.stub(:file?).and_return(true)
20
- Dir.stub(:[]).and_return(files)
20
+ allow(File).to receive(:directory?) { true }
21
+ allow(File).to receive(:file?) { true }
22
+ allow(Dir).to receive(:[]) { files }
21
23
  end
22
24
 
23
25
  before(:each) do
24
- File.stub(:exist?).and_return(false) # Meaning, no cucumber.yml exists
25
- Kernel.stub(:exit).and_return(nil)
26
+ allow(File).to receive(:exist?) { false } # Meaning, no cucumber.yml exists
27
+ allow(Kernel).to receive(:exit)
26
28
  end
27
29
 
28
30
  def config
@@ -35,34 +37,34 @@ module Cli
35
37
 
36
38
  attr_reader :out, :error
37
39
 
38
- it "should require env.rb files first" do
40
+ it "requires env.rb files first" do
39
41
  given_the_following_files("/features/support/a_file.rb","/features/support/env.rb")
40
42
 
41
43
  config.parse!(%w{--require /features})
42
44
 
43
- config.support_to_load.should == [
45
+ expect(config.support_to_load).to eq [
44
46
  "/features/support/env.rb",
45
47
  "/features/support/a_file.rb"
46
48
  ]
47
49
  end
48
50
 
49
- it "should not require env.rb files when --dry-run" do
51
+ it "does not require env.rb files when --dry-run" do
50
52
  given_the_following_files("/features/support/a_file.rb","/features/support/env.rb")
51
53
 
52
54
  config.parse!(%w{--require /features --dry-run})
53
55
 
54
- config.support_to_load.should == [
56
+ expect(config.support_to_load).to eq [
55
57
  "/features/support/a_file.rb"
56
58
  ]
57
59
  end
58
60
 
59
- it "should require files in vendor/{plugins,gems}/*/cucumber/*.rb" do
61
+ it "requires files in vendor/{plugins,gems}/*/cucumber/*.rb" do
60
62
  given_the_following_files("/vendor/gems/gem_a/cucumber/bar.rb",
61
63
  "/vendor/plugins/plugin_a/cucumber/foo.rb")
62
64
 
63
65
  config.parse!(%w{--require /features})
64
66
 
65
- config.step_defs_to_load.should == [
67
+ expect(config.step_defs_to_load).to eq [
66
68
  "/vendor/gems/gem_a/cucumber/bar.rb",
67
69
  "/vendor/plugins/plugin_a/cucumber/foo.rb"
68
70
  ]
@@ -75,7 +77,7 @@ module Cli
75
77
 
76
78
  config.parse!(%w{--require /features --exclude a_file.rb})
77
79
 
78
- config.all_files_to_load.should == [
80
+ expect(config.all_files_to_load).to eq [
79
81
  "/features/support/env.rb"
80
82
  ]
81
83
  end
@@ -87,43 +89,19 @@ module Cli
87
89
 
88
90
  config.parse!(%w{--require /features --exclude foo[df] --exclude blah})
89
91
 
90
- config.all_files_to_load.should == [
92
+ expect(config.all_files_to_load).to eq [
91
93
  "/features/support/bar.rb",
92
94
  "/features/support/fooz.rb"
93
95
  ]
94
96
  end
95
97
  end
96
98
 
97
- describe '#drb?' do
98
- it "indicates whether the --drb flag was passed in or not" do
99
- config.parse!(%w{features})
100
- config.should_not be_drb
101
-
102
-
103
- config.parse!(%w{features --drb})
104
- config.should be_drb
105
- end
106
- end
107
-
108
- describe "#drb_port" do
109
- it "is nil when not configured" do
110
- config.parse!([])
111
- config.drb_port.should be_nil
112
- end
113
-
114
- it "is numeric when configured" do
115
- config.parse!(%w{features --port 1000})
116
- config.drb_port.should == 1000
117
- end
118
-
119
-
120
- end
121
-
122
99
  it "uses the default profile when no profile is defined" do
123
100
  given_cucumber_yml_defined_as({'default' => '--require some_file'})
124
101
 
125
102
  config.parse!(%w{--format progress})
126
- config.options[:require].should include('some_file')
103
+
104
+ expect(config.options[:require]).to include('some_file')
127
105
  end
128
106
 
129
107
  context '--profile' do
@@ -133,29 +111,33 @@ module Cli
133
111
  given_cucumber_yml_defined_as({'bongo' => '--require from/yml'})
134
112
 
135
113
  config.parse!(%w{--format progress --profile bongo})
136
- config.options[:formats].should == [['progress', out]]
137
- config.options[:require].should == ['from/yml']
114
+
115
+ expect(config.options[:formats]).to eq [['progress', out]]
116
+ expect(config.options[:require]).to eq ['from/yml']
138
117
  end
139
118
 
140
119
  it "expands args from the default profile when no flags are provided" do
141
120
  given_cucumber_yml_defined_as({'default' => '--require from/yml'})
142
121
 
143
122
  config.parse!([])
144
- config.options[:require].should == ['from/yml']
123
+
124
+ expect(config.options[:require]).to eq ['from/yml']
145
125
  end
146
126
 
147
127
  it "allows --strict to be set by a profile" do
148
128
  given_cucumber_yml_defined_as({'bongo' => '--strict'})
149
129
 
150
130
  config.parse!(%w{--profile bongo})
151
- config.options[:strict].should be_true
131
+
132
+ expect(config.options[:strict]).to be true
152
133
  end
153
134
 
154
135
  it "parses ERB syntax in the cucumber.yml file" do
155
136
  given_cucumber_yml_defined_as("---\ndefault: \"<%=\"--require some_file\"%>\"\n")
156
137
 
157
138
  config.parse!([])
158
- config.options[:require].should include('some_file')
139
+
140
+ expect(config.options[:require]).to include('some_file')
159
141
  end
160
142
 
161
143
  it "parses ERB in cucumber.yml that makes uses nested ERB sessions" do
@@ -165,7 +147,8 @@ module Cli
165
147
  ERB_YML
166
148
 
167
149
  config.parse!(%w(-p standard))
168
- config.options[:require].should include('some_file')
150
+
151
+ expect(config.options[:require]).to include('some_file')
169
152
  end
170
153
 
171
154
  it "provides a helpful error message when a specified profile does not exists in cucumber.yml" do
@@ -179,23 +162,23 @@ Defined profiles in cucumber.yml:
179
162
  * html_report
180
163
  END_OF_MESSAGE
181
164
 
182
- lambda{config.parse!(%w{--profile i_do_not_exist})}.should raise_error(ProfileNotFound, expected_message)
165
+ expect(-> { config.parse!(%w{--profile i_do_not_exist}) }).to raise_error(ProfileNotFound, expected_message)
183
166
  end
184
167
 
185
168
  it "allows profiles to be defined in arrays" do
186
169
  given_cucumber_yml_defined_as({'foo' => ['-f','progress']})
187
170
 
188
171
  config.parse!(%w{--profile foo})
189
- config.options[:formats].should == [['progress', out]]
172
+
173
+ expect(config.options[:formats]).to eq [['progress', out]]
190
174
  end
191
175
 
192
176
  it "disregards default STDOUT formatter defined in profile when another is passed in (via cmd line)" do
193
177
  given_cucumber_yml_defined_as({'foo' => %w[--format pretty]})
194
178
  config.parse!(%w{--format progress --profile foo})
195
- config.options[:formats].should == [['progress', out]]#, ['pretty', 'pretty.txt']]
196
- end
197
-
198
179
 
180
+ expect(config.options[:formats]).to eq [['progress', out]]
181
+ end
199
182
 
200
183
  ["--no-profile", "-P"].each do |flag|
201
184
  context 'when none is specified with #{flag}' do
@@ -203,14 +186,16 @@ END_OF_MESSAGE
203
186
  given_cucumber_yml_defined_as({'default' => '-v --require file_specified_in_default_profile.rb'})
204
187
 
205
188
  config.parse!("#{flag} --require some_file.rb".split(" "))
206
- config.options[:require].should == ['some_file.rb']
189
+
190
+ expect(config.options[:require]).to eq ['some_file.rb']
207
191
  end
208
192
 
209
193
  it "notifies the user that the profiles are being disabled" do
210
194
  given_cucumber_yml_defined_as({'default' => '-v'})
211
195
 
212
196
  config.parse!("#{flag} --require some_file.rb".split(" "))
213
- out.string.should =~ /Disabling profiles.../
197
+
198
+ expect(out.string).to match /Disabling profiles.../
214
199
  end
215
200
  end
216
201
  end
@@ -220,15 +205,17 @@ END_OF_MESSAGE
220
205
  given_cucumber_yml_defined_as({'foo' => bad_input})
221
206
 
222
207
  expected_error = /The 'foo' profile in cucumber.yml was blank. Please define the command line arguments for the 'foo' profile in cucumber.yml./
223
- lambda{config.parse!(%w{--profile foo})}.should raise_error(expected_error)
208
+
209
+ expect(-> { config.parse!(%w{--profile foo}) }).to raise_error(expected_error)
224
210
  end
225
211
  end
226
212
 
227
213
  it "issues a helpful error message when no YAML file exists and a profile is specified" do
228
- File.should_receive(:exist?).with('cucumber.yml').and_return(false)
214
+ expect(File).to receive(:exist?).with('cucumber.yml') { false }
229
215
 
230
216
  expected_error = /cucumber\.yml was not found/
231
- lambda{config.parse!(%w{--profile i_do_not_exist})}.should raise_error(expected_error)
217
+
218
+ expect(-> { config.parse!(%w{--profile i_do_not_exist}) }).to raise_error(expected_error)
232
219
  end
233
220
 
234
221
  it "issues a helpful error message when cucumber.yml is blank or malformed" do
@@ -236,7 +223,9 @@ END_OF_MESSAGE
236
223
 
237
224
  ['', 'sfsadfs', "--- \n- an\n- array\n", "---dddfd"].each do |bad_input|
238
225
  given_cucumber_yml_defined_as(bad_input)
239
- lambda{config.parse!([])}.should raise_error(expected_error_message)
226
+
227
+ expect(-> { config.parse!([]) }).to raise_error(expected_error_message)
228
+
240
229
  reset_config
241
230
  end
242
231
  end
@@ -245,104 +234,109 @@ END_OF_MESSAGE
245
234
  expected_error_message = /cucumber.yml was found, but could not be parsed. Please refer to cucumber's documentation on correct profile usage./
246
235
 
247
236
  given_cucumber_yml_defined_as("input that causes an exception in YAML loading")
248
- YAML.should_receive(:load).and_raise ArgumentError
249
237
 
250
- lambda{config.parse!([])}.should raise_error(expected_error_message)
238
+ expect(YAML).to receive(:load).and_raise(ArgumentError)
239
+ expect(-> { config.parse!([]) }).to raise_error(expected_error_message)
251
240
  end
252
241
 
253
242
  it "issues a helpful error message when cucumber.yml can not be parsed by ERB" do
254
243
  expected_error_message = /cucumber.yml was found, but could not be parsed with ERB. Please refer to cucumber's documentation on correct profile usage./
255
244
  given_cucumber_yml_defined_as("<% this_fails %>")
256
245
 
257
- lambda{config.parse!([])}.should raise_error(expected_error_message)
246
+ expect(-> { config.parse!([]) }).to raise_error(expected_error_message)
258
247
  end
259
248
  end
260
249
 
261
-
262
- it "should accept --dry-run option" do
250
+ it "accepts --dry-run option" do
263
251
  config.parse!(%w{--dry-run})
264
- config.options[:dry_run].should be_true
252
+
253
+ expect(config.options[:dry_run]).to be true
265
254
  end
266
255
 
267
- it "should accept --no-source option" do
256
+ it "accepts --no-source option" do
268
257
  config.parse!(%w{--no-source})
269
258
 
270
- config.options[:source].should be_false
259
+ expect(config.options[:source]).to be false
271
260
  end
272
261
 
273
- it "should accept --no-snippets option" do
262
+ it "accepts --no-snippets option" do
274
263
  config.parse!(%w{--no-snippets})
275
264
 
276
- config.options[:snippets].should be_false
265
+ expect(config.options[:snippets]).to be false
277
266
  end
278
267
 
279
- it "should set snippets and source to false with --quiet option" do
268
+ it "sets snippets and source to false with --quiet option" do
280
269
  config.parse!(%w{--quiet})
281
270
 
282
- config.options[:snippets].should be_false
283
- config.options[:source].should be_false
271
+ expect(config.options[:snippets]).to be false
272
+ expect(config.options[:source]).to be false
284
273
  end
285
274
 
286
- it "should accept --verbose option" do
275
+ it "accepts --verbose option" do
287
276
  config.parse!(%w{--verbose})
288
277
 
289
- config.options[:verbose].should be_true
278
+ expect(config.options[:verbose]).to be true
290
279
  end
291
280
 
292
- it "should accept --out option" do
281
+ it "accepts --out option" do
293
282
  config.parse!(%w{--out jalla.txt})
294
- config.formats.should == [['pretty', 'jalla.txt']]
283
+
284
+ expect(config.formats).to eq [['pretty', 'jalla.txt']]
295
285
  end
296
286
 
297
- it "should accept multiple --out options" do
287
+ it "accepts multiple --out options" do
298
288
  config.parse!(%w{--format progress --out file1 --out file2})
299
- config.formats.should == [['progress', 'file2']]
289
+
290
+ expect(config.formats).to eq [['progress', 'file2']]
300
291
  end
301
292
 
302
- it "should accept multiple --format options and put the STDOUT one first so progress is seen" do
293
+ it "accepts multiple --format options and put the STDOUT one first so progress is seen" do
303
294
  config.parse!(%w{--format pretty --out pretty.txt --format progress})
304
- config.formats.should == [['progress', out], ['pretty', 'pretty.txt']]
295
+
296
+ expect(config.formats).to eq [['progress', out], ['pretty', 'pretty.txt']]
305
297
  end
306
298
 
307
- it "should not accept multiple --format options when both use implicit STDOUT" do
308
- lambda do
309
- config.parse!(%w{--format pretty --format progress})
310
- end.should raise_error("All but one formatter must use --out, only one can print to each stream (or STDOUT)")
299
+ it "does not accept multiple --format options when both use implicit STDOUT" do
300
+ expect(-> { config.parse!(%w{--format pretty --format progress}) }).to raise_error("All but one formatter must use --out, only one can print to each stream (or STDOUT)")
311
301
  end
312
302
 
313
- it "should accept same --format options with implicit STDOUT, and keep only one" do
303
+ it "accepts same --format options with implicit STDOUT, and keep only one" do
314
304
  config.parse!(%w{--format pretty --format pretty})
315
- config.formats.should == [["pretty", out]]
305
+
306
+ expect(config.formats).to eq [["pretty", out]]
316
307
  end
317
308
 
318
- it "should not accept multiple --out streams pointing to the same place" do
319
- lambda do
320
- config.parse!(%w{--format pretty --out file1 --format progress --out file1})
321
- end.should raise_error("All but one formatter must use --out, only one can print to each stream (or STDOUT)")
309
+ it "does not accept multiple --out streams pointing to the same place" do
310
+ expect(-> { config.parse!(%w{--format pretty --out file1 --format progress --out file1}) }).to raise_error("All but one formatter must use --out, only one can print to each stream (or STDOUT)")
322
311
  end
323
312
 
324
- it "should associate --out to previous --format" do
313
+ it "associates --out to previous --format" do
325
314
  config.parse!(%w{--format progress --out file1 --format profile --out file2})
326
- config.formats.should == [["progress", "file1"], ["profile" ,"file2"]]
315
+
316
+ expect(config.formats).to eq [["progress", "file1"], ["profile" ,"file2"]]
327
317
  end
328
318
 
329
- it "should accept same --format options with same --out streams and keep only one" do
319
+ it "accepts same --format options with same --out streams and keep only one" do
330
320
  config.parse!(%w{--format html --out file --format pretty --format html --out file})
331
- config.formats.should == [["pretty", out], ["html", "file"]]
321
+
322
+ expect(config.formats).to eq [["pretty", out], ["html", "file"]]
332
323
  end
333
324
 
334
- it "should accept same --format options with different --out streams" do
325
+ it "accepts same --format options with different --out streams" do
335
326
  config.parse!(%w{--format html --out file1 --format html --out file2})
336
- config.formats.should == [["html", "file1"], ["html", "file2"]]
327
+
328
+ expect(config.formats).to eq [["html", "file1"], ["html", "file2"]]
337
329
  end
338
330
 
339
- it "should accept --color option" do
340
- Cucumber::Term::ANSIColor.should_receive(:coloring=).with(true)
331
+ it "accepts --color option" do
332
+ expect(Cucumber::Term::ANSIColor).to receive(:coloring=).with(true)
333
+
341
334
  config.parse!(['--color'])
342
335
  end
343
336
 
344
- it "should accept --no-color option" do
345
- Cucumber::Term::ANSIColor.should_receive(:coloring=).with(false)
337
+ it "accepts --no-color option" do
338
+ expect(Cucumber::Term::ANSIColor).to receive(:coloring=).with(false)
339
+
346
340
  config = Configuration.new(StringIO.new)
347
341
  config.parse!(['--no-color'])
348
342
  end
@@ -352,12 +346,12 @@ END_OF_MESSAGE
352
346
  Cucumber.use_full_backtrace = false
353
347
  end
354
348
 
355
- it "should show full backtrace when --backtrace is present" do
356
- config = Main.new(['--backtrace'])
349
+ it "shows full backtrace when --backtrace is present" do
350
+ Main.new(['--backtrace'])
357
351
  begin
358
- "x".should == "y"
359
- rescue => e
360
- e.backtrace[0].should_not == "#{__FILE__}:#{__LINE__ - 2}"
352
+ expect("x").to eq "y"
353
+ rescue RSpec::Expectations::ExpectationNotMetError => e
354
+ expect(e.backtrace[0]).not_to eq "#{__FILE__}:#{__LINE__ - 2}"
361
355
  end
362
356
  end
363
357
 
@@ -366,72 +360,57 @@ END_OF_MESSAGE
366
360
  end
367
361
  end
368
362
 
369
- it "should accept multiple --name options" do
363
+ it "accepts multiple --name options" do
370
364
  config.parse!(['--name', "User logs in", '--name', "User signs up"])
371
365
 
372
- config.options[:name_regexps].should include(/User logs in/)
373
- config.options[:name_regexps].should include(/User signs up/)
366
+ expect(config.options[:name_regexps]).to include(/User logs in/)
367
+ expect(config.options[:name_regexps]).to include(/User signs up/)
374
368
  end
375
369
 
376
- it "should accept multiple -n options" do
370
+ it "accepts multiple -n options" do
377
371
  config.parse!(['-n', "User logs in", '-n', "User signs up"])
378
372
 
379
- config.options[:name_regexps].should include(/User logs in/)
380
- config.options[:name_regexps].should include(/User signs up/)
373
+ expect(config.options[:name_regexps]).to include(/User logs in/)
374
+ expect(config.options[:name_regexps]).to include(/User signs up/)
381
375
  end
382
376
 
383
- it "should preserve the order of the feature files" do
377
+ it "preserves the order of the feature files" do
384
378
  config.parse!(%w{b.feature c.feature a.feature})
385
379
 
386
- config.feature_files.should == ["b.feature", "c.feature", "a.feature"]
380
+ expect(config.feature_files).to eq ["b.feature", "c.feature", "a.feature"]
387
381
  end
388
382
 
389
- it "should search for all features in the specified directory" do
390
- File.stub(:directory?).and_return(true)
391
- Dir.stub(:[]).with("feature_directory/**/*.feature").
392
- and_return(["cucumber.feature"])
383
+ it "searchs for all features in the specified directory" do
384
+ allow(File).to receive(:directory?) { true }
385
+ allow(Dir).to receive(:[]).with("feature_directory/**/*.feature") { ["cucumber.feature"] }
393
386
 
394
387
  config.parse!(%w{feature_directory/})
395
388
 
396
- config.feature_files.should == ["cucumber.feature"]
389
+ expect(config.feature_files).to eq ["cucumber.feature"]
397
390
  end
398
391
 
399
392
  it "defaults to the features directory when no feature file are provided" do
400
- File.stub(:directory?).and_return(true)
401
- Dir.stub(:[]).with("features/**/*.feature").
402
- and_return(["cucumber.feature"])
393
+ allow(File).to receive(:directory?) { true }
394
+ allow(Dir).to receive(:[]).with("features/**/*.feature") { ["cucumber.feature"] }
403
395
 
404
396
  config.parse!(%w{})
405
397
 
406
- config.feature_files.should == ["cucumber.feature"]
407
- end
408
-
409
- it "should get the feature files from the rerun file" do
410
- File.stub(:directory?).and_return(false)
411
- File.stub(:file?).and_return(true)
412
- IO.stub(:read).and_return(
413
- "cucumber.feature:1:3 cucumber space.feature:134 domain folder/cuke.feature:1 domain folder/different cuke:4:5" )
414
-
415
- config.parse!(%w{@rerun.txt})
416
-
417
- config.feature_files.should == [
418
- "cucumber.feature:1:3",
419
- "cucumber space.feature:134",
420
- "domain folder/cuke.feature:1",
421
- "domain folder/different cuke:4:5"]
398
+ expect(config.feature_files).to eq ["cucumber.feature"]
422
399
  end
423
400
 
424
- it "should allow specifying environment variables on the command line" do
401
+ it "allows specifying environment variables on the command line" do
425
402
  config.parse!(["foo=bar"])
426
- ENV["foo"].should == "bar"
427
- config.feature_files.should_not include('foo=bar')
403
+
404
+ expect(ENV["foo"]).to eq "bar"
405
+ expect(config.feature_files).not_to include('foo=bar')
428
406
  end
429
407
 
430
- it "should allow specifying environment variables in profiles" do
408
+ it "allows specifying environment variables in profiles" do
431
409
  given_cucumber_yml_defined_as({'selenium' => 'RAILS_ENV=selenium'})
432
410
  config.parse!(["--profile", "selenium"])
433
- ENV["RAILS_ENV"].should == "selenium"
434
- config.feature_files.should_not include('RAILS_ENV=selenium')
411
+
412
+ expect(ENV["RAILS_ENV"]).to eq "selenium"
413
+ expect(config.feature_files).not_to include('RAILS_ENV=selenium')
435
414
  end
436
415
 
437
416
  describe "#tag_expression" do
@@ -439,47 +418,69 @@ END_OF_MESSAGE
439
418
 
440
419
  it "returns an empty expression when no tags are specified" do
441
420
  config.parse!([])
442
- config.tag_expression.should be_empty
421
+
422
+ expect(config.tag_expression).to be_empty
443
423
  end
444
424
 
445
425
  it "returns an expression when tags are specified" do
446
426
  config.parse!(['--tags','@foo'])
447
- config.tag_expression.should_not be_empty
427
+
428
+ expect(config.tag_expression).not_to be_empty
429
+ end
430
+ end
431
+
432
+ describe '#tag_limits' do
433
+ it "returns an empty hash when no limits are specified" do
434
+ config.parse!([])
435
+
436
+ expect(config.tag_limits).to eq({ })
437
+ end
438
+
439
+ it "returns a hash of limits when limits are specified" do
440
+ config.parse!(['--tags','@foo:1'])
441
+
442
+ expect(config.tag_limits).to eq({ "@foo" => 1 })
448
443
  end
449
444
  end
450
445
 
451
446
  describe "#dry_run?" do
452
447
  it "returns true when --dry-run was specified on in the arguments" do
453
448
  config.parse!(['--dry-run'])
454
- config.dry_run?.should be_true
449
+
450
+ expect(config.dry_run?).to be true
455
451
  end
456
452
 
457
453
  it "returns true when --dry-run was specified in yaml file" do
458
454
  given_cucumber_yml_defined_as({'default' => '--dry-run'})
459
455
  config.parse!([])
460
- config.dry_run?.should be_true
456
+
457
+ expect(config.dry_run?).to be true
461
458
  end
462
459
 
463
460
  it "returns false by default" do
464
461
  config.parse!([])
465
- config.dry_run?.should be_false
462
+
463
+ expect(config.dry_run?).to be false
466
464
  end
467
465
  end
468
466
 
469
467
  describe "#snippet_type" do
470
468
  it "returns the snippet type when it was set" do
471
469
  config.parse!(["--snippet-type", "classic"])
472
- config.snippet_type.should eql :classic
470
+
471
+ expect(config.snippet_type).to eq :classic
473
472
  end
474
473
 
475
474
  it "returns the snippet type when it was set with shorthand option" do
476
475
  config.parse!(["-I", "classic"])
477
- config.snippet_type.should eql :classic
476
+
477
+ expect(config.snippet_type).to eq :classic
478
478
  end
479
479
 
480
480
  it "returns the default snippet type if it was not set" do
481
481
  config.parse!([])
482
- config.snippet_type.should eql :regexp
482
+
483
+ expect(config.snippet_type).to eq :regexp
483
484
  end
484
485
  end
485
486
  end