cavalle-cucumber 0.2.3.3.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (343) hide show
  1. data/History.txt +556 -0
  2. data/License.txt +20 -0
  3. data/Manifest.txt +345 -0
  4. data/README.txt +4 -0
  5. data/Rakefile +8 -0
  6. data/bin/cucumber +6 -0
  7. data/config/hoe.rb +76 -0
  8. data/config/requirements.rb +15 -0
  9. data/cucumber.yml +1 -0
  10. data/examples/cs/README.textile +1 -0
  11. data/examples/cs/Rakefile +12 -0
  12. data/examples/cs/compile.bat +1 -0
  13. data/examples/cs/features/addition.feature +16 -0
  14. data/examples/cs/features/step_definitons/calculator_steps.rb +19 -0
  15. data/examples/cs/src/demo/Calculator.cs +20 -0
  16. data/examples/dos_line_endings/Rakefile +6 -0
  17. data/examples/dos_line_endings/features/dos_line_endings.feature +9 -0
  18. data/examples/i18n/README.textile +18 -0
  19. data/examples/i18n/Rakefile +30 -0
  20. data/examples/i18n/ar/Rakefile +6 -0
  21. data/examples/i18n/ar/features/addition.feature +16 -0
  22. data/examples/i18n/ar/features/step_definitons/calculator_steps.rb +24 -0
  23. data/examples/i18n/ar/lib/calculator.rb +11 -0
  24. data/examples/i18n/bg/Rakefile +6 -0
  25. data/examples/i18n/bg/features/addition.feature +11 -0
  26. data/examples/i18n/bg/features/consecutive_calculations.feature +18 -0
  27. data/examples/i18n/bg/features/division.feature +16 -0
  28. data/examples/i18n/bg/features/step_definitons/calculator_steps.rb +24 -0
  29. data/examples/i18n/bg/features/support/env.rb +6 -0
  30. data/examples/i18n/bg/features/support/world.rb +8 -0
  31. data/examples/i18n/bg/lib/calculator.rb +24 -0
  32. data/examples/i18n/da/Rakefile +6 -0
  33. data/examples/i18n/da/features/step_definitons/kalkulator_steps.rb +24 -0
  34. data/examples/i18n/da/features/summering.feature +17 -0
  35. data/examples/i18n/da/lib/kalkulator.rb +11 -0
  36. data/examples/i18n/de/Rakefile +6 -0
  37. data/examples/i18n/de/features/addition.feature +16 -0
  38. data/examples/i18n/de/features/division.feature +9 -0
  39. data/examples/i18n/de/features/step_definitons/calculator_steps.rb +24 -0
  40. data/examples/i18n/de/lib/calculator.rb +14 -0
  41. data/examples/i18n/en/Rakefile +6 -0
  42. data/examples/i18n/en/features/addition.feature +16 -0
  43. data/examples/i18n/en/features/division.feature +9 -0
  44. data/examples/i18n/en/features/step_definitons/calculator_steps.rb +24 -0
  45. data/examples/i18n/en/lib/calculator.rb +14 -0
  46. data/examples/i18n/en-lol/Rakefile +6 -0
  47. data/examples/i18n/en-lol/features/step_definitions/cucumbrz_steps.rb +16 -0
  48. data/examples/i18n/en-lol/features/stuffing.feature +8 -0
  49. data/examples/i18n/en-lol/features/support/env.rb +8 -0
  50. data/examples/i18n/en-lol/lib/basket.rb +12 -0
  51. data/examples/i18n/en-lol/lib/belly.rb +11 -0
  52. data/examples/i18n/es/Rakefile +6 -0
  53. data/examples/i18n/es/features/adicion.feature +16 -0
  54. data/examples/i18n/es/features/step_definitons/calculador_steps.rb +21 -0
  55. data/examples/i18n/es/lib/calculador.rb +14 -0
  56. data/examples/i18n/et/Rakefile +6 -0
  57. data/examples/i18n/et/features/jagamine.feature +9 -0
  58. data/examples/i18n/et/features/liitmine.feature +16 -0
  59. data/examples/i18n/et/features/step_definitions/kalkulaator_steps.rb +24 -0
  60. data/examples/i18n/et/lib/kalkulaator.rb +14 -0
  61. data/examples/i18n/fi/Rakefile +6 -0
  62. data/examples/i18n/fi/features/jakolasku.feature +9 -0
  63. data/examples/i18n/fi/features/step_definitons/laskin_steps.rb +24 -0
  64. data/examples/i18n/fi/features/yhteenlasku.feature +16 -0
  65. data/examples/i18n/fi/lib/laskin.rb +14 -0
  66. data/examples/i18n/fr/Rakefile +6 -0
  67. data/examples/i18n/fr/features/addition.feature +17 -0
  68. data/examples/i18n/fr/features/step_definitions/calculatrice_steps.rb +25 -0
  69. data/examples/i18n/fr/lib/calculatrice.rb +10 -0
  70. data/examples/i18n/id/Rakefile +6 -0
  71. data/examples/i18n/id/features/addition.feature +16 -0
  72. data/examples/i18n/id/features/division.feature +9 -0
  73. data/examples/i18n/id/features/step_definitons/calculator_steps.rb +24 -0
  74. data/examples/i18n/id/lib/calculator.rb +14 -0
  75. data/examples/i18n/it/Rakefile +6 -0
  76. data/examples/i18n/it/features/somma.feature +10 -0
  77. data/examples/i18n/it/features/step_definitons/calcolatrice_steps.rb +24 -0
  78. data/examples/i18n/it/lib/calcolatrice.rb +11 -0
  79. data/examples/i18n/ja/Rakefile +6 -0
  80. data/examples/i18n/ja/features/addition.feature +16 -0
  81. data/examples/i18n/ja/features/division.feature +9 -0
  82. data/examples/i18n/ja/features/step_definitons/calculator_steps.rb +24 -0
  83. data/examples/i18n/ja/lib/calculator.rb +14 -0
  84. data/examples/i18n/ko/Rakefile +6 -0
  85. data/examples/i18n/ko/features/addition.feature +16 -0
  86. data/examples/i18n/ko/features/division.feature +10 -0
  87. data/examples/i18n/ko/features/step_definitons/calculator_steps.rb +24 -0
  88. data/examples/i18n/ko/lib/calculator.rb +14 -0
  89. data/examples/i18n/lt/Rakefile +6 -0
  90. data/examples/i18n/lt/features/addition.feature +17 -0
  91. data/examples/i18n/lt/features/division.feature +9 -0
  92. data/examples/i18n/lt/features/step_definitons/calculator_steps.rb +24 -0
  93. data/examples/i18n/lt/lib/calculator.rb +14 -0
  94. data/examples/i18n/no/Rakefile +6 -0
  95. data/examples/i18n/no/features/step_definitons/kalkulator_steps.rb +17 -0
  96. data/examples/i18n/no/features/summering.feature +18 -0
  97. data/examples/i18n/no/features/support/env.rb +6 -0
  98. data/examples/i18n/no/lib/kalkulator.rb +11 -0
  99. data/examples/i18n/pt/Rakefile +6 -0
  100. data/examples/i18n/pt/features/adicao.feature +10 -0
  101. data/examples/i18n/pt/features/step_definitions/calculadora_steps.rb +24 -0
  102. data/examples/i18n/pt/lib/calculadora.rb +10 -0
  103. data/examples/i18n/ro/Rakefile +6 -0
  104. data/examples/i18n/ro/features/step_definitons/calculator_steps.rb +24 -0
  105. data/examples/i18n/ro/features/suma.feature +10 -0
  106. data/examples/i18n/ro/lib/calculator.rb +11 -0
  107. data/examples/i18n/ru/Rakefile +6 -0
  108. data/examples/i18n/ru/features/addition.feature +10 -0
  109. data/examples/i18n/ru/features/consecutive_calculations.feature +16 -0
  110. data/examples/i18n/ru/features/division.feature +15 -0
  111. data/examples/i18n/ru/features/step_definitons/calculator_steps.rb +19 -0
  112. data/examples/i18n/ru/features/support/env.rb +6 -0
  113. data/examples/i18n/ru/features/support/world.rb +8 -0
  114. data/examples/i18n/ru/lib/calculator.rb +24 -0
  115. data/examples/i18n/se/Rakefile +6 -0
  116. data/examples/i18n/se/features/step_definitons/kalkulator_steps.rb +24 -0
  117. data/examples/i18n/se/features/summering.feature +17 -0
  118. data/examples/i18n/se/lib/kalkulator.rb +11 -0
  119. data/examples/i18n/sk/Rakefile +6 -0
  120. data/examples/i18n/sk/features/addition.feature +16 -0
  121. data/examples/i18n/sk/features/division.feature +9 -0
  122. data/examples/i18n/sk/features/step_definitons/calculator_steps.rb +24 -0
  123. data/examples/i18n/sk/lib/calculator.rb +14 -0
  124. data/examples/i18n/zh-CN/Rakefile +6 -0
  125. data/examples/i18n/zh-CN/features/addition.feature +17 -0
  126. data/examples/i18n/zh-CN/features/step_definitons/calculator_steps.rb +26 -0
  127. data/examples/i18n/zh-CN/lib/calculator.rb +10 -0
  128. data/examples/i18n/zh-TW/Rakefile +6 -0
  129. data/examples/i18n/zh-TW/features/addition.feature +16 -0
  130. data/examples/i18n/zh-TW/features/division.feature +10 -0
  131. data/examples/i18n/zh-TW/features/step_definitons/calculator_steps.rb +24 -0
  132. data/examples/i18n/zh-TW/lib/calculator.rb +14 -0
  133. data/examples/java/README.textile +22 -0
  134. data/examples/java/Rakefile +12 -0
  135. data/examples/java/features/hello.feature +11 -0
  136. data/examples/java/features/step_definitons/hello_steps.rb +25 -0
  137. data/examples/java/features/step_definitons/tree_steps.rb +14 -0
  138. data/examples/java/features/tree.feature +9 -0
  139. data/examples/java/src/cucumber/demo/Hello.java +16 -0
  140. data/examples/pure_java/README.textile +5 -0
  141. data/examples/selenium/Rakefile +6 -0
  142. data/examples/selenium/features/search.feature +9 -0
  143. data/examples/selenium/features/step_definitons/search_steps.rb +13 -0
  144. data/examples/selenium/features/support/env.rb +19 -0
  145. data/examples/selenium_webrat/Rakefile +6 -0
  146. data/examples/selenium_webrat/features/search.feature +9 -0
  147. data/examples/selenium_webrat/features/step_definitons/search_steps.rb +13 -0
  148. data/examples/selenium_webrat/features/support/env.rb +41 -0
  149. data/examples/self_test/README.textile +6 -0
  150. data/examples/self_test/Rakefile +6 -0
  151. data/examples/self_test/features/background/background_with_name.feature +7 -0
  152. data/examples/self_test/features/background/failing_background.feature +11 -0
  153. data/examples/self_test/features/background/failing_background_after_success.feature +11 -0
  154. data/examples/self_test/features/background/multiline_args_background.feature +32 -0
  155. data/examples/self_test/features/background/passing_background.feature +10 -0
  156. data/examples/self_test/features/background/pending_background.feature +10 -0
  157. data/examples/self_test/features/background/scenario_outline_failing_background.feature +16 -0
  158. data/examples/self_test/features/background/scenario_outline_passing_background.feature +16 -0
  159. data/examples/self_test/features/call_undefined_step_from_step_def.feature +7 -0
  160. data/examples/self_test/features/failing_expectation.feature +4 -0
  161. data/examples/self_test/features/lots_of_undefined.feature +8 -0
  162. data/examples/self_test/features/outline_sample.feature +15 -0
  163. data/examples/self_test/features/sample.feature +19 -0
  164. data/examples/self_test/features/step_definitions/sample_steps.rb +70 -0
  165. data/examples/self_test/features/support/env.rb +1 -0
  166. data/examples/self_test/features/support/tag_count_formatter.rb +25 -0
  167. data/examples/self_test/features/tons_of_cukes.feature +52 -0
  168. data/examples/self_test/features/undefined_multiline_args.feature +12 -0
  169. data/examples/sinatra/Rakefile +6 -0
  170. data/examples/sinatra/app.rb +14 -0
  171. data/examples/sinatra/features/add.feature +11 -0
  172. data/examples/sinatra/features/step_definitions/add_steps.rb +15 -0
  173. data/examples/sinatra/features/support/env.rb +20 -0
  174. data/examples/sinatra/views/add.erb +5 -0
  175. data/examples/sinatra/views/layout.erb +8 -0
  176. data/examples/test_unit/Rakefile +6 -0
  177. data/examples/test_unit/features/step_definitions/test_unit_steps.rb +23 -0
  178. data/examples/test_unit/features/test_unit.feature +9 -0
  179. data/examples/tickets/Rakefile +16 -0
  180. data/examples/tickets/features/172.feature +28 -0
  181. data/examples/tickets/features/177/1.feature +29 -0
  182. data/examples/tickets/features/177/2.feature +21 -0
  183. data/examples/tickets/features/177/3.feature +18 -0
  184. data/examples/tickets/features/180.feature +7 -0
  185. data/examples/tickets/features/236.feature +13 -0
  186. data/examples/tickets/features/241.feature +13 -0
  187. data/examples/tickets/features/246.feature +4 -0
  188. data/examples/tickets/features/248.feature +11 -0
  189. data/examples/tickets/features/270/back.feature +14 -0
  190. data/examples/tickets/features/270/back.steps.rb +14 -0
  191. data/examples/tickets/features/lib/eatting_machine.rb +18 -0
  192. data/examples/tickets/features/lib/pantry.rb +20 -0
  193. data/examples/tickets/features/scenario_outline.feature +95 -0
  194. data/examples/tickets/features/step_definitons/246_steps.rb +3 -0
  195. data/examples/tickets/features/step_definitons/248_steps.rb +15 -0
  196. data/examples/tickets/features/step_definitons/scenario_outline_steps.rb +42 -0
  197. data/examples/tickets/features/step_definitons/tickets_steps.rb +73 -0
  198. data/examples/tickets/features/tickets.feature +28 -0
  199. data/examples/watir/README.textile +16 -0
  200. data/examples/watir/Rakefile +6 -0
  201. data/examples/watir/features/search.feature +9 -0
  202. data/examples/watir/features/step_definitons/search_steps.rb +24 -0
  203. data/examples/watir/features/support/env.rb +32 -0
  204. data/features/background.feature +238 -0
  205. data/features/cucumber_cli.feature +402 -0
  206. data/features/cucumber_cli_diff_disabled.feature +45 -0
  207. data/features/cucumber_cli_outlines.feature +84 -0
  208. data/features/custom_formatter.feature +11 -0
  209. data/features/report_called_undefined_steps.feature +34 -0
  210. data/features/snippet.feature +23 -0
  211. data/features/step_definitions/cucumber_steps.rb +34 -0
  212. data/features/step_definitions/extra_steps.rb +2 -0
  213. data/features/support/env.rb +8 -0
  214. data/features/usage.feature +113 -0
  215. data/gem_tasks/deployment.rake +11 -0
  216. data/gem_tasks/environment.rake +7 -0
  217. data/gem_tasks/features.rake +6 -0
  218. data/gem_tasks/fix_cr_lf.rake +10 -0
  219. data/gem_tasks/flog.rake +4 -0
  220. data/gem_tasks/gemspec.rake +10 -0
  221. data/gem_tasks/rspec.rake +38 -0
  222. data/gem_tasks/yard.rake +8 -0
  223. data/lib/autotest/cucumber.rb +6 -0
  224. data/lib/autotest/cucumber_mixin.rb +125 -0
  225. data/lib/autotest/cucumber_rails.rb +6 -0
  226. data/lib/autotest/cucumber_rails_rspec.rb +6 -0
  227. data/lib/autotest/cucumber_rspec.rb +6 -0
  228. data/lib/autotest/discover.rb +9 -0
  229. data/lib/cucumber/ast/background.rb +50 -0
  230. data/lib/cucumber/ast/comment.rb +26 -0
  231. data/lib/cucumber/ast/examples.rb +26 -0
  232. data/lib/cucumber/ast/feature.rb +52 -0
  233. data/lib/cucumber/ast/feature_element.rb +38 -0
  234. data/lib/cucumber/ast/features.rb +26 -0
  235. data/lib/cucumber/ast/outline_table.rb +73 -0
  236. data/lib/cucumber/ast/py_string.rb +53 -0
  237. data/lib/cucumber/ast/scenario.rb +57 -0
  238. data/lib/cucumber/ast/scenario_outline.rb +80 -0
  239. data/lib/cucumber/ast/step.rb +105 -0
  240. data/lib/cucumber/ast/step_collection.rb +62 -0
  241. data/lib/cucumber/ast/step_invocation.rb +117 -0
  242. data/lib/cucumber/ast/table.rb +326 -0
  243. data/lib/cucumber/ast/tags.rb +25 -0
  244. data/lib/cucumber/ast/visitor.rb +112 -0
  245. data/lib/cucumber/ast.rb +29 -0
  246. data/lib/cucumber/broadcaster.rb +13 -0
  247. data/lib/cucumber/cli/configuration.rb +361 -0
  248. data/lib/cucumber/cli/language_help_formatter.rb +59 -0
  249. data/lib/cucumber/cli/main.rb +105 -0
  250. data/lib/cucumber/core_ext/exception.rb +53 -0
  251. data/lib/cucumber/core_ext/instance_exec.rb +67 -0
  252. data/lib/cucumber/core_ext/proc.rb +33 -0
  253. data/lib/cucumber/core_ext/string.rb +48 -0
  254. data/lib/cucumber/formatter/ansicolor.rb +110 -0
  255. data/lib/cucumber/formatter/color_io.rb +23 -0
  256. data/lib/cucumber/formatter/console.rb +110 -0
  257. data/lib/cucumber/formatter/cucumber.css +55 -0
  258. data/lib/cucumber/formatter/cucumber.sass +49 -0
  259. data/lib/cucumber/formatter/html.rb +186 -0
  260. data/lib/cucumber/formatter/pretty.rb +185 -0
  261. data/lib/cucumber/formatter/profile.rb +77 -0
  262. data/lib/cucumber/formatter/progress.rb +60 -0
  263. data/lib/cucumber/formatter/rerun.rb +43 -0
  264. data/lib/cucumber/formatter/unicode.rb +35 -0
  265. data/lib/cucumber/formatter/usage.rb +85 -0
  266. data/lib/cucumber/formatter.rb +1 -0
  267. data/lib/cucumber/formatters/unicode.rb +2 -0
  268. data/lib/cucumber/languages.yml +455 -0
  269. data/lib/cucumber/parser/feature.rb +1590 -0
  270. data/lib/cucumber/parser/feature.tt +288 -0
  271. data/lib/cucumber/parser/i18n.tt +35 -0
  272. data/lib/cucumber/parser/table.rb +414 -0
  273. data/lib/cucumber/parser/table.tt +71 -0
  274. data/lib/cucumber/parser/treetop_ext.rb +114 -0
  275. data/lib/cucumber/parser.rb +38 -0
  276. data/lib/cucumber/platform.rb +17 -0
  277. data/lib/cucumber/rails/rspec.rb +8 -0
  278. data/lib/cucumber/rails/world.rb +74 -0
  279. data/lib/cucumber/rake/task.rb +138 -0
  280. data/lib/cucumber/step_definition.rb +113 -0
  281. data/lib/cucumber/step_match.rb +57 -0
  282. data/lib/cucumber/step_mother.rb +290 -0
  283. data/lib/cucumber/version.rb +10 -0
  284. data/lib/cucumber/world.rb +53 -0
  285. data/lib/cucumber.rb +63 -0
  286. data/rails_generators/cucumber/USAGE +11 -0
  287. data/rails_generators/cucumber/cucumber_generator.rb +50 -0
  288. data/rails_generators/cucumber/templates/cucumber +8 -0
  289. data/rails_generators/cucumber/templates/cucumber.rake +15 -0
  290. data/rails_generators/cucumber/templates/env.rb +19 -0
  291. data/rails_generators/cucumber/templates/paths.rb +29 -0
  292. data/rails_generators/cucumber/templates/webrat_steps.rb +123 -0
  293. data/rails_generators/feature/USAGE +12 -0
  294. data/rails_generators/feature/feature_generator.rb +40 -0
  295. data/rails_generators/feature/templates/feature.erb +31 -0
  296. data/rails_generators/feature/templates/steps.erb +20 -0
  297. data/spec/cucumber/ast/background_spec.rb +50 -0
  298. data/spec/cucumber/ast/feature_factory.rb +63 -0
  299. data/spec/cucumber/ast/feature_spec.rb +38 -0
  300. data/spec/cucumber/ast/py_string_spec.rb +47 -0
  301. data/spec/cucumber/ast/scenario_outline_spec.rb +67 -0
  302. data/spec/cucumber/ast/scenario_spec.rb +38 -0
  303. data/spec/cucumber/ast/step_collection_spec.rb +16 -0
  304. data/spec/cucumber/ast/step_spec.rb +66 -0
  305. data/spec/cucumber/ast/table_spec.rb +170 -0
  306. data/spec/cucumber/broadcaster_spec.rb +15 -0
  307. data/spec/cucumber/cli/configuration_spec.rb +287 -0
  308. data/spec/cucumber/cli/main_spec.rb +191 -0
  309. data/spec/cucumber/core_ext/proc_spec.rb +54 -0
  310. data/spec/cucumber/core_ext/string_spec.rb +42 -0
  311. data/spec/cucumber/formatter/ansicolor_spec.rb +35 -0
  312. data/spec/cucumber/formatter/color_io_spec.rb +26 -0
  313. data/spec/cucumber/formatter/html/cucumber.css +37 -0
  314. data/spec/cucumber/formatter/html/cucumber.js +13 -0
  315. data/spec/cucumber/formatter/html/index.html +45 -0
  316. data/spec/cucumber/formatter/html/jquery-1.3.min.js +19 -0
  317. data/spec/cucumber/formatter/html/jquery.uitableedit.js +100 -0
  318. data/spec/cucumber/formatters/profile_formatter_spec.rb +198 -0
  319. data/spec/cucumber/parser/feature_parser_spec.rb +284 -0
  320. data/spec/cucumber/parser/table_parser_spec.rb +48 -0
  321. data/spec/cucumber/rails/stubs/mini_rails.rb +18 -0
  322. data/spec/cucumber/rails/stubs/test_help.rb +1 -0
  323. data/spec/cucumber/rails/world_spec.rb +11 -0
  324. data/spec/cucumber/sell_cucumbers.feature +19 -0
  325. data/spec/cucumber/step_definition_spec.rb +101 -0
  326. data/spec/cucumber/step_mother_spec.rb +137 -0
  327. data/spec/cucumber/treetop_parser/empty_feature.feature +4 -0
  328. data/spec/cucumber/treetop_parser/empty_scenario.feature +9 -0
  329. data/spec/cucumber/treetop_parser/empty_scenario_outline.feature +3 -0
  330. data/spec/cucumber/treetop_parser/fit_scenario.feature +8 -0
  331. data/spec/cucumber/treetop_parser/given_scenario.feature +9 -0
  332. data/spec/cucumber/treetop_parser/invalid_scenario_outlines.feature +7 -0
  333. data/spec/cucumber/treetop_parser/multiline_steps.feature +17 -0
  334. data/spec/cucumber/treetop_parser/multiple_tables.feature +27 -0
  335. data/spec/cucumber/treetop_parser/scenario_outline.feature +16 -0
  336. data/spec/cucumber/treetop_parser/spaces.feature +12 -0
  337. data/spec/cucumber/treetop_parser/test_dos.feature +25 -0
  338. data/spec/cucumber/treetop_parser/with_comments.feature +10 -0
  339. data/spec/cucumber/treetop_parser/with_tags.feature +18 -0
  340. data/spec/cucumber/world/pending_spec.rb +47 -0
  341. data/spec/spec.opts +2 -0
  342. data/spec/spec_helper.rb +12 -0
  343. metadata +458 -0
