cucumber 2.0.0.rc.5 → 4.0.0.rc.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (527) hide show
  1. checksums.yaml +5 -5
  2. data/{History.md → CHANGELOG.md} +700 -264
  3. data/CONTRIBUTING.md +26 -23
  4. data/LICENSE +1 -1
  5. data/README.md +25 -8
  6. data/bin/cucumber +3 -3
  7. data/lib/autotest/cucumber.rb +2 -0
  8. data/lib/autotest/cucumber_mixin.rb +45 -48
  9. data/lib/autotest/cucumber_rails.rb +2 -0
  10. data/lib/autotest/cucumber_rails_rspec.rb +2 -0
  11. data/lib/autotest/cucumber_rails_rspec2.rb +2 -0
  12. data/lib/autotest/cucumber_rspec.rb +2 -0
  13. data/lib/autotest/cucumber_rspec2.rb +2 -0
  14. data/lib/autotest/discover.rb +4 -2
  15. data/lib/cucumber.rb +3 -7
  16. data/lib/cucumber/cli/configuration.rb +23 -106
  17. data/lib/cucumber/cli/main.rb +45 -25
  18. data/lib/cucumber/cli/options.rb +410 -229
  19. data/lib/cucumber/cli/profile_loader.rb +64 -38
  20. data/lib/cucumber/cli/rerun_file.rb +31 -0
  21. data/lib/cucumber/configuration.rb +240 -8
  22. data/lib/cucumber/constantize.rb +9 -10
  23. data/lib/cucumber/core_ext/string.rb +3 -1
  24. data/lib/cucumber/deprecate.rb +30 -0
  25. data/lib/cucumber/encoding.rb +3 -1
  26. data/lib/cucumber/errors.rb +9 -8
  27. data/lib/cucumber/events.rb +40 -0
  28. data/lib/cucumber/events/gherkin_source_parsed.rb +11 -0
  29. data/lib/cucumber/events/gherkin_source_read.rb +14 -0
  30. data/lib/cucumber/events/step_activated.rb +26 -0
  31. data/lib/cucumber/events/step_definition_registered.rb +20 -0
  32. data/lib/cucumber/events/test_case_finished.rb +14 -0
  33. data/lib/cucumber/events/test_case_started.rb +11 -0
  34. data/lib/cucumber/events/test_run_finished.rb +11 -0
  35. data/lib/cucumber/events/test_run_started.rb +14 -0
  36. data/lib/cucumber/events/test_step_finished.rb +14 -0
  37. data/lib/cucumber/events/test_step_started.rb +11 -0
  38. data/lib/cucumber/file_specs.rb +8 -6
  39. data/lib/cucumber/filters.rb +4 -0
  40. data/lib/cucumber/filters/activate_steps.rb +48 -7
  41. data/lib/cucumber/filters/apply_after_hooks.rb +2 -0
  42. data/lib/cucumber/filters/apply_after_step_hooks.rb +2 -0
  43. data/lib/cucumber/filters/apply_around_hooks.rb +2 -0
  44. data/lib/cucumber/filters/apply_before_hooks.rb +2 -0
  45. data/lib/cucumber/filters/broadcast_test_run_started_event.rb +28 -0
  46. data/lib/cucumber/filters/gated_receiver.rb +2 -2
  47. data/lib/cucumber/filters/prepare_world.rb +7 -13
  48. data/lib/cucumber/filters/quit.rb +4 -7
  49. data/lib/cucumber/filters/randomizer.rb +10 -5
  50. data/lib/cucumber/filters/retry.rb +32 -0
  51. data/lib/cucumber/filters/tag_limits.rb +6 -5
  52. data/lib/cucumber/filters/tag_limits/test_case_index.rb +2 -2
  53. data/lib/cucumber/filters/tag_limits/verifier.rb +5 -7
  54. data/lib/cucumber/formatter/ansicolor.rb +39 -45
  55. data/lib/cucumber/formatter/ast_lookup.rb +165 -0
  56. data/lib/cucumber/formatter/backtrace_filter.rb +54 -0
  57. data/lib/cucumber/formatter/console.rb +93 -115
  58. data/lib/cucumber/formatter/console_counts.rb +39 -0
  59. data/lib/cucumber/formatter/console_issues.rb +61 -0
  60. data/lib/cucumber/formatter/duration.rb +3 -1
  61. data/lib/cucumber/formatter/duration_extractor.rb +31 -0
  62. data/lib/cucumber/formatter/fail_fast.rb +23 -0
  63. data/lib/cucumber/formatter/fanout.rb +4 -3
  64. data/lib/cucumber/formatter/ignore_missing_messages.rb +3 -4
  65. data/lib/cucumber/formatter/interceptor.rb +13 -14
  66. data/lib/cucumber/formatter/io.rb +10 -5
  67. data/lib/cucumber/formatter/json.rb +310 -8
  68. data/lib/cucumber/formatter/junit.rb +143 -173
  69. data/lib/cucumber/formatter/pretty.rb +359 -154
  70. data/lib/cucumber/formatter/progress.rb +78 -72
  71. data/lib/cucumber/formatter/rerun.rb +34 -17
  72. data/lib/cucumber/formatter/stepdefs.rb +3 -2
  73. data/lib/cucumber/formatter/steps.rb +7 -7
  74. data/lib/cucumber/formatter/summary.rb +50 -20
  75. data/lib/cucumber/formatter/unicode.rb +17 -18
  76. data/lib/cucumber/formatter/usage.rb +61 -54
  77. data/lib/cucumber/gherkin/data_table_parser.rb +44 -0
  78. data/lib/cucumber/gherkin/formatter/ansi_escapes.rb +97 -0
  79. data/lib/cucumber/gherkin/formatter/escaping.rb +19 -0
  80. data/lib/cucumber/gherkin/i18n.rb +17 -0
  81. data/lib/cucumber/gherkin/steps_parser.rb +42 -0
  82. data/lib/cucumber/{rb_support/rb_dsl.rb → glue/dsl.rb} +47 -26
  83. data/lib/cucumber/glue/hook.rb +51 -0
  84. data/lib/cucumber/glue/invoke_in_world.rb +65 -0
  85. data/lib/cucumber/glue/proto_world.rb +219 -0
  86. data/lib/cucumber/glue/registry_and_more.rb +192 -0
  87. data/lib/cucumber/glue/snippet.rb +205 -0
  88. data/lib/cucumber/glue/step_definition.rb +142 -0
  89. data/lib/cucumber/glue/world_factory.rb +21 -0
  90. data/lib/cucumber/hooks.rb +34 -21
  91. data/lib/cucumber/load_path.rb +2 -0
  92. data/lib/cucumber/multiline_argument.rb +10 -24
  93. data/lib/cucumber/multiline_argument/data_table.rb +157 -253
  94. data/lib/cucumber/multiline_argument/data_table/diff_matrices.rb +154 -0
  95. data/lib/cucumber/multiline_argument/doc_string.rb +3 -2
  96. data/lib/cucumber/platform.rb +7 -10
  97. data/lib/cucumber/project_initializer.rb +4 -3
  98. data/lib/cucumber/rake/task.rb +37 -29
  99. data/lib/cucumber/rspec/disable_option_parser.rb +11 -8
  100. data/lib/cucumber/rspec/doubles.rb +3 -1
  101. data/lib/cucumber/running_test_case.rb +15 -70
  102. data/lib/cucumber/runtime.rb +83 -81
  103. data/lib/cucumber/runtime/after_hooks.rb +10 -7
  104. data/lib/cucumber/runtime/before_hooks.rb +12 -6
  105. data/lib/cucumber/runtime/for_programming_languages.rb +14 -44
  106. data/lib/cucumber/runtime/step_hooks.rb +8 -4
  107. data/lib/cucumber/runtime/support_code.rb +46 -160
  108. data/lib/cucumber/runtime/user_interface.rb +15 -24
  109. data/lib/cucumber/step_definition_light.rb +10 -6
  110. data/lib/cucumber/step_definitions.rb +6 -4
  111. data/lib/cucumber/step_match.rb +58 -38
  112. data/lib/cucumber/step_match_search.rb +67 -0
  113. data/lib/cucumber/term/ansicolor.rb +40 -39
  114. data/lib/cucumber/unit.rb +2 -0
  115. data/lib/cucumber/version +1 -0
  116. data/{spec → lib}/simplecov_setup.rb +3 -1
  117. metadata +257 -621
  118. data/.coveralls.yml +0 -1
  119. data/.rspec +0 -1
  120. data/.ruby-gemset +0 -1
  121. data/.travis.yml +0 -18
  122. data/.yardopts +0 -1
  123. data/Gemfile +0 -11
  124. data/Rakefile +0 -22
  125. data/cucumber.gemspec +0 -50
  126. data/cucumber.yml +0 -20
  127. data/examples/i18n/README.textile +0 -3
  128. data/examples/i18n/Rakefile +0 -33
  129. data/examples/i18n/ar/Rakefile +0 -6
  130. data/examples/i18n/ar/features/addition.feature +0 -17
  131. data/examples/i18n/ar/features/step_definitions/calculator_steps.rb +0 -24
  132. data/examples/i18n/ar/lib/calculator.rb +0 -11
  133. data/examples/i18n/bg/Rakefile +0 -6
  134. data/examples/i18n/bg/features/addition.feature +0 -12
  135. data/examples/i18n/bg/features/consecutive_calculations.feature +0 -19
  136. data/examples/i18n/bg/features/division.feature +0 -17
  137. data/examples/i18n/bg/features/step_definitions/calculator_steps.rb +0 -24
  138. data/examples/i18n/bg/features/support/env.rb +0 -5
  139. data/examples/i18n/bg/features/support/world.rb +0 -8
  140. data/examples/i18n/bg/lib/calculator.rb +0 -24
  141. data/examples/i18n/ca/Rakefile +0 -6
  142. data/examples/i18n/ca/features/step_definitions/calculator_steps.rb +0 -21
  143. data/examples/i18n/ca/features/suma.feature +0 -17
  144. data/examples/i18n/ca/lib/calculadora.rb +0 -16
  145. data/examples/i18n/cs/Rakefile +0 -6
  146. data/examples/i18n/cs/features/addition.feature +0 -17
  147. data/examples/i18n/cs/features/division.feature +0 -11
  148. data/examples/i18n/cs/features/step_definitions/calculator_steps.rb +0 -24
  149. data/examples/i18n/cs/lib/calculator.rb +0 -14
  150. data/examples/i18n/da/Rakefile +0 -6
  151. data/examples/i18n/da/features/sammenlaegning.feature +0 -18
  152. data/examples/i18n/da/features/step_definitions/lommeregner_steps.rb +0 -24
  153. data/examples/i18n/da/lib/lommeregner.rb +0 -11
  154. data/examples/i18n/de/Rakefile +0 -6
  155. data/examples/i18n/de/features/addition.feature +0 -17
  156. data/examples/i18n/de/features/division.feature +0 -10
  157. data/examples/i18n/de/features/step_definitions/calculator_steps.rb +0 -24
  158. data/examples/i18n/de/lib/calculator.rb +0 -14
  159. data/examples/i18n/el/Rakefile +0 -6
  160. data/examples/i18n/el/features/addition.feature +0 -17
  161. data/examples/i18n/el/features/division.feature +0 -10
  162. data/examples/i18n/el/features/step_definitions/calculator_steps.rb +0 -24
  163. data/examples/i18n/el/lib/calculator.rb +0 -14
  164. data/examples/i18n/en-lol/Rakefile +0 -4
  165. data/examples/i18n/en-lol/features/step_definitions/cucumbrz_steps.rb +0 -16
  166. data/examples/i18n/en-lol/features/stuffing.feature +0 -8
  167. data/examples/i18n/en-lol/features/support/env.rb +0 -7
  168. data/examples/i18n/en-lol/lib/basket.rb +0 -12
  169. data/examples/i18n/en-lol/lib/belly.rb +0 -11
  170. data/examples/i18n/en/Rakefile +0 -6
  171. data/examples/i18n/en/features/addition.feature +0 -17
  172. data/examples/i18n/en/features/division.feature +0 -10
  173. data/examples/i18n/en/features/step_definitions/calculator_steps.rb +0 -24
  174. data/examples/i18n/en/lib/calculator.rb +0 -14
  175. data/examples/i18n/eo/Rakefile +0 -6
  176. data/examples/i18n/eo/features/adicio.feature +0 -17
  177. data/examples/i18n/eo/features/divido.feature +0 -10
  178. data/examples/i18n/eo/features/step_definitions/calculator_steps.rb +0 -24
  179. data/examples/i18n/eo/lib/calculator.rb +0 -14
  180. data/examples/i18n/es/Rakefile +0 -6
  181. data/examples/i18n/es/features/adicion.feature +0 -17
  182. data/examples/i18n/es/features/step_definitions/calculador_steps.rb +0 -21
  183. data/examples/i18n/es/lib/calculador.rb +0 -14
  184. data/examples/i18n/et/Rakefile +0 -6
  185. data/examples/i18n/et/features/jagamine.feature +0 -10
  186. data/examples/i18n/et/features/liitmine.feature +0 -17
  187. data/examples/i18n/et/features/step_definitions/kalkulaator_steps.rb +0 -24
  188. data/examples/i18n/et/lib/kalkulaator.rb +0 -14
  189. data/examples/i18n/fi/Rakefile +0 -6
  190. data/examples/i18n/fi/features/jakolasku.feature +0 -10
  191. data/examples/i18n/fi/features/step_definitions/laskin_steps.rb +0 -24
  192. data/examples/i18n/fi/features/yhteenlasku.feature +0 -17
  193. data/examples/i18n/fi/lib/laskin.rb +0 -14
  194. data/examples/i18n/fr/Rakefile +0 -8
  195. data/examples/i18n/fr/features/addition.feature +0 -18
  196. data/examples/i18n/fr/features/addition2.feature +0 -17
  197. data/examples/i18n/fr/features/step_definitions/calculatrice_steps.rb +0 -32
  198. data/examples/i18n/fr/features/support/env.rb +0 -5
  199. data/examples/i18n/fr/lib/calculatrice.rb +0 -10
  200. data/examples/i18n/he/Rakefile +0 -6
  201. data/examples/i18n/he/features/addition.feature +0 -17
  202. data/examples/i18n/he/features/division.feature +0 -10
  203. data/examples/i18n/he/features/step_definitions/calculator_steps.rb +0 -24
  204. data/examples/i18n/he/lib/calculator.rb +0 -15
  205. data/examples/i18n/hi/Rakefile +0 -6
  206. data/examples/i18n/hi/features/addition.feature +0 -16
  207. data/examples/i18n/hi/features/division.feature +0 -10
  208. data/examples/i18n/hi/features/step_definitions/calculator_steps.rb +0 -24
  209. data/examples/i18n/hi/lib/calculator.rb +0 -15
  210. data/examples/i18n/ht/Rakefile +0 -6
  211. data/examples/i18n/ht/features/adisyon.feature +0 -17
  212. data/examples/i18n/ht/features/divizyon.feature +0 -10
  213. data/examples/i18n/ht/features/step_definitions/kalkilatris_steps.rb +0 -25
  214. data/examples/i18n/ht/lib/kalkilatris.rb +0 -14
  215. data/examples/i18n/hu/Rakefile +0 -6
  216. data/examples/i18n/hu/features/osszeadas.feature +0 -17
  217. data/examples/i18n/hu/features/osztas.feature +0 -10
  218. data/examples/i18n/hu/features/step_definitions/calculator_steps.rb +0 -25
  219. data/examples/i18n/hu/lib/calculator.rb +0 -14
  220. data/examples/i18n/id/Rakefile +0 -6
  221. data/examples/i18n/id/features/addition.feature +0 -17
  222. data/examples/i18n/id/features/division.feature +0 -10
  223. data/examples/i18n/id/features/step_definitions/calculator_steps.rb +0 -24
  224. data/examples/i18n/id/lib/calculator.rb +0 -14
  225. data/examples/i18n/it/Rakefile +0 -6
  226. data/examples/i18n/it/features/somma.feature +0 -11
  227. data/examples/i18n/it/features/step_definitions/calcolatrice_steps.rb +0 -24
  228. data/examples/i18n/it/lib/calcolatrice.rb +0 -11
  229. data/examples/i18n/ja/Rakefile +0 -6
  230. data/examples/i18n/ja/features/addition.feature +0 -17
  231. data/examples/i18n/ja/features/division.feature +0 -10
  232. data/examples/i18n/ja/features/step_definitions/calculator_steps.rb +0 -19
  233. data/examples/i18n/ja/features/support/env.rb +0 -5
  234. data/examples/i18n/ja/lib/calculator.rb +0 -14
  235. data/examples/i18n/ko/Rakefile +0 -6
  236. data/examples/i18n/ko/features/addition.feature +0 -17
  237. data/examples/i18n/ko/features/division.feature +0 -11
  238. data/examples/i18n/ko/features/step_definitions/calculator_steps.rb +0 -24
  239. data/examples/i18n/ko/lib/calculator.rb +0 -14
  240. data/examples/i18n/lt/Rakefile +0 -6
  241. data/examples/i18n/lt/features/addition.feature +0 -17
  242. data/examples/i18n/lt/features/division.feature +0 -10
  243. data/examples/i18n/lt/features/step_definitions/calculator_steps.rb +0 -24
  244. data/examples/i18n/lt/lib/calculator.rb +0 -14
  245. data/examples/i18n/lv/Rakefile +0 -6
  246. data/examples/i18n/lv/features/addition.feature +0 -17
  247. data/examples/i18n/lv/features/division.feature +0 -10
  248. data/examples/i18n/lv/features/step_definitions/calculator_steps.rb +0 -24
  249. data/examples/i18n/lv/lib/calculator.rb +0 -14
  250. data/examples/i18n/no/Rakefile +0 -6
  251. data/examples/i18n/no/features/step_definitions/kalkulator_steps.rb +0 -17
  252. data/examples/i18n/no/features/summering.feature +0 -19
  253. data/examples/i18n/no/features/support/env.rb +0 -6
  254. data/examples/i18n/no/lib/kalkulator.rb +0 -11
  255. data/examples/i18n/pl/Rakefile +0 -6
  256. data/examples/i18n/pl/features/addition.feature +0 -17
  257. data/examples/i18n/pl/features/division.feature +0 -10
  258. data/examples/i18n/pl/features/step_definitions/calculator_steps.rb +0 -24
  259. data/examples/i18n/pl/features/support/env.rb +0 -5
  260. data/examples/i18n/pl/lib/calculator.rb +0 -14
  261. data/examples/i18n/pt/Rakefile +0 -6
  262. data/examples/i18n/pt/features/adicao.feature +0 -11
  263. data/examples/i18n/pt/features/step_definitions/calculadora_steps.rb +0 -20
  264. data/examples/i18n/pt/features/support/env.rb +0 -5
  265. data/examples/i18n/pt/lib/calculadora.rb +0 -10
  266. data/examples/i18n/ro/Rakefile +0 -6
  267. data/examples/i18n/ro/features/adunare.feature +0 -12
  268. data/examples/i18n/ro/features/step_definitions/calculator_steps.rb +0 -21
  269. data/examples/i18n/ro/lib/calculator.rb +0 -11
  270. data/examples/i18n/ru/Rakefile +0 -6
  271. data/examples/i18n/ru/features/addition.feature +0 -11
  272. data/examples/i18n/ru/features/consecutive_calculations.feature +0 -17
  273. data/examples/i18n/ru/features/division.feature +0 -16
  274. data/examples/i18n/ru/features/step_definitions/calculator_steps.rb +0 -19
  275. data/examples/i18n/ru/features/support/env.rb +0 -5
  276. data/examples/i18n/ru/features/support/world.rb +0 -8
  277. data/examples/i18n/ru/lib/calculator.rb +0 -24
  278. data/examples/i18n/sk/Rakefile +0 -6
  279. data/examples/i18n/sk/features/addition.feature +0 -17
  280. data/examples/i18n/sk/features/division.feature +0 -10
  281. data/examples/i18n/sk/features/step_definitions/calculator_steps.rb +0 -24
  282. data/examples/i18n/sk/lib/calculator.rb +0 -14
  283. data/examples/i18n/sr-Cyrl/Rakefile +0 -6
  284. data/examples/i18n/sr-Cyrl/features/sabiranje.feature +0 -18
  285. data/examples/i18n/sr-Cyrl/features/step_definitions/calculator_steps.rb +0 -20
  286. data/examples/i18n/sr-Cyrl/features/support/env.rb +0 -5
  287. data/examples/i18n/sr-Cyrl/lib/calculator.rb +0 -12
  288. data/examples/i18n/sr-Latn/Rakefile +0 -6
  289. data/examples/i18n/sr-Latn/features/sabiranje.feature +0 -18
  290. data/examples/i18n/sr-Latn/features/step_definitions/calculator_steps.rb +0 -24
  291. data/examples/i18n/sr-Latn/lib/calculator.rb +0 -12
  292. data/examples/i18n/sv/Rakefile +0 -6
  293. data/examples/i18n/sv/features/step_definitions/kalkulator_steps.rb +0 -24
  294. data/examples/i18n/sv/features/summering.feature +0 -18
  295. data/examples/i18n/sv/lib/kalkulator.rb +0 -11
  296. data/examples/i18n/tr/Rakefile +0 -6
  297. data/examples/i18n/tr/features/bolme.feature +0 -10
  298. data/examples/i18n/tr/features/step_definitions/hesap_makinesi_adimlari.rb +0 -24
  299. data/examples/i18n/tr/features/toplama.feature +0 -18
  300. data/examples/i18n/tr/lib/hesap_makinesi.rb +0 -15
  301. data/examples/i18n/uk/Rakefile +0 -6
  302. data/examples/i18n/uk/features/addition.feature +0 -11
  303. data/examples/i18n/uk/features/consecutive_calculations.feature +0 -17
  304. data/examples/i18n/uk/features/division.feature +0 -16
  305. data/examples/i18n/uk/features/step_definitions/calculator_steps.rb +0 -19
  306. data/examples/i18n/uk/features/support/env.rb +0 -5
  307. data/examples/i18n/uk/features/support/world.rb +0 -8
  308. data/examples/i18n/uk/lib/calculator.rb +0 -24
  309. data/examples/i18n/uz/Rakefile +0 -6
  310. data/examples/i18n/uz/features/addition.feature +0 -10
  311. data/examples/i18n/uz/features/consecutive_calculations.feature +0 -17
  312. data/examples/i18n/uz/features/division.feature +0 -17
  313. data/examples/i18n/uz/features/step_definitions/calculator_steps.rb +0 -19
  314. data/examples/i18n/uz/features/support/env.rb +0 -5
  315. data/examples/i18n/uz/features/support/world.rb +0 -8
  316. data/examples/i18n/uz/lib/calculator.rb +0 -24
  317. data/examples/i18n/zh-CN/Rakefile +0 -4
  318. data/examples/i18n/zh-CN/features/addition.feature +0 -18
  319. data/examples/i18n/zh-CN/features/step_definitions/calculator_steps.rb +0 -26
  320. data/examples/i18n/zh-CN/lib/calculator.rb +0 -10
  321. data/examples/i18n/zh-TW/Rakefile +0 -4
  322. data/examples/i18n/zh-TW/features/addition.feature +0 -17
  323. data/examples/i18n/zh-TW/features/division.feature +0 -11
  324. data/examples/i18n/zh-TW/features/step_definitions/calculator_steps.rb +0 -24
  325. data/examples/i18n/zh-TW/lib/calculator.rb +0 -14
  326. data/examples/rspec_doubles/Rakefile +0 -4
  327. data/examples/rspec_doubles/features/mocking.feature +0 -9
  328. data/examples/rspec_doubles/features/step_definitions/calvin_steps.rb +0 -19
  329. data/examples/rspec_doubles/features/support/env.rb +0 -12
  330. data/examples/sinatra/README.textile +0 -13
  331. data/examples/sinatra/Rakefile +0 -6
  332. data/examples/sinatra/app.rb +0 -14
  333. data/examples/sinatra/features/add.feature +0 -11
  334. data/examples/sinatra/features/step_definitions/add_steps.rb +0 -15
  335. data/examples/sinatra/features/support/env.rb +0 -10
  336. data/examples/sinatra/views/add.erb +0 -7
  337. data/examples/sinatra/views/layout.erb +0 -8
  338. data/examples/tcl/README.textile +0 -11
  339. data/examples/tcl/Rakefile +0 -6
  340. data/examples/tcl/features/fibonnacci.feature +0 -17
  341. data/examples/tcl/features/step_definitions/fib_steps.rb +0 -7
  342. data/examples/tcl/features/support/env.rb +0 -6
  343. data/examples/tcl/src/fib.tcl +0 -3
  344. data/examples/test_unit/Gemfile +0 -4
  345. data/examples/test_unit/Rakefile +0 -6
  346. data/examples/test_unit/features/step_definitions/test_unit_steps.rb +0 -20
  347. data/examples/test_unit/features/test_unit.feature +0 -9
  348. data/examples/watir/README.textile +0 -16
  349. data/examples/watir/Rakefile +0 -12
  350. data/examples/watir/cucumber.yml +0 -1
  351. data/examples/watir/features/search.feature +0 -12
  352. data/examples/watir/features/step_definitions/search_steps.rb +0 -26
  353. data/examples/watir/features/support/env.rb +0 -35
  354. data/examples/watir/features/support/screenshots.rb +0 -47
  355. data/features/docs/api/list_step_defs_as_json.feature +0 -50
  356. data/features/docs/api/run_cli_main_with_existing_runtime.feature +0 -29
  357. data/features/docs/cli/backtraces.feature +0 -36
  358. data/features/docs/cli/dry_run.feature +0 -68
  359. data/features/docs/cli/exclude_files.feature +0 -19
  360. data/features/docs/cli/execute_with_tag_filter.feature +0 -117
  361. data/features/docs/cli/randomize.feature +0 -46
  362. data/features/docs/cli/require.feature +0 -27
  363. data/features/docs/cli/run_scenarios_matching_name.feature +0 -104
  364. data/features/docs/cli/run_specific_scenarios.feature +0 -130
  365. data/features/docs/cli/showing_differences.feature +0 -43
  366. data/features/docs/cli/specifying_multiple_formatters.feature +0 -44
  367. data/features/docs/cli/strict_mode.feature +0 -64
  368. data/features/docs/defining_steps/nested_steps.feature +0 -178
  369. data/features/docs/defining_steps/nested_steps_i18n.feature +0 -34
  370. data/features/docs/defining_steps/nested_steps_with_second_arg.feature +0 -73
  371. data/features/docs/defining_steps/one_line_step_definitions.feature +0 -65
  372. data/features/docs/defining_steps/printing_messages.feature +0 -148
  373. data/features/docs/defining_steps/skip_scenario.feature +0 -62
  374. data/features/docs/defining_steps/snippets.feature +0 -56
  375. data/features/docs/defining_steps/table_diffing.feature +0 -50
  376. data/features/docs/defining_steps/transforms.feature +0 -63
  377. data/features/docs/exception_in_after_hook.feature +0 -126
  378. data/features/docs/exception_in_after_step_hook.feature +0 -102
  379. data/features/docs/exception_in_around_hook.feature +0 -80
  380. data/features/docs/exception_in_before_hook.feature +0 -96
  381. data/features/docs/extending_cucumber/custom_filter.feature +0 -29
  382. data/features/docs/extending_cucumber/custom_formatter.feature +0 -94
  383. data/features/docs/formatters/debug_formatter.feature +0 -47
  384. data/features/docs/formatters/formatter_step_file_colon_line.feature +0 -44
  385. data/features/docs/formatters/html_formatter.feature +0 -90
  386. data/features/docs/formatters/json_formatter.feature +0 -760
  387. data/features/docs/formatters/junit_formatter.feature +0 -316
  388. data/features/docs/formatters/pretty_formatter.feature +0 -73
  389. data/features/docs/formatters/progress_formatter.feature +0 -31
  390. data/features/docs/formatters/rerun_formatter.feature +0 -136
  391. data/features/docs/formatters/usage_formatter.feature +0 -102
  392. data/features/docs/getting_started.feature +0 -27
  393. data/features/docs/gherkin/background.feature +0 -559
  394. data/features/docs/gherkin/doc_strings.feature +0 -74
  395. data/features/docs/gherkin/expand_option_for_outlines.feature +0 -46
  396. data/features/docs/gherkin/language_from_header.feature +0 -32
  397. data/features/docs/gherkin/language_help.feature +0 -37
  398. data/features/docs/gherkin/outlines.feature +0 -158
  399. data/features/docs/gherkin/unicode_table.feature +0 -32
  400. data/features/docs/gherkin/using_descriptions.feature +0 -88
  401. data/features/docs/gherkin/using_star_notation.feature +0 -37
  402. data/features/docs/iso-8859-1.feature +0 -6
  403. data/features/docs/post_configuration_hook.feature +0 -49
  404. data/features/docs/profiles.feature +0 -120
  405. data/features/docs/rake_task.feature +0 -141
  406. data/features/docs/raketask.feature +0 -44
  407. data/features/docs/wire_protocol/erb_configuration.feature +0 -56
  408. data/features/docs/wire_protocol/handle_unexpected_response.feature +0 -30
  409. data/features/docs/wire_protocol/invoke_message.feature +0 -216
  410. data/features/docs/wire_protocol/readme.md +0 -26
  411. data/features/docs/wire_protocol/snippets_message.feature +0 -51
  412. data/features/docs/wire_protocol/step_matches_message.feature +0 -81
  413. data/features/docs/wire_protocol/table_diffing.feature +0 -126
  414. data/features/docs/wire_protocol/tags.feature +0 -87
  415. data/features/docs/wire_protocol/timeouts.feature +0 -64
  416. data/features/docs/work_in_progress.feature +0 -154
  417. data/features/docs/writing_support_code/after_hooks.feature +0 -56
  418. data/features/docs/writing_support_code/around_hooks.feature +0 -260
  419. data/features/docs/writing_support_code/before_hook.feature +0 -65
  420. data/features/docs/writing_support_code/hook_order.feature +0 -61
  421. data/features/docs/writing_support_code/load_path.feature +0 -17
  422. data/features/docs/writing_support_code/state.feature +0 -32
  423. data/features/docs/writing_support_code/tagged_hooks.feature +0 -95
  424. data/features/lib/step_definitions/aruba_steps.rb +0 -22
  425. data/features/lib/step_definitions/cucumber_steps.rb +0 -50
  426. data/features/lib/step_definitions/iso-8859-1_steps.rb +0 -12
  427. data/features/lib/step_definitions/json_steps.rb +0 -7
  428. data/features/lib/step_definitions/junit_steps.rb +0 -13
  429. data/features/lib/step_definitions/language_steps.rb +0 -8
  430. data/features/lib/step_definitions/profile_steps.rb +0 -15
  431. data/features/lib/step_definitions/ruby_steps.rb +0 -3
  432. data/features/lib/step_definitions/wire_steps.rb +0 -58
  433. data/features/lib/support/env.rb +0 -21
  434. data/features/lib/support/fake_wire_server.rb +0 -80
  435. data/features/lib/support/feature_factory.rb +0 -67
  436. data/features/lib/support/normalise_output.rb +0 -33
  437. data/gem_tasks/contributors.rake +0 -15
  438. data/gem_tasks/cov.rake +0 -5
  439. data/gem_tasks/cucumber.rake +0 -25
  440. data/gem_tasks/downloads.rb +0 -7
  441. data/gem_tasks/environment.rake +0 -7
  442. data/gem_tasks/examples.rake +0 -11
  443. data/gem_tasks/fix_cr_lf.rake +0 -10
  444. data/gem_tasks/flog.rake +0 -4
  445. data/gem_tasks/rspec.rake +0 -6
  446. data/gem_tasks/sass.rake +0 -4
  447. data/gem_tasks/stats +0 -16
  448. data/gem_tasks/versions.txt +0 -74
  449. data/lib/cucumber/ast.rb +0 -13
  450. data/lib/cucumber/core_ext/instance_exec.rb +0 -70
  451. data/lib/cucumber/core_ext/proc.rb +0 -36
  452. data/lib/cucumber/formatter/cucumber.css +0 -285
  453. data/lib/cucumber/formatter/cucumber.sass +0 -247
  454. data/lib/cucumber/formatter/debug.rb +0 -35
  455. data/lib/cucumber/formatter/gherkin_formatter_adapter.rb +0 -204
  456. data/lib/cucumber/formatter/gpretty.rb +0 -24
  457. data/lib/cucumber/formatter/html.rb +0 -674
  458. data/lib/cucumber/formatter/jquery-min.js +0 -154
  459. data/lib/cucumber/formatter/json_pretty.rb +0 -10
  460. data/lib/cucumber/formatter/legacy_api/adapter.rb +0 -1060
  461. data/lib/cucumber/formatter/legacy_api/ast.rb +0 -376
  462. data/lib/cucumber/formatter/legacy_api/results.rb +0 -51
  463. data/lib/cucumber/formatter/legacy_api/runtime_facade.rb +0 -30
  464. data/lib/cucumber/language_support.rb +0 -30
  465. data/lib/cucumber/language_support/language_methods.rb +0 -71
  466. data/lib/cucumber/rb_support/rb_hook.rb +0 -18
  467. data/lib/cucumber/rb_support/rb_language.rb +0 -160
  468. data/lib/cucumber/rb_support/rb_step_definition.rb +0 -131
  469. data/lib/cucumber/rb_support/rb_transform.rb +0 -59
  470. data/lib/cucumber/rb_support/rb_world.rb +0 -142
  471. data/lib/cucumber/rb_support/regexp_argument_matcher.rb +0 -21
  472. data/lib/cucumber/rb_support/snippet.rb +0 -149
  473. data/lib/cucumber/wire_support/configuration.rb +0 -38
  474. data/lib/cucumber/wire_support/connection.rb +0 -61
  475. data/lib/cucumber/wire_support/request_handler.rb +0 -32
  476. data/lib/cucumber/wire_support/wire_exception.rb +0 -32
  477. data/lib/cucumber/wire_support/wire_language.rb +0 -68
  478. data/lib/cucumber/wire_support/wire_packet.rb +0 -34
  479. data/lib/cucumber/wire_support/wire_protocol.rb +0 -43
  480. data/lib/cucumber/wire_support/wire_protocol/requests.rb +0 -133
  481. data/lib/cucumber/wire_support/wire_step_definition.rb +0 -19
  482. data/spec/cucumber/cli/configuration_spec.rb +0 -503
  483. data/spec/cucumber/cli/main_spec.rb +0 -105
  484. data/spec/cucumber/cli/options_spec.rb +0 -335
  485. data/spec/cucumber/cli/profile_loader_spec.rb +0 -46
  486. data/spec/cucumber/configuration_spec.rb +0 -23
  487. data/spec/cucumber/constantize_spec.rb +0 -19
  488. data/spec/cucumber/core_ext/proc_spec.rb +0 -69
  489. data/spec/cucumber/file_specs_spec.rb +0 -60
  490. data/spec/cucumber/filters/activate_steps_spec.rb +0 -57
  491. data/spec/cucumber/filters/gated_receiver_spec.rb +0 -47
  492. data/spec/cucumber/filters/tag_limits/test_case_index_spec.rb +0 -38
  493. data/spec/cucumber/filters/tag_limits/verifier_spec.rb +0 -57
  494. data/spec/cucumber/filters/tag_limits_spec.rb +0 -59
  495. data/spec/cucumber/formatter/ansicolor_spec.rb +0 -32
  496. data/spec/cucumber/formatter/debug_spec.rb +0 -64
  497. data/spec/cucumber/formatter/duration_spec.rb +0 -22
  498. data/spec/cucumber/formatter/html_spec.rb +0 -459
  499. data/spec/cucumber/formatter/interceptor_spec.rb +0 -136
  500. data/spec/cucumber/formatter/junit_spec.rb +0 -252
  501. data/spec/cucumber/formatter/legacy_api/adapter_spec.rb +0 -2090
  502. data/spec/cucumber/formatter/pretty_spec.rb +0 -823
  503. data/spec/cucumber/formatter/progress_spec.rb +0 -85
  504. data/spec/cucumber/formatter/rerun_spec.rb +0 -107
  505. data/spec/cucumber/formatter/spec_helper.rb +0 -67
  506. data/spec/cucumber/hooks_spec.rb +0 -30
  507. data/spec/cucumber/multiline_argument/data_table_spec.rb +0 -514
  508. data/spec/cucumber/project_initializer_spec.rb +0 -87
  509. data/spec/cucumber/rake/forked_spec.rb +0 -53
  510. data/spec/cucumber/rb_support/rb_language_spec.rb +0 -279
  511. data/spec/cucumber/rb_support/rb_step_definition_spec.rb +0 -170
  512. data/spec/cucumber/rb_support/rb_transform_spec.rb +0 -46
  513. data/spec/cucumber/rb_support/regexp_argument_matcher_spec.rb +0 -22
  514. data/spec/cucumber/rb_support/snippet_spec.rb +0 -137
  515. data/spec/cucumber/running_test_case_spec.rb +0 -83
  516. data/spec/cucumber/runtime/for_programming_languages_spec.rb +0 -36
  517. data/spec/cucumber/runtime/support_code_spec.rb +0 -123
  518. data/spec/cucumber/runtime_spec.rb +0 -46
  519. data/spec/cucumber/sell_cucumbers.feature +0 -19
  520. data/spec/cucumber/step_match_spec.rb +0 -79
  521. data/spec/cucumber/wire_support/configuration_spec.rb +0 -64
  522. data/spec/cucumber/wire_support/connection_spec.rb +0 -64
  523. data/spec/cucumber/wire_support/wire_exception_spec.rb +0 -50
  524. data/spec/cucumber/wire_support/wire_language_spec.rb +0 -46
  525. data/spec/cucumber/wire_support/wire_packet_spec.rb +0 -44
  526. data/spec/cucumber/world/pending_spec.rb +0 -46
  527. data/spec/spec_helper.rb +0 -29
