cavalle-cucumber 0.2.3.3.1
Sign up to get free protection for your applications and to get access to all the features.
- data/History.txt +556 -0
- data/License.txt +20 -0
- data/Manifest.txt +345 -0
- data/README.txt +4 -0
- data/Rakefile +8 -0
- data/bin/cucumber +6 -0
- data/config/hoe.rb +76 -0
- data/config/requirements.rb +15 -0
- data/cucumber.yml +1 -0
- data/examples/cs/README.textile +1 -0
- data/examples/cs/Rakefile +12 -0
- data/examples/cs/compile.bat +1 -0
- data/examples/cs/features/addition.feature +16 -0
- data/examples/cs/features/step_definitons/calculator_steps.rb +19 -0
- data/examples/cs/src/demo/Calculator.cs +20 -0
- data/examples/dos_line_endings/Rakefile +6 -0
- data/examples/dos_line_endings/features/dos_line_endings.feature +9 -0
- data/examples/i18n/README.textile +18 -0
- data/examples/i18n/Rakefile +30 -0
- data/examples/i18n/ar/Rakefile +6 -0
- data/examples/i18n/ar/features/addition.feature +16 -0
- data/examples/i18n/ar/features/step_definitons/calculator_steps.rb +24 -0
- data/examples/i18n/ar/lib/calculator.rb +11 -0
- data/examples/i18n/bg/Rakefile +6 -0
- data/examples/i18n/bg/features/addition.feature +11 -0
- data/examples/i18n/bg/features/consecutive_calculations.feature +18 -0
- data/examples/i18n/bg/features/division.feature +16 -0
- data/examples/i18n/bg/features/step_definitons/calculator_steps.rb +24 -0
- data/examples/i18n/bg/features/support/env.rb +6 -0
- data/examples/i18n/bg/features/support/world.rb +8 -0
- data/examples/i18n/bg/lib/calculator.rb +24 -0
- data/examples/i18n/da/Rakefile +6 -0
- data/examples/i18n/da/features/step_definitons/kalkulator_steps.rb +24 -0
- data/examples/i18n/da/features/summering.feature +17 -0
- data/examples/i18n/da/lib/kalkulator.rb +11 -0
- data/examples/i18n/de/Rakefile +6 -0
- data/examples/i18n/de/features/addition.feature +16 -0
- data/examples/i18n/de/features/division.feature +9 -0
- data/examples/i18n/de/features/step_definitons/calculator_steps.rb +24 -0
- data/examples/i18n/de/lib/calculator.rb +14 -0
- data/examples/i18n/en/Rakefile +6 -0
- data/examples/i18n/en/features/addition.feature +16 -0
- data/examples/i18n/en/features/division.feature +9 -0
- data/examples/i18n/en/features/step_definitons/calculator_steps.rb +24 -0
- data/examples/i18n/en/lib/calculator.rb +14 -0
- data/examples/i18n/en-lol/Rakefile +6 -0
- data/examples/i18n/en-lol/features/step_definitions/cucumbrz_steps.rb +16 -0
- data/examples/i18n/en-lol/features/stuffing.feature +8 -0
- data/examples/i18n/en-lol/features/support/env.rb +8 -0
- data/examples/i18n/en-lol/lib/basket.rb +12 -0
- data/examples/i18n/en-lol/lib/belly.rb +11 -0
- data/examples/i18n/es/Rakefile +6 -0
- data/examples/i18n/es/features/adicion.feature +16 -0
- data/examples/i18n/es/features/step_definitons/calculador_steps.rb +21 -0
- data/examples/i18n/es/lib/calculador.rb +14 -0
- data/examples/i18n/et/Rakefile +6 -0
- data/examples/i18n/et/features/jagamine.feature +9 -0
- data/examples/i18n/et/features/liitmine.feature +16 -0
- data/examples/i18n/et/features/step_definitions/kalkulaator_steps.rb +24 -0
- data/examples/i18n/et/lib/kalkulaator.rb +14 -0
- data/examples/i18n/fi/Rakefile +6 -0
- data/examples/i18n/fi/features/jakolasku.feature +9 -0
- data/examples/i18n/fi/features/step_definitons/laskin_steps.rb +24 -0
- data/examples/i18n/fi/features/yhteenlasku.feature +16 -0
- data/examples/i18n/fi/lib/laskin.rb +14 -0
- data/examples/i18n/fr/Rakefile +6 -0
- data/examples/i18n/fr/features/addition.feature +17 -0
- data/examples/i18n/fr/features/step_definitions/calculatrice_steps.rb +25 -0
- data/examples/i18n/fr/lib/calculatrice.rb +10 -0
- data/examples/i18n/id/Rakefile +6 -0
- data/examples/i18n/id/features/addition.feature +16 -0
- data/examples/i18n/id/features/division.feature +9 -0
- data/examples/i18n/id/features/step_definitons/calculator_steps.rb +24 -0
- data/examples/i18n/id/lib/calculator.rb +14 -0
- data/examples/i18n/it/Rakefile +6 -0
- data/examples/i18n/it/features/somma.feature +10 -0
- data/examples/i18n/it/features/step_definitons/calcolatrice_steps.rb +24 -0
- data/examples/i18n/it/lib/calcolatrice.rb +11 -0
- data/examples/i18n/ja/Rakefile +6 -0
- data/examples/i18n/ja/features/addition.feature +16 -0
- data/examples/i18n/ja/features/division.feature +9 -0
- data/examples/i18n/ja/features/step_definitons/calculator_steps.rb +24 -0
- data/examples/i18n/ja/lib/calculator.rb +14 -0
- data/examples/i18n/ko/Rakefile +6 -0
- data/examples/i18n/ko/features/addition.feature +16 -0
- data/examples/i18n/ko/features/division.feature +10 -0
- data/examples/i18n/ko/features/step_definitons/calculator_steps.rb +24 -0
- data/examples/i18n/ko/lib/calculator.rb +14 -0
- data/examples/i18n/lt/Rakefile +6 -0
- data/examples/i18n/lt/features/addition.feature +17 -0
- data/examples/i18n/lt/features/division.feature +9 -0
- data/examples/i18n/lt/features/step_definitons/calculator_steps.rb +24 -0
- data/examples/i18n/lt/lib/calculator.rb +14 -0
- data/examples/i18n/no/Rakefile +6 -0
- data/examples/i18n/no/features/step_definitons/kalkulator_steps.rb +17 -0
- data/examples/i18n/no/features/summering.feature +18 -0
- data/examples/i18n/no/features/support/env.rb +6 -0
- data/examples/i18n/no/lib/kalkulator.rb +11 -0
- data/examples/i18n/pt/Rakefile +6 -0
- data/examples/i18n/pt/features/adicao.feature +10 -0
- data/examples/i18n/pt/features/step_definitions/calculadora_steps.rb +24 -0
- data/examples/i18n/pt/lib/calculadora.rb +10 -0
- data/examples/i18n/ro/Rakefile +6 -0
- data/examples/i18n/ro/features/step_definitons/calculator_steps.rb +24 -0
- data/examples/i18n/ro/features/suma.feature +10 -0
- data/examples/i18n/ro/lib/calculator.rb +11 -0
- data/examples/i18n/ru/Rakefile +6 -0
- data/examples/i18n/ru/features/addition.feature +10 -0
- data/examples/i18n/ru/features/consecutive_calculations.feature +16 -0
- data/examples/i18n/ru/features/division.feature +15 -0
- data/examples/i18n/ru/features/step_definitons/calculator_steps.rb +19 -0
- data/examples/i18n/ru/features/support/env.rb +6 -0
- data/examples/i18n/ru/features/support/world.rb +8 -0
- data/examples/i18n/ru/lib/calculator.rb +24 -0
- data/examples/i18n/se/Rakefile +6 -0
- data/examples/i18n/se/features/step_definitons/kalkulator_steps.rb +24 -0
- data/examples/i18n/se/features/summering.feature +17 -0
- data/examples/i18n/se/lib/kalkulator.rb +11 -0
- data/examples/i18n/sk/Rakefile +6 -0
- data/examples/i18n/sk/features/addition.feature +16 -0
- data/examples/i18n/sk/features/division.feature +9 -0
- data/examples/i18n/sk/features/step_definitons/calculator_steps.rb +24 -0
- data/examples/i18n/sk/lib/calculator.rb +14 -0
- data/examples/i18n/zh-CN/Rakefile +6 -0
- data/examples/i18n/zh-CN/features/addition.feature +17 -0
- data/examples/i18n/zh-CN/features/step_definitons/calculator_steps.rb +26 -0
- data/examples/i18n/zh-CN/lib/calculator.rb +10 -0
- data/examples/i18n/zh-TW/Rakefile +6 -0
- data/examples/i18n/zh-TW/features/addition.feature +16 -0
- data/examples/i18n/zh-TW/features/division.feature +10 -0
- data/examples/i18n/zh-TW/features/step_definitons/calculator_steps.rb +24 -0
- data/examples/i18n/zh-TW/lib/calculator.rb +14 -0
- data/examples/java/README.textile +22 -0
- data/examples/java/Rakefile +12 -0
- data/examples/java/features/hello.feature +11 -0
- data/examples/java/features/step_definitons/hello_steps.rb +25 -0
- data/examples/java/features/step_definitons/tree_steps.rb +14 -0
- data/examples/java/features/tree.feature +9 -0
- data/examples/java/src/cucumber/demo/Hello.java +16 -0
- data/examples/pure_java/README.textile +5 -0
- data/examples/selenium/Rakefile +6 -0
- data/examples/selenium/features/search.feature +9 -0
- data/examples/selenium/features/step_definitons/search_steps.rb +13 -0
- data/examples/selenium/features/support/env.rb +19 -0
- data/examples/selenium_webrat/Rakefile +6 -0
- data/examples/selenium_webrat/features/search.feature +9 -0
- data/examples/selenium_webrat/features/step_definitons/search_steps.rb +13 -0
- data/examples/selenium_webrat/features/support/env.rb +41 -0
- data/examples/self_test/README.textile +6 -0
- data/examples/self_test/Rakefile +6 -0
- data/examples/self_test/features/background/background_with_name.feature +7 -0
- data/examples/self_test/features/background/failing_background.feature +11 -0
- data/examples/self_test/features/background/failing_background_after_success.feature +11 -0
- data/examples/self_test/features/background/multiline_args_background.feature +32 -0
- data/examples/self_test/features/background/passing_background.feature +10 -0
- data/examples/self_test/features/background/pending_background.feature +10 -0
- data/examples/self_test/features/background/scenario_outline_failing_background.feature +16 -0
- data/examples/self_test/features/background/scenario_outline_passing_background.feature +16 -0
- data/examples/self_test/features/call_undefined_step_from_step_def.feature +7 -0
- data/examples/self_test/features/failing_expectation.feature +4 -0
- data/examples/self_test/features/lots_of_undefined.feature +8 -0
- data/examples/self_test/features/outline_sample.feature +15 -0
- data/examples/self_test/features/sample.feature +19 -0
- data/examples/self_test/features/step_definitions/sample_steps.rb +70 -0
- data/examples/self_test/features/support/env.rb +1 -0
- data/examples/self_test/features/support/tag_count_formatter.rb +25 -0
- data/examples/self_test/features/tons_of_cukes.feature +52 -0
- data/examples/self_test/features/undefined_multiline_args.feature +12 -0
- data/examples/sinatra/Rakefile +6 -0
- data/examples/sinatra/app.rb +14 -0
- data/examples/sinatra/features/add.feature +11 -0
- data/examples/sinatra/features/step_definitions/add_steps.rb +15 -0
- data/examples/sinatra/features/support/env.rb +20 -0
- data/examples/sinatra/views/add.erb +5 -0
- data/examples/sinatra/views/layout.erb +8 -0
- data/examples/test_unit/Rakefile +6 -0
- data/examples/test_unit/features/step_definitions/test_unit_steps.rb +23 -0
- data/examples/test_unit/features/test_unit.feature +9 -0
- data/examples/tickets/Rakefile +16 -0
- data/examples/tickets/features/172.feature +28 -0
- data/examples/tickets/features/177/1.feature +29 -0
- data/examples/tickets/features/177/2.feature +21 -0
- data/examples/tickets/features/177/3.feature +18 -0
- data/examples/tickets/features/180.feature +7 -0
- data/examples/tickets/features/236.feature +13 -0
- data/examples/tickets/features/241.feature +13 -0
- data/examples/tickets/features/246.feature +4 -0
- data/examples/tickets/features/248.feature +11 -0
- data/examples/tickets/features/270/back.feature +14 -0
- data/examples/tickets/features/270/back.steps.rb +14 -0
- data/examples/tickets/features/lib/eatting_machine.rb +18 -0
- data/examples/tickets/features/lib/pantry.rb +20 -0
- data/examples/tickets/features/scenario_outline.feature +95 -0
- data/examples/tickets/features/step_definitons/246_steps.rb +3 -0
- data/examples/tickets/features/step_definitons/248_steps.rb +15 -0
- data/examples/tickets/features/step_definitons/scenario_outline_steps.rb +42 -0
- data/examples/tickets/features/step_definitons/tickets_steps.rb +73 -0
- data/examples/tickets/features/tickets.feature +28 -0
- data/examples/watir/README.textile +16 -0
- data/examples/watir/Rakefile +6 -0
- data/examples/watir/features/search.feature +9 -0
- data/examples/watir/features/step_definitons/search_steps.rb +24 -0
- data/examples/watir/features/support/env.rb +32 -0
- data/features/background.feature +238 -0
- data/features/cucumber_cli.feature +402 -0
- data/features/cucumber_cli_diff_disabled.feature +45 -0
- data/features/cucumber_cli_outlines.feature +84 -0
- data/features/custom_formatter.feature +11 -0
- data/features/report_called_undefined_steps.feature +34 -0
- data/features/snippet.feature +23 -0
- data/features/step_definitions/cucumber_steps.rb +34 -0
- data/features/step_definitions/extra_steps.rb +2 -0
- data/features/support/env.rb +8 -0
- data/features/usage.feature +113 -0
- data/gem_tasks/deployment.rake +11 -0
- data/gem_tasks/environment.rake +7 -0
- data/gem_tasks/features.rake +6 -0
- data/gem_tasks/fix_cr_lf.rake +10 -0
- data/gem_tasks/flog.rake +4 -0
- data/gem_tasks/gemspec.rake +10 -0
- data/gem_tasks/rspec.rake +38 -0
- data/gem_tasks/yard.rake +8 -0
- data/lib/autotest/cucumber.rb +6 -0
- data/lib/autotest/cucumber_mixin.rb +125 -0
- data/lib/autotest/cucumber_rails.rb +6 -0
- data/lib/autotest/cucumber_rails_rspec.rb +6 -0
- data/lib/autotest/cucumber_rspec.rb +6 -0
- data/lib/autotest/discover.rb +9 -0
- data/lib/cucumber/ast/background.rb +50 -0
- data/lib/cucumber/ast/comment.rb +26 -0
- data/lib/cucumber/ast/examples.rb +26 -0
- data/lib/cucumber/ast/feature.rb +52 -0
- data/lib/cucumber/ast/feature_element.rb +38 -0
- data/lib/cucumber/ast/features.rb +26 -0
- data/lib/cucumber/ast/outline_table.rb +73 -0
- data/lib/cucumber/ast/py_string.rb +53 -0
- data/lib/cucumber/ast/scenario.rb +57 -0
- data/lib/cucumber/ast/scenario_outline.rb +80 -0
- data/lib/cucumber/ast/step.rb +105 -0
- data/lib/cucumber/ast/step_collection.rb +62 -0
- data/lib/cucumber/ast/step_invocation.rb +117 -0
- data/lib/cucumber/ast/table.rb +326 -0
- data/lib/cucumber/ast/tags.rb +25 -0
- data/lib/cucumber/ast/visitor.rb +112 -0
- data/lib/cucumber/ast.rb +29 -0
- data/lib/cucumber/broadcaster.rb +13 -0
- data/lib/cucumber/cli/configuration.rb +361 -0
- data/lib/cucumber/cli/language_help_formatter.rb +59 -0
- data/lib/cucumber/cli/main.rb +105 -0
- data/lib/cucumber/core_ext/exception.rb +53 -0
- data/lib/cucumber/core_ext/instance_exec.rb +67 -0
- data/lib/cucumber/core_ext/proc.rb +33 -0
- data/lib/cucumber/core_ext/string.rb +48 -0
- data/lib/cucumber/formatter/ansicolor.rb +110 -0
- data/lib/cucumber/formatter/color_io.rb +23 -0
- data/lib/cucumber/formatter/console.rb +110 -0
- data/lib/cucumber/formatter/cucumber.css +55 -0
- data/lib/cucumber/formatter/cucumber.sass +49 -0
- data/lib/cucumber/formatter/html.rb +186 -0
- data/lib/cucumber/formatter/pretty.rb +185 -0
- data/lib/cucumber/formatter/profile.rb +77 -0
- data/lib/cucumber/formatter/progress.rb +60 -0
- data/lib/cucumber/formatter/rerun.rb +43 -0
- data/lib/cucumber/formatter/unicode.rb +35 -0
- data/lib/cucumber/formatter/usage.rb +85 -0
- data/lib/cucumber/formatter.rb +1 -0
- data/lib/cucumber/formatters/unicode.rb +2 -0
- data/lib/cucumber/languages.yml +455 -0
- data/lib/cucumber/parser/feature.rb +1590 -0
- data/lib/cucumber/parser/feature.tt +288 -0
- data/lib/cucumber/parser/i18n.tt +35 -0
- data/lib/cucumber/parser/table.rb +414 -0
- data/lib/cucumber/parser/table.tt +71 -0
- data/lib/cucumber/parser/treetop_ext.rb +114 -0
- data/lib/cucumber/parser.rb +38 -0
- data/lib/cucumber/platform.rb +17 -0
- data/lib/cucumber/rails/rspec.rb +8 -0
- data/lib/cucumber/rails/world.rb +74 -0
- data/lib/cucumber/rake/task.rb +138 -0
- data/lib/cucumber/step_definition.rb +113 -0
- data/lib/cucumber/step_match.rb +57 -0
- data/lib/cucumber/step_mother.rb +290 -0
- data/lib/cucumber/version.rb +10 -0
- data/lib/cucumber/world.rb +53 -0
- data/lib/cucumber.rb +63 -0
- data/rails_generators/cucumber/USAGE +11 -0
- data/rails_generators/cucumber/cucumber_generator.rb +50 -0
- data/rails_generators/cucumber/templates/cucumber +8 -0
- data/rails_generators/cucumber/templates/cucumber.rake +15 -0
- data/rails_generators/cucumber/templates/env.rb +19 -0
- data/rails_generators/cucumber/templates/paths.rb +29 -0
- data/rails_generators/cucumber/templates/webrat_steps.rb +123 -0
- data/rails_generators/feature/USAGE +12 -0
- data/rails_generators/feature/feature_generator.rb +40 -0
- data/rails_generators/feature/templates/feature.erb +31 -0
- data/rails_generators/feature/templates/steps.erb +20 -0
- data/spec/cucumber/ast/background_spec.rb +50 -0
- data/spec/cucumber/ast/feature_factory.rb +63 -0
- data/spec/cucumber/ast/feature_spec.rb +38 -0
- data/spec/cucumber/ast/py_string_spec.rb +47 -0
- data/spec/cucumber/ast/scenario_outline_spec.rb +67 -0
- data/spec/cucumber/ast/scenario_spec.rb +38 -0
- data/spec/cucumber/ast/step_collection_spec.rb +16 -0
- data/spec/cucumber/ast/step_spec.rb +66 -0
- data/spec/cucumber/ast/table_spec.rb +170 -0
- data/spec/cucumber/broadcaster_spec.rb +15 -0
- data/spec/cucumber/cli/configuration_spec.rb +287 -0
- data/spec/cucumber/cli/main_spec.rb +191 -0
- data/spec/cucumber/core_ext/proc_spec.rb +54 -0
- data/spec/cucumber/core_ext/string_spec.rb +42 -0
- data/spec/cucumber/formatter/ansicolor_spec.rb +35 -0
- data/spec/cucumber/formatter/color_io_spec.rb +26 -0
- data/spec/cucumber/formatter/html/cucumber.css +37 -0
- data/spec/cucumber/formatter/html/cucumber.js +13 -0
- data/spec/cucumber/formatter/html/index.html +45 -0
- data/spec/cucumber/formatter/html/jquery-1.3.min.js +19 -0
- data/spec/cucumber/formatter/html/jquery.uitableedit.js +100 -0
- data/spec/cucumber/formatters/profile_formatter_spec.rb +198 -0
- data/spec/cucumber/parser/feature_parser_spec.rb +284 -0
- data/spec/cucumber/parser/table_parser_spec.rb +48 -0
- data/spec/cucumber/rails/stubs/mini_rails.rb +18 -0
- data/spec/cucumber/rails/stubs/test_help.rb +1 -0
- data/spec/cucumber/rails/world_spec.rb +11 -0
- data/spec/cucumber/sell_cucumbers.feature +19 -0
- data/spec/cucumber/step_definition_spec.rb +101 -0
- data/spec/cucumber/step_mother_spec.rb +137 -0
- data/spec/cucumber/treetop_parser/empty_feature.feature +4 -0
- data/spec/cucumber/treetop_parser/empty_scenario.feature +9 -0
- data/spec/cucumber/treetop_parser/empty_scenario_outline.feature +3 -0
- data/spec/cucumber/treetop_parser/fit_scenario.feature +8 -0
- data/spec/cucumber/treetop_parser/given_scenario.feature +9 -0
- data/spec/cucumber/treetop_parser/invalid_scenario_outlines.feature +7 -0
- data/spec/cucumber/treetop_parser/multiline_steps.feature +17 -0
- data/spec/cucumber/treetop_parser/multiple_tables.feature +27 -0
- data/spec/cucumber/treetop_parser/scenario_outline.feature +16 -0
- data/spec/cucumber/treetop_parser/spaces.feature +12 -0
- data/spec/cucumber/treetop_parser/test_dos.feature +25 -0
- data/spec/cucumber/treetop_parser/with_comments.feature +10 -0
- data/spec/cucumber/treetop_parser/with_tags.feature +18 -0
- data/spec/cucumber/world/pending_spec.rb +47 -0
- data/spec/spec.opts +2 -0
- data/spec/spec_helper.rb +12 -0
- 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
|