@@ -0,0 +1,74 @@
1
+ # Based on code from Brian Takita, Yurii Rashkovskii and Ben Mabey
2
+ # Adapted by Aslak Hellesøy
3
+
4
+ if defined?(ActiveRecord::Base)
5
+ require 'test_help'
6
+ else
7
+ require 'action_controller/test_process'
8
+ require 'action_controller/integration'
9
+ end
10
+ require 'test/unit/testresult'
11
+
12
+ # So that Test::Unit doesn't launch at the end - makes it think it has already been run.
13
+ Test::Unit.run = true if Test::Unit.respond_to?(:run=)
14
+
15
+ $__cucumber_toplevel = self
16
+
17
+ module Cucumber #:nodoc:
18
+ module Rails
19
+ # All scenarios will execute in the context of a new instance of World.
20
+ class World < ActionController::IntegrationTest
21
+ if defined?(ActiveRecord::Base)
22
+ self.use_transactional_fixtures = false
23
+ else
24
+ def self.fixture_table_names; []; end # Workaround for projects that don't use ActiveRecord
25
+ end
26
+
27
+ def initialize #:nodoc:
28
+ @_result = Test::Unit::TestResult.new
29
+ end
30
+ end
31
+
32
+ def self.use_transactional_fixtures
33
+ World.use_transactional_fixtures = true
34
+ if defined?(ActiveRecord::Base)
35
+ $__cucumber_toplevel.Before do
36
+ @__cucumber_ar_connection = ActiveRecord::Base.connection
37
+ if @__cucumber_ar_connection.respond_to?(:increment_open_transactions)
38
+ @__cucumber_ar_connection.increment_open_transactions
39
+ else
40
+ ActiveRecord::Base.__send__(:increment_open_transactions)
41
+ end
42
+ @__cucumber_ar_connection.begin_db_transaction
43
+ ActionMailer::Base.deliveries = [] if defined?(ActionMailer::Base)
44
+ end
45
+
46
+ $__cucumber_toplevel.After do
47
+ @__cucumber_ar_connection.rollback_db_transaction
48
+ if @__cucumber_ar_connection.respond_to?(:decrement_open_transactions)
49
+ @__cucumber_ar_connection.decrement_open_transactions
50
+ else
51
+ ActiveRecord::Base.__send__(:decrement_open_transactions)
52
+ end
53
+ end
54
+ end
55
+ end
56
+
57
+ def self.bypass_rescue
58
+ ActionController::Base.class_eval do
59
+ def rescue_action(exception)
60
+ raise exception
61
+ end
62
+ end
63
+ ActionController::Dispatcher.class_eval do
64
+ def self.failsafe_response(output, status, exception = nil)
65
+ raise exception
66
+ end
67
+ end
68
+ end
69
+ end
70
+ end
71
+
72
+ World do
73
+ Cucumber::Rails::World.new
74
+ end
@@ -0,0 +1,138 @@
1
+ require 'cucumber/platform'
2
+
3
+ module Cucumber
4
+ module Rake
5
+ # Defines a Rake task for running features.
6
+ #
7
+ # The simplest use of it goes something like:
8
+ #
9
+ # Cucumber::Rake::Task.new
10
+ #
11
+ # This will create a task named 'features' described as 'Run Features with
12
+ # Cucumber'. It will use steps from 'features/**/*.rb' and features in 'features/**/*.feature'.
13
+ #
14
+ # To further configure the task, you can pass a block:
15
+ #
16
+ # Cucumber::Rake::Task.new do |t|
17
+ # t.cucumber_opts = "--format progress"
18
+ # end
19
+ #
20
+ # This task can also be configured to be run with RCov:
21
+ #
22
+ # Cucumber::Rake::Task.new do |t|
23
+ # t.rcov = true
24
+ # end
25
+ #
26
+ # See the attributes for additional configuration possibilities.
27
+ class Task
28
+ LIB = File.expand_path(File.dirname(__FILE__) + '/../..') # :nodoc:
29
+
30
+ # Directories to add to the Ruby $LOAD_PATH
31
+ attr_accessor :libs
32
+ # Name of the cucumber binary to use for running features. Defaults to Cucumber::BINARY
33
+ attr_accessor :binary
34
+ # Array of paths to specific step definition files to use
35
+ attr_accessor :step_list
36
+ # File pattern for finding step definitions. Defaults to
37
+ # 'features/**/*.rb'.
38
+ attr_accessor :step_pattern
39
+ # Array of paths to specific features to run.
40
+ attr_accessor :feature_list
41
+ # File pattern for finding features to run. Defaults to
42
+ # 'features/**/*.feature'. Can be overriden by the FEATURE environment variable.
43
+ attr_accessor :feature_pattern
44
+ # Extra options to pass to the cucumber binary. Can be overridden by the CUCUMBER_OPTS environment variable.
45
+ attr_accessor :cucumber_opts
46
+ # Run cucumber with RCov?
47
+ attr_accessor :rcov
48
+ # Extra options to pass to rcov
49
+ attr_accessor :rcov_opts
50
+
51
+ # Define a Rake
52
+ def initialize(task_name = "features", desc = "Run Features with Cucumber")
53
+ @task_name, @desc = task_name, desc
54
+ @libs = ['lib']
55
+ @rcov_opts = %w{--rails --exclude osx\/objc,gems\/}
56
+
57
+ yield self if block_given?
58
+
59
+ @feature_pattern = "features/**/*.feature" if feature_pattern.nil? && feature_list.nil?
60
+ @step_pattern = "features/**/*.rb" if step_pattern.nil? && step_list.nil?
61
+
62
+ @binary = binary.nil? ? Cucumber::BINARY : File.expand_path(binary)
63
+ @libs.insert(0, LIB) if binary == Cucumber::BINARY
64
+
65
+ define_task
66
+ end
67
+
68
+ def define_task # :nodoc:
69
+ desc @desc
70
+ task @task_name do
71
+ ruby(arguments_for_ruby_execution.join(" ")) # ruby(*args) is broken on Windows
72
+ end
73
+ end
74
+
75
+ def arguments_for_ruby_execution(task_args = nil) # :nodoc:
76
+ lib_args = ['"%s"' % libs.join(File::PATH_SEPARATOR)]
77
+ cucumber_bin = ['"%s"' % binary]
78
+ cuc_opts = [(ENV['CUCUMBER_OPTS'] || cucumber_opts)]
79
+
80
+ step_files(task_args).each do |step_file|
81
+ cuc_opts << '--require'
82
+ cuc_opts << step_file
83
+ end
84
+
85
+ if rcov
86
+ args = (['-I'] + lib_args + ['-S', 'rcov'] + rcov_opts +
87
+ cucumber_bin + ['--'] + cuc_opts + feature_files(task_args)).flatten
88
+ else
89
+ args = (['-I'] + lib_args + cucumber_bin + cuc_opts + feature_files(task_args)).flatten
90
+ end
91
+
92
+ args
93
+ end
94
+
95
+ def feature_files(task_args = nil) # :nodoc:
96
+ if ENV['FEATURE']
97
+ FileList[ ENV['FEATURE'] ]
98
+ else
99
+ result = []
100
+ result += feature_list.to_a if feature_list
101
+ result += FileList[feature_pattern].to_a if feature_pattern
102
+ FileList[result]
103
+ end
104
+ end
105
+
106
+ def step_files(task_args = nil) # :nodoc:
107
+ if ENV['STEPS']
108
+ FileList[ ENV['STEPS'] ]
109
+ else
110
+ result = []
111
+ result += Array(step_list) if step_list
112
+ result += Array(FileList[step_pattern]) if step_pattern
113
+ FileList[result]
114
+ end
115
+ end
116
+ end
117
+
118
+ class FeatureTask < Task
119
+
120
+ def initialize(task_name = "feature", desc = "Run a specified feature with Cucumber. #{task_name}[feature_name]")
121
+ super(task_name, desc)
122
+ end
123
+
124
+ def define_task # :nodoc:
125
+ desc @desc
126
+ task @task_name, :feature_name do |t, args|
127
+ ruby(arguments_for_ruby_execution(args).join(" ")) # ruby(*args) is broken on Windows
128
+ end
129
+ end
130
+
131
+ def feature_files(task_arguments) # :nodoc:
132
+ FileList[File.join("features", "**", "#{task_arguments[:feature_name]}.feature")]
133
+ end
134
+
135
+ end
136
+
137
+ end
138
+ end
@@ -0,0 +1,113 @@
1
+ require 'cucumber/step_match'
2
+ require 'cucumber/core_ext/string'
3
+ require 'cucumber/core_ext/proc'
4
+
5
+ module Cucumber
6
+ module StepDefinitionMethods
7
+ def step_match(name_to_match, name_to_report)
8
+ if(match = name_to_match.match(regexp))
9
+ StepMatch.new(self, name_to_match, name_to_report, match.captures)
10
+ else
11
+ nil
12
+ end
13
+ end
14
+
15
+ # Formats the matched arguments of the associated Step. This method
16
+ # is usually called from visitors, which render output.
17
+ #
18
+ # The +format+ can either be a String or a Proc.
19
+ #
20
+ # If it is a String it should be a format string according to
21
+ # <tt>Kernel#sprinf</tt>, for example:
22
+ #
23
+ # '<span class="param">%s</span></tt>'
24
+ #
25
+ # If it is a Proc, it should take one argument and return the formatted
26
+ # argument, for example:
27
+ #
28
+ # lambda { |param| "[#{param}]" }
29
+ #
30
+ def format_args(step_name, format)
31
+ step_name.gzub(regexp, format)
32
+ end
33
+
34
+ def match(step_name)
35
+ case step_name
36
+ when String then regexp.match(step_name)
37
+ when Regexp then regexp == step_name
38
+ end
39
+ end
40
+
41
+ def backtrace_line
42
+ "#{file_colon_line}:in `#{regexp.inspect}'"
43
+ end
44
+
45
+ def text_length
46
+ regexp.inspect.jlength
47
+ end
48
+ end
49
+
50
+ # A Step Definition holds a Regexp and a Proc, and is created
51
+ # by calling <tt>Given</tt>, <tt>When</tt> or <tt>Then</tt>
52
+ # in the <tt>step_definitions</tt> ruby files - for example:
53
+ #
54
+ # Given /I have (\d+) cucumbers in my belly/ do
55
+ # # some code here
56
+ # end
57
+ #
58
+ class StepDefinition
59
+ PARAM_PATTERN = /"([^\"]*)"/
60
+ ESCAPED_PARAM_PATTERN = '"([^\\"]*)"'
61
+
62
+ def self.snippet_text(step_keyword, step_name, multiline_arg_class = nil)
63
+ escaped = Regexp.escape(step_name).gsub('\ ', ' ').gsub('/', '\/')
64
+ escaped = escaped.gsub(PARAM_PATTERN, ESCAPED_PARAM_PATTERN)
65
+
66
+ n = 0
67
+ block_args = escaped.scan(ESCAPED_PARAM_PATTERN).map do |a|
68
+ n += 1
69
+ "arg#{n}"
70
+ end
71
+ block_args << multiline_arg_class.default_arg_name unless multiline_arg_class.nil?
72
+ block_arg_string = block_args.empty? ? "" : " |#{block_args.join(", ")}|"
73
+ multiline_class_string = multiline_arg_class ? "# #{multiline_arg_class.default_arg_name} is a #{multiline_arg_class.to_s}\n " : ""
74
+
75
+ "#{step_keyword} /^#{escaped}$/ do#{block_arg_string}\n #{multiline_class_string}pending\nend"
76
+ end
77
+
78
+ class MissingProc < StandardError
79
+ def message
80
+ "Step definitions must always have a proc"
81
+ end
82
+ end
83
+
84
+ include StepDefinitionMethods
85
+
86
+ def initialize(pattern, &proc)
87
+ raise MissingProc if proc.nil?
88
+ if String === pattern
89
+ p = pattern.gsub(/\$\w+/, '(.*)') # Replace $var with (.*)
90
+ pattern = Regexp.new("^#{p}$")
91
+ end
92
+ @regexp, @proc = pattern, proc
93
+ end
94
+
95
+ def regexp
96
+ @regexp
97
+ end
98
+
99
+ def invoke(world, args)
100
+ args = args.map{|arg| Ast::PyString === arg ? arg.to_s : arg}
101
+ begin
102
+ world.cucumber_instance_exec(true, regexp.inspect, *args, &@proc)
103
+ rescue Cucumber::ArityMismatchError => e
104
+ e.backtrace.unshift(self.backtrace_line)
105
+ raise e
106
+ end
107
+ end
108
+
109
+ def file_colon_line
110
+ @proc.file_colon_line
111
+ end
112
+ end
113
+ end
@@ -0,0 +1,57 @@
1
+ module Cucumber
2
+ class StepMatch
3
+ attr_reader :step_definition
4
+ attr_reader :args
5
+
6
+ def initialize(step_definition, step_name, formatted_step_name, args)
7
+ @step_definition, @step_name, @formatted_step_name, @args = step_definition, step_name, formatted_step_name, args
8
+ end
9
+
10
+ def invoke(world, multiline_arg)
11
+ all_args = @args.dup
12
+ all_args << multiline_arg if multiline_arg
13
+ @step_definition.invoke(world, all_args)
14
+ end
15
+
16
+ def format_args(format = lambda{|a| a})
17
+ @formatted_step_name || @step_definition.format_args(@step_name, format)
18
+ end
19
+
20
+ def file_colon_line
21
+ @step_definition.file_colon_line
22
+ end
23
+
24
+ def backtrace_line
25
+ @step_definition.backtrace_line
26
+ end
27
+
28
+ def text_length
29
+ @step_definition.text_length
30
+ end
31
+ end
32
+
33
+ class NoStepMatch
34
+ attr_reader :step_definition
35
+
36
+ def initialize(step)
37
+ @step = step
38
+ end
39
+
40
+ def format_args(format)
41
+ @step.name
42
+ end
43
+
44
+ def file_colon_line
45
+ raise "No file:line for #{@step}" unless @step.file_colon_line
46
+ @step.file_colon_line
47
+ end
48
+
49
+ def backtrace_line
50
+ @step.backtrace_line
51
+ end
52
+
53
+ def text_length
54
+ @step.text_length
55
+ end
56
+ end
57
+ end
@@ -0,0 +1,290 @@
1
+ require 'cucumber/step_definition'
2
+ require 'cucumber/world'
3
+ require 'cucumber/core_ext/instance_exec'
4
+
5
+ module Cucumber
6
+ class Undefined < StandardError
7
+ attr_reader :step_name
8
+
9
+ def initialize(step_name)
10
+ super %{Undefined step: "#{step_name}"}
11
+ @step_name = step_name
12
+ end
13
+
14
+ def nested!
15
+ @nested = true
16
+ end
17
+
18
+ def nested?
19
+ @nested
20
+ end
21
+ end
22
+
23
+ # Raised when a StepDefinition's block invokes World#pending
24
+ class Pending < StandardError
25
+ end
26
+
27
+ # Raised when a step matches 2 or more StepDefinition
28
+ class Ambiguous < StandardError
29
+ def initialize(step_name, step_definitions, used_guess)
30
+ message = "Ambiguous match of \"#{step_name}\":\n\n"
31
+ message << step_definitions.map{|sd| sd.backtrace_line}.join("\n")
32
+ message << "\n\n"
33
+ message << "You can run again with --guess to make Cucumber be more smart about it\n" unless used_guess
34
+ super(message)
35
+ end
36
+ end
37
+
38
+ # Raised when 2 or more StepDefinition have the same Regexp
39
+ class Redundant < StandardError
40
+ def initialize(step_def_1, step_def_2)
41
+ message = "Multiple step definitions have the same Regexp:\n\n"
42
+ message << step_def_1.backtrace_line << "\n"
43
+ message << step_def_2.backtrace_line << "\n\n"
44
+ super(message)
45
+ end
46
+ end
47
+
48
+ class NilWorld < StandardError
49
+ def initialize
50
+ super("World procs should never return nil")
51
+ end
52
+ end
53
+
54
+ class MultipleWorld < StandardError
55
+ def initialize(first_proc, second_proc)
56
+ message = "You can only pass a proc to #World once, but it's happening\n"
57
+ message << "in 2 places:\n\n"
58
+ message << first_proc.backtrace_line('World') << "\n"
59
+ message << second_proc.backtrace_line('World') << "\n\n"
60
+ message << "Use Ruby modules instead to extend your worlds. See the #World RDoc.\n\n"
61
+ super(message)
62
+ end
63
+ end
64
+
65
+ # This is the main interface for registering step definitions, which is done
66
+ # from <tt>*_steps.rb</tt> files. This module is included right at the top-level
67
+ # so #register_step_definition (and more interestingly - its aliases) are
68
+ # available from the top-level.
69
+ module StepMother
70
+ class << self
71
+ def alias_adverb(adverb)
72
+ adverb = adverb.gsub(/\s/, '')
73
+ alias_method adverb, :register_step_definition
74
+ end
75
+ end
76
+
77
+ attr_writer :snippet_generator, :options, :visitor
78
+
79
+ def step_visited(step)
80
+ steps << step unless steps.index(step)
81
+ end
82
+
83
+ def steps(status = nil)
84
+ @steps ||= []
85
+ if(status)
86
+ @steps.select{|step| step.status == status}
87
+ else
88
+ @steps
89
+ end
90
+ end
91
+
92
+ def scenarios
93
+ @scenarios ||= []
94
+ end
95
+
96
+ # Registers a new StepDefinition. This method is aliased
97
+ # to <tt>Given</tt>, <tt>When</tt> and <tt>Then</tt>.
98
+ #
99
+ # See Cucumber#alias_steps for details on how to
100
+ # create your own aliases.
101
+ #
102
+ # The +&proc+ gets executed in the context of a <tt>world</tt>
103
+ # object, which is defined by #World. A new <tt>world</tt>
104
+ # object is created for each scenario and is shared across
105
+ # step definitions within that scenario.
106
+ def register_step_definition(regexp, &proc)
107
+ step_definition = StepDefinition.new(regexp, &proc)
108
+ step_definitions.each do |already|
109
+ raise Redundant.new(already, step_definition) if already.match(regexp)
110
+ end
111
+ step_definitions << step_definition
112
+ step_definition
113
+ end
114
+
115
+ # Registers a Before proc. You can call this method as many times as you
116
+ # want (typically from ruby scripts under <tt>support</tt>).
117
+ def Before(&proc)
118
+ (@before_procs ||= []) << proc
119
+ end
120
+
121
+ def After(&proc)
122
+ (@after_procs ||= []).unshift(proc)
123
+ end
124
+
125
+ # Registers any number of +world_modules+ (Ruby Modules) and/or a Proc.
126
+ # The +proc+ will be executed once before each scenario to create an
127
+ # Object that the scenario's steps will run within. Any +world_modules+
128
+ # will be mixed into this Object (via Object#extend).
129
+ #
130
+ # This method is typically called from one or more Ruby scripts under
131
+ # <tt>features/support</tt>. You can call this method as many times as you
132
+ # like (to register more modules), but if you try to register more than
133
+ # one Proc you will get an error.
134
+ #
135
+ # Cucumber will not yield anything to the +proc+ (like it used to do before v0.3).
136
+ #
137
+ # In earlier versions of Cucumber (before 0.3) you could not register
138
+ # any +world_modules+. Instead you would register several Proc objects (by
139
+ # calling the method several times). The result of each +proc+ would be yielded
140
+ # to the next +proc+. Example:
141
+ #
142
+ # World do |world| # NOT SUPPORTED FROM 0.3
143
+ # MyClass.new
144
+ # end
145
+ #
146
+ # World do |world| # NOT SUPPORTED FROM 0.3
147
+ # world.extend(MyModule)
148
+ # end
149
+ #
150
+ # From Cucumber 0.3 the recommended way to do this is:
151
+ #
152
+ # World do
153
+ # MyClass.new
154
+ # end
155
+ #
156
+ # World(MyModule)
157
+ #
158
+ def World(*world_modules, &proc)
159
+ if(proc)
160
+ raise MultipleWorld.new(@world_proc, proc) if @world_proc
161
+ @world_proc = proc
162
+ end
163
+ @world_modules ||= []
164
+ @world_modules += world_modules
165
+ end
166
+
167
+ def current_world
168
+ @current_world
169
+ end
170
+
171
+ def step_match(step_name, formatted_step_name=nil)
172
+ matches = step_definitions.map { |d| d.step_match(step_name, formatted_step_name) }.compact
173
+ raise Undefined.new(step_name) if matches.empty?
174
+ matches = best_matches(step_name, matches) if matches.size > 1 && options[:guess]
175
+ raise Ambiguous.new(step_name, matches, options[:guess]) if matches.size > 1
176
+ matches[0]
177
+ end
178
+
179
+ def best_matches(step_name, step_matches)
180
+ max_arg_length = step_matches.map {|step_match| step_match.args.length }.max
181
+ top_groups = step_matches.select {|step_match| step_match.args.length == max_arg_length }
182
+
183
+ if top_groups.length > 1
184
+ shortest_capture_length = top_groups.map {|step_match| step_match.args.inject(0) {|sum, c| sum + c.length } }.min
185
+ top_groups.select {|step_match| step_match.args.inject(0) {|sum, c| sum + c.length } == shortest_capture_length }
186
+ else
187
+ top_groups
188
+ end
189
+ end
190
+
191
+ def step_definitions
192
+ @step_definitions ||= []
193
+ end
194
+
195
+ def snippet_text(step_keyword, step_name, multiline_arg_class)
196
+ @snippet_generator.snippet_text(step_keyword, step_name, multiline_arg_class)
197
+ end
198
+
199
+ def before_and_after(scenario, skip=false)
200
+ unless current_world || skip
201
+ new_world!
202
+ execute_before(scenario)
203
+ end
204
+ if block_given?
205
+ yield
206
+ execute_after(scenario) unless skip
207
+ nil_world!
208
+ scenario_visited(scenario)
209
+ end
210
+ end
211
+
212
+ private
213
+
214
+ def max_step_definition_length
215
+ @max_step_definition_length ||= step_definitions.map{|step_definition| step_definition.text_length}.max
216
+ end
217
+
218
+ def options
219
+ @options || {}
220
+ end
221
+
222
+ # Creates a new world instance
223
+ def new_world!
224
+ create_world!
225
+ extend_world
226
+ connect_world
227
+ @current_world
228
+ end
229
+
230
+ def create_world!
231
+ if(@world_proc)
232
+ @current_world = @world_proc.call
233
+ check_nil(@current_world, @world_proc)
234
+ else
235
+ @current_world = Object.new
236
+ end
237
+ end
238
+
239
+ def extend_world
240
+ @current_world.extend(World)
241
+ @current_world.extend(::Spec::Matchers) if defined?(::Spec::Matchers)
242
+ (@world_modules || []).each do |mod|
243
+ @current_world.extend(mod)
244
+ end
245
+ end
246
+
247
+ def connect_world
248
+ @current_world.__cucumber_step_mother = self
249
+ @current_world.__cucumber_visitor = @visitor
250
+ end
251
+
252
+ def check_nil(o, proc)
253
+ if o.nil?
254
+ begin
255
+ raise NilWorld.new
256
+ rescue NilWorld => e
257
+ e.backtrace.clear
258
+ e.backtrace.push(proc.backtrace_line("World"))
259
+ raise e
260
+ end
261
+ else
262
+ o
263
+ end
264
+ end
265
+
266
+ def nil_world!
267
+ @current_world = nil
268
+ end
269
+
270
+ def execute_before(scenario)
271
+ (@before_procs ||= []).each do |proc|
272
+ @current_world.cucumber_instance_exec(false, 'Before', scenario, &proc)
273
+ end
274
+ end
275
+
276
+ def execute_after(scenario)
277
+ (@after_procs ||= []).each do |proc|
278
+ @current_world.cucumber_instance_exec(false, 'After', scenario, &proc)
279
+ end
280
+ end
281
+
282
+ def scenario_visited(scenario)
283
+ scenarios << scenario unless scenarios.index(scenario)
284
+ end
285
+
286
+ def options
287
+ @options || {}
288
+ end
289
+ end
290
+ end
@@ -0,0 +1,10 @@
1
+ module Cucumber #:nodoc:
2
+ class VERSION #:nodoc:
3
+ MAJOR = 0
4
+ MINOR = 2
5
+ TINY = 3
6
+ PATCH = 3 # Set to nil for official release
7
+
8
+ STRING = [MAJOR, MINOR, TINY, PATCH].compact.join('.')
9
+ end
10
+ end