@@ -0,0 +1,54 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'cucumber/platform'
4
+
5
+ module Cucumber
6
+ module Formatter
7
+ @backtrace_filters = %w[
8
+ /vendor/rails
9
+ lib/cucumber
10
+ bin/cucumber:
11
+ lib/rspec
12
+ gems/
13
+ site_ruby/
14
+ minitest
15
+ test/unit
16
+ .gem/ruby
17
+ bin/bundle
18
+ ]
19
+
20
+ @backtrace_filters << RbConfig::CONFIG['rubyarchdir'] if RbConfig::CONFIG['rubyarchdir']
21
+ @backtrace_filters << RbConfig::CONFIG['rubylibdir'] if RbConfig::CONFIG['rubylibdir']
22
+
23
+ @backtrace_filters << 'org/jruby/' if ::Cucumber::JRUBY
24
+
25
+ BACKTRACE_FILTER_PATTERNS = Regexp.new(@backtrace_filters.join('|'))
26
+
27
+ class BacktraceFilter
28
+ def initialize(exception)
29
+ @exception = exception
30
+ end
31
+
32
+ def exception
33
+ return @exception if ::Cucumber.use_full_backtrace
34
+
35
+ pwd_pattern = /#{::Regexp.escape(::Dir.pwd)}\//m # rubocop:disable Style/RegexpLiteral
36
+ backtrace = @exception.backtrace.map { |line| line.gsub(pwd_pattern, './') }
37
+
38
+ filtered = (backtrace || []).reject do |line|
39
+ line =~ BACKTRACE_FILTER_PATTERNS
40
+ end
41
+
42
+ if ::ENV['CUCUMBER_TRUNCATE_OUTPUT']
43
+ # Strip off file locations
44
+ filtered = filtered.map do |line|
45
+ line =~ /(.*):in `/ ? Regexp.last_match(1) : line
46
+ end
47
+ end
48
+
49
+ @exception.set_backtrace(filtered)
50
+ @exception
51
+ end
52
+ end
53
+ end
54
+ end
@@ -1,10 +1,11 @@
1
+ # frozen_string_literal: true
2
+
1
3
  require 'cucumber/formatter/ansicolor'
2
4
  require 'cucumber/formatter/duration'
3
- require 'cucumber/formatter/summary'
5
+ require 'cucumber/gherkin/i18n'
4
6
 
5
7
  module Cucumber
6
8
  module Formatter
7
-
8
9
  # This module contains helper methods that are used by formatters that
9
10
  # print output to the terminal.
10
11
  #
@@ -28,15 +29,14 @@ module Cucumber
28
29
  module Console
29
30
  extend ANSIColor
30
31
  include Duration
31
- include Summary
32
32
 
33
33
  def format_step(keyword, step_match, status, source_indent)
34
34
  comment = if source_indent
35
- c = ('# ' + step_match.file_colon_line).indent(source_indent)
36
- format_string(c, :comment)
37
- else
38
- ''
39
- end
35
+ c = ('# ' + step_match.location.to_s).indent(source_indent)
36
+ format_string(c, :comment)
37
+ else
38
+ ''
39
+ end
40
40
 
41
41
  format = format_for(status, :param)
42
42
  line = keyword + step_match.format_args(format) + comment
@@ -46,7 +46,7 @@ module Cucumber
46
46
  def format_string(o, status)
47
47
  fmt = format_for(status)
48
48
  o.to_s.split("\n").map do |line|
49
- if Proc === fmt
49
+ if Proc == fmt.class
50
50
  fmt.call(line)
51
51
  else
52
52
  fmt % line
@@ -54,101 +54,81 @@ module Cucumber
54
54
  end.join("\n")
55
55
  end
56
56
 
57
- def print_steps(status)
58
- print_elements(runtime.steps(status), status, 'steps')
57
+ def print_elements(elements, status, kind)
58
+ return if elements.empty?
59
+
60
+ element_messages = element_messages(elements, status)
61
+ print_element_messages(element_messages, status, kind)
59
62
  end
60
63
 
61
- def print_elements(elements, status, kind)
62
- if elements.any?
64
+ def print_element_messages(element_messages, status, kind)
65
+ if element_messages.any?
63
66
  @io.puts(format_string("(::) #{status} #{kind} (::)", status))
64
67
  @io.puts
65
68
  @io.flush
66
69
  end
67
70
 
68
- elements.each_with_index do |element, i|
69
- if status == :failed
70
- print_exception(element.exception, status, 0)
71
- else
72
- @io.puts(format_string(element.backtrace_line, status))
73
- end
71
+ element_messages.each do |message|
72
+ @io.puts(format_string(message, status))
74
73
  @io.puts
75
74
  @io.flush
76
75
  end
77
76
  end
78
77
 
79
- def print_stats(features, options)
80
- failures = collect_failing_scenarios(runtime)
81
- if !failures.empty?
82
- print_failing_scenarios(failures, options.custom_profiles, options[:source])
78
+ def print_statistics(duration, config, counts, issues)
79
+ if issues.any?
80
+ @io.puts issues.to_s
81
+ @io.puts
83
82
  end
84
83
 
85
- @io.puts scenario_summary(runtime) {|status_count, status| format_string(status_count, status)}
86
- @io.puts step_summary(runtime) {|status_count, status| format_string(status_count, status)}
84
+ @io.puts counts.to_s
85
+ @io.puts(format_duration(duration)) if duration && config.duration?
87
86
 
88
- @io.puts(format_duration(features.duration)) if features && features.duration
89
-
90
- if runtime.configuration.randomize?
87
+ if config.randomize?
91
88
  @io.puts
92
- @io.puts "Randomized with seed #{runtime.configuration.seed}"
89
+ @io.puts "Randomized with seed #{config.seed}"
93
90
  end
94
91
 
95
92
  @io.flush
96
93
  end
97
94
 
98
- def collect_failing_scenarios(runtime)
99
- # TODO: brittle - stop coupling to types
100
- scenario_class = LegacyApi::Ast::Scenario
101
- example_table_class = Core::Ast::ExamplesTable
102
-
103
- runtime.scenarios(:failed).select do |s|
104
- [scenario_class, example_table_class].include?(s.class)
105
- end.map do |s|
106
- s.is_a?(example_table_class)? s.scenario_outline : s
107
- end
95
+ def print_exception(e, status, indent)
96
+ string = exception_message_string(e, indent)
97
+ @io.puts(format_string(string, status))
108
98
  end
109
99
 
110
- def print_failing_scenarios(failures, custom_profiles, given_source)
111
- @io.puts format_string("Failing Scenarios:", :failed)
112
- failures.each do |failure|
113
- profiles_string = custom_profiles.empty? ? '' : (custom_profiles.map{|profile| "-p #{profile}" }).join(' ') + ' '
114
- source = given_source ? format_string(" # " + failure.name, :comment) : ''
115
- @io.puts format_string("cucumber #{profiles_string}" + failure.location, :failed) + source
116
- end
117
- @io.puts
118
- end
100
+ def exception_message_string(e, indent)
101
+ message = "#{e.message} (#{e.class})".dup.force_encoding('UTF-8')
102
+ message = linebreaks(message, ENV['CUCUMBER_TRUNCATE_OUTPUT'].to_i)
119
103
 
120
- def print_exception(e, status, indent)
121
- message = "#{e.message} (#{e.class})".force_encoding("UTF-8")
122
- if ENV['CUCUMBER_TRUNCATE_OUTPUT']
123
- message = linebreaks(message, ENV['CUCUMBER_TRUNCATE_OUTPUT'].to_i)
124
- end
125
-
126
- string = "#{message}\n#{e.backtrace.join("\n")}".indent(indent)
127
- @io.puts(format_string(string, status))
104
+ "#{message}\n#{e.backtrace.join("\n")}".indent(indent)
128
105
  end
129
106
 
130
107
  # http://blade.nagaokaut.ac.jp/cgi-bin/scat.rb/ruby/ruby-talk/10655
131
- def linebreaks(s, max)
132
- s.gsub(/.{1,#{max}}(?:\s|\Z)/){($& + 5.chr).gsub(/\n\005/,"\n").gsub(/\005/,"\n")}.rstrip
108
+ def linebreaks(msg, max)
109
+ return msg unless max && max > 0
110
+ msg.gsub(/.{1,#{max}}(?:\s|\Z)/) { ($& + 5.chr).gsub(/\n\005/, "\n").gsub(/\005/, "\n") }.rstrip
133
111
  end
134
112
 
135
- def collect_snippet_data(test_step, result)
113
+ def collect_snippet_data(test_step, ast_lookup)
136
114
  # collect snippet data for undefined steps
137
- unless hook?(test_step)
138
- keyword = test_step.source.last.actual_keyword(@previous_step_keyword)
139
- @previous_step_keyword = keyword
140
- if result.undefined?
141
- @snippets_input << Console::SnippetData.new(keyword, test_step.source.last)
142
- end
143
- end
115
+ keyword = ast_lookup.snippet_step_keyword(test_step)
116
+ @snippets_input << Console::SnippetData.new(keyword, test_step)
144
117
  end
145
118
 
146
119
  def print_snippets(options)
147
120
  return unless options[:snippets]
148
- return if runtime.steps(:undefined).empty?
121
+ return if @snippets_input.empty?
149
122
 
123
+ snippet_text_proc = lambda do |step_keyword, step_name, multiline_arg|
124
+ snippet_text(step_keyword, step_name, multiline_arg)
125
+ end
126
+ do_print_snippets(snippet_text_proc)
127
+ end
128
+
129
+ def do_print_snippets(snippet_text_proc)
150
130
  snippets = @snippets_input.map do |data|
151
- @runtime.snippet_text(data.actual_keyword, data.step.name, data.step.multiline_arg)
131
+ snippet_text_proc.call(data.actual_keyword, data.step.text, data.step.multiline_arg)
152
132
  end.uniq
153
133
 
154
134
  text = "\nYou can implement step definitions for undefined steps with these snippets:\n\n"
@@ -159,12 +139,20 @@ module Cucumber
159
139
  @io.flush
160
140
  end
161
141
 
162
- def print_passing_wip(options)
163
- return unless options[:wip]
164
- passed = runtime.scenarios(:passed)
165
- if passed.any?
142
+ def print_passing_wip(config, passed_test_cases, ast_lookup)
143
+ return unless config.wip?
144
+ messages = passed_test_cases.map do |test_case|
145
+ scenario_source = ast_lookup.scenario_source(test_case)
146
+ keyword = scenario_source.type == :Scenario ? scenario_source.scenario.keyword : scenario_source.scenario_outline.keyword
147
+ linebreaks("#{test_case.location.on_line(test_case.location.lines.max)}:in `#{keyword}: #{test_case.name}'", ENV['CUCUMBER_TRUNCATE_OUTPUT'].to_i)
148
+ end
149
+ do_print_passing_wip(messages)
150
+ end
151
+
152
+ def do_print_passing_wip(passed_messages)
153
+ if passed_messages.any?
166
154
  @io.puts format_string("\nThe --wip switch was used, so I didn't expect anything to pass. These scenarios passed:", :failed)
167
- print_elements(passed, :passed, "scenarios")
155
+ print_element_messages(passed_messages, :passed, 'scenarios')
168
156
  else
169
157
  @io.puts format_string("\nThe --wip switch was used, so the failures were expected. All is good.\n", :passed)
170
158
  end
@@ -174,56 +162,33 @@ module Cucumber
174
162
  # no-op
175
163
  end
176
164
 
177
- #define @delayed_messages = [] in your Formatter if you want to
178
- #activate this feature
179
165
  def puts(*messages)
180
- if @delayed_messages
181
- @delayed_messages += messages
182
- else
183
- if @io
184
- @io.puts
185
- messages.each do |message|
186
- @io.puts(format_string(message, :tag))
187
- end
188
- @io.flush
189
- end
166
+ return unless @io
167
+ @io.puts
168
+ messages.each do |message|
169
+ @io.puts(format_string(message, :tag))
190
170
  end
191
- end
192
-
193
- def print_messages
194
- @delayed_messages.each {|message| print_message(message)}
195
- empty_messages
196
- end
197
-
198
- def print_table_row_messages
199
- return if @delayed_messages.empty?
200
- @io.print(format_string(@delayed_messages.join(', '), :tag).indent(2))
201
- @io.flush
202
- empty_messages
203
- end
204
-
205
- def print_message(message)
206
- @io.puts(format_string(message, :tag).indent(@indent))
207
171
  @io.flush
208
172
  end
209
173
 
210
- def empty_messages
211
- @delayed_messages = []
212
- end
213
-
214
174
  def print_profile_information
215
175
  return if @options[:skip_profile_information] || @options[:profiles].nil? || @options[:profiles].empty?
216
- profiles = @options[:profiles]
217
- profiles_sentence = ''
218
- profiles_sentence = profiles.size == 1 ? profiles.first :
219
- "#{profiles[0...-1].join(', ')} and #{profiles.last}"
176
+ do_print_profile_information(@options[:profiles])
177
+ end
220
178
 
221
- @io.puts "Using the #{profiles_sentence} profile#{'s' if profiles.size> 1}..."
179
+ def do_print_profile_information(profiles)
180
+ profiles_sentence = if profiles.size == 1
181
+ profiles.first
182
+ else
183
+ "#{profiles[0...-1].join(', ')} and #{profiles.last}"
184
+ end
185
+
186
+ @io.puts "Using the #{profiles_sentence} profile#{'s' if profiles.size > 1}..."
222
187
  end
223
188
 
224
189
  private
225
190
 
226
- FORMATS = Hash.new{ |hash, format| hash[format] = method(format).to_proc }
191
+ FORMATS = Hash.new { |hash, format| hash[format] = method(format).to_proc }
227
192
 
228
193
  def format_for(*keys)
229
194
  key = keys.join('_').to_sym
@@ -232,17 +197,30 @@ module Cucumber
232
197
  fmt
233
198
  end
234
199
 
235
- def hook?(test_step)
236
- not test_step.source.last.respond_to?(:actual_keyword)
200
+ def element_messages(elements, status)
201
+ elements.map do |element|
202
+ if status == :failed
203
+ exception_message_string(element.exception, 0)
204
+ else
205
+ linebreaks(element.backtrace_line, ENV['CUCUMBER_TRUNCATE_OUTPUT'].to_i)
206
+ end
207
+ end
208
+ end
209
+
210
+ def snippet_text(step_keyword, step_name, multiline_arg)
211
+ keyword = Cucumber::Gherkin::I18n.code_keyword_for(step_keyword).strip
212
+ config.snippet_generators.map do |generator|
213
+ generator.call(keyword, step_name, multiline_arg, config.snippet_type)
214
+ end.join("\n")
237
215
  end
238
216
 
239
217
  class SnippetData
240
218
  attr_reader :actual_keyword, :step
241
219
  def initialize(actual_keyword, step)
242
- @actual_keyword, @step = actual_keyword, step
220
+ @actual_keyword = actual_keyword
221
+ @step = step
243
222
  end
244
223
  end
245
-
246
224
  end
247
225
  end
248
226
  end
@@ -0,0 +1,39 @@
1
+ require 'cucumber/formatter/console'
2
+
3
+ module Cucumber
4
+ module Formatter
5
+ class ConsoleCounts
6
+ include Console
7
+
8
+ def initialize(config)
9
+ @summary = Core::Report::Summary.new(config.event_bus)
10
+ end
11
+
12
+ def to_s
13
+ [
14
+ [scenario_count, status_counts(@summary.test_cases)].compact.join(' '),
15
+ [step_count, status_counts(@summary.test_steps)].compact.join(' ')
16
+ ].join("\n")
17
+ end
18
+
19
+ private
20
+
21
+ def scenario_count
22
+ count = @summary.test_cases.total
23
+ "#{count} scenario" + (count == 1 ? '' : 's')
24
+ end
25
+
26
+ def step_count
27
+ count = @summary.test_steps.total
28
+ "#{count} step" + (count == 1 ? '' : 's')
29
+ end
30
+
31
+ def status_counts(summary)
32
+ counts = Core::Test::Result::TYPES.map { |status| [status, summary.total(status)] }
33
+ counts = counts.select { |_status, count| count > 0 }
34
+ counts = counts.map { |status, count| format_string("#{count} #{status}", status) }
35
+ "(#{counts.join(', ')})" if counts.any?
36
+ end
37
+ end
38
+ end
39
+ end
@@ -0,0 +1,61 @@
1
+ require 'cucumber/formatter/console'
2
+
3
+ module Cucumber
4
+ module Formatter
5
+ class ConsoleIssues
6
+ include Console
7
+
8
+ def initialize(config, ast_lookup = AstLookup.new(config))
9
+ @previous_test_case = nil
10
+ @issues = Hash.new { |h, k| h[k] = [] }
11
+ @config = config
12
+ @config.on_event(:test_case_finished) do |event|
13
+ if event.test_case != @previous_test_case
14
+ @previous_test_case = event.test_case
15
+ @issues[event.result.to_sym] << event.test_case unless event.result.ok?(@config.strict)
16
+ elsif event.result.passed?
17
+ @issues[:flaky] << event.test_case unless Core::Test::Result::Flaky.ok?(@config.strict.strict?(:flaky))
18
+ @issues[:failed].delete(event.test_case)
19
+ end
20
+ end
21
+ @ast_lookup = ast_lookup
22
+ end
23
+
24
+ def to_s
25
+ return if @issues.empty?
26
+ result = Core::Test::Result::TYPES.map { |type| scenario_listing(type, @issues[type]) }
27
+ result.flatten.join("\n")
28
+ end
29
+
30
+ def any?
31
+ @issues.any?
32
+ end
33
+
34
+ private
35
+
36
+ def scenario_listing(type, test_cases)
37
+ return [] if test_cases.empty?
38
+ [format_string("#{type_heading(type)} Scenarios:", type)] + test_cases.map do |test_case|
39
+ scenario_source = @ast_lookup.scenario_source(test_case)
40
+ keyword = scenario_source.type == :Scenario ? scenario_source.scenario.keyword : scenario_source.scenario_outline.keyword
41
+ source = @config.source? ? format_string(" # #{keyword}: #{test_case.name}", :comment) : ''
42
+ format_string("cucumber #{profiles_string}#{test_case.location.file}:#{test_case.location.lines.max}", type) + source
43
+ end
44
+ end
45
+
46
+ def type_heading(type)
47
+ case type
48
+ when :failed
49
+ 'Failing'
50
+ else
51
+ type.to_s.slice(0, 1).capitalize + type.to_s.slice(1..-1)
52
+ end
53
+ end
54
+
55
+ def profiles_string
56
+ return if @config.custom_profiles.empty?
57
+ @config.custom_profiles.map { |profile| "-p #{profile}" }.join(' ') + ' '
58
+ end
59
+ end
60
+ end
61
+ end