10 changed files with 221 additions and 0 deletions
			
			
		| @ -0,0 +1,9 @@ | ||||
| <% | ||||
| rerun = File.file?('rerun.txt') ? IO.read('rerun.txt') : "" | ||||
| rerun = rerun.strip.gsub /\s/, ' ' | ||||
| rerun_opts = rerun.empty? ? "--format #{ENV['CUCUMBER_FORMAT'] || 'progress'} features" : "--format #{ENV['CUCUMBER_FORMAT'] || 'pretty'} #{rerun}" | ||||
| std_opts = "--format #{ENV['CUCUMBER_FORMAT'] || 'pretty'} --strict --tags 'not @wip'" | ||||
| %> | ||||
| default: <%= std_opts %> features | ||||
| wip: --tags @wip:3 --wip features | ||||
| rerun: <%= rerun_opts %> --format rerun --out rerun.txt --strict --tags 'not @wip' | ||||
| @ -0,0 +1,9 @@ | ||||
| Feature: Sign in | ||||
| 
 | ||||
|   @wip | ||||
|   Scenario: Signing in | ||||
|     Given There is a user in the database | ||||
|     When I visit the sign in page | ||||
|     And I fill in the sign in form | ||||
|     And I click the sign in button | ||||
|     Then I should see the logs page | ||||
| @ -0,0 +1,60 @@ | ||||
| # IMPORTANT: This file is generated by cucumber-rails - edit at your own peril. | ||||
| # It is recommended to regenerate this file in the future when you upgrade to a | ||||
| # newer version of cucumber-rails. Consider adding your own code to a new file | ||||
| # instead of editing this one. Cucumber will automatically load all features/**/*.rb | ||||
| # files. | ||||
| 
 | ||||
| require 'cucumber/rails' | ||||
| 
 | ||||
| # frozen_string_literal: true | ||||
| 
 | ||||
| # Capybara defaults to CSS3 selectors rather than XPath. | ||||
| # If you'd prefer to use XPath, just uncomment this line and adjust any | ||||
| # selectors in your step definitions to use the XPath syntax. | ||||
| # Capybara.default_selector = :xpath | ||||
| 
 | ||||
| # By default, any exception happening in your Rails application will bubble up | ||||
| # to Cucumber so that your scenario will fail. This is a different from how | ||||
| # your application behaves in the production environment, where an error page will | ||||
| # be rendered instead. | ||||
| # | ||||
| # Sometimes we want to override this default behaviour and allow Rails to rescue | ||||
| # exceptions and display an error page (just like when the app is running in production). | ||||
| # Typical scenarios where you want to do this is when you test your error pages. | ||||
| # There are two ways to allow Rails to rescue exceptions: | ||||
| # | ||||
| # 1) Tag your scenario (or feature) with @allow-rescue | ||||
| # | ||||
| # 2) Set the value below to true. Beware that doing this globally is not | ||||
| # recommended as it will mask a lot of errors for you! | ||||
| # | ||||
| ActionController::Base.allow_rescue = false | ||||
| 
 | ||||
| # Remove/comment out the lines below if your app doesn't have a database. | ||||
| # For some databases (like MongoDB and CouchDB) you may need to use :truncation instead. | ||||
| begin | ||||
|   DatabaseCleaner.strategy = :transaction | ||||
| rescue NameError | ||||
|   raise "You need to add database_cleaner to your Gemfile (in the :test group) if you wish to use it." | ||||
| end | ||||
| 
 | ||||
| # You may also want to configure DatabaseCleaner to use different strategies for certain features and scenarios. | ||||
| # See the DatabaseCleaner documentation for details. Example: | ||||
| # | ||||
| #   Before('@no-txn,@selenium,@culerity,@celerity,@javascript') do | ||||
| #     # { except: [:widgets] } may not do what you expect here | ||||
| #     # as Cucumber::Rails::Database.javascript_strategy overrides | ||||
| #     # this setting. | ||||
| #     DatabaseCleaner.strategy = :truncation | ||||
| #   end | ||||
| # | ||||
| #   Before('not @no-txn', 'not @selenium', 'not @culerity', 'not @celerity', 'not @javascript') do | ||||
| #     DatabaseCleaner.strategy = :transaction | ||||
| #   end | ||||
| # | ||||
| 
 | ||||
| # Possible values are :truncation and :transaction | ||||
| # The :transaction strategy is faster, but might give you threading problems. | ||||
| # See https://github.com/cucumber/cucumber-rails/blob/master/features/choose_javascript_database_strategy.feature | ||||
| Cucumber::Rails::Database.javascript_strategy = :truncation | ||||
| 
 | ||||
| @ -0,0 +1,69 @@ | ||||
| # IMPORTANT: This file is generated by cucumber-rails - edit at your own peril. | ||||
| # It is recommended to regenerate this file in the future when you upgrade to a | ||||
| # newer version of cucumber-rails. Consider adding your own code to a new file | ||||
| # instead of editing this one. Cucumber will automatically load all features/**/*.rb | ||||
| # files. | ||||
| 
 | ||||
| 
 | ||||
| unless ARGV.any? {|a| a =~ /^gems/} # Don't load anything when running the gems:* tasks | ||||
| 
 | ||||
| vendored_cucumber_bin = Dir["#{Rails.root}/vendor/{gems,plugins}/cucumber*/bin/cucumber"].first | ||||
| $LOAD_PATH.unshift(File.dirname(vendored_cucumber_bin) + '/../lib') unless vendored_cucumber_bin.nil? | ||||
| 
 | ||||
| begin | ||||
|   require 'cucumber/rake/task' | ||||
| 
 | ||||
|   namespace :cucumber do | ||||
|     Cucumber::Rake::Task.new({ok: 'test:prepare'}, 'Run features that should pass') do |t| | ||||
|       t.binary = vendored_cucumber_bin # If nil, the gem's binary is used. | ||||
|       t.fork = true # You may get faster startup if you set this to false | ||||
|       t.profile = 'default' | ||||
|     end | ||||
| 
 | ||||
|     Cucumber::Rake::Task.new({wip: 'test:prepare'}, 'Run features that are being worked on') do |t| | ||||
|       t.binary = vendored_cucumber_bin | ||||
|       t.fork = true # You may get faster startup if you set this to false | ||||
|       t.profile = 'wip' | ||||
|     end | ||||
| 
 | ||||
|     Cucumber::Rake::Task.new({rerun: 'test:prepare'}, 'Record failing features and run only them if any exist') do |t| | ||||
|       t.binary = vendored_cucumber_bin | ||||
|       t.fork = true # You may get faster startup if you set this to false | ||||
|       t.profile = 'rerun' | ||||
|     end | ||||
| 
 | ||||
|     desc 'Run all features' | ||||
|     task all: [:ok, :wip] | ||||
| 
 | ||||
|     task :statsetup do | ||||
|       require 'rails/code_statistics' | ||||
|       ::STATS_DIRECTORIES << %w(Cucumber\ features features) if File.exist?('features') | ||||
|       ::CodeStatistics::TEST_TYPES << "Cucumber features" if File.exist?('features') | ||||
|     end | ||||
|      | ||||
|   end | ||||
| 
 | ||||
|   desc 'Alias for cucumber:ok' | ||||
|   task cucumber: 'cucumber:ok' | ||||
| 
 | ||||
|   task default: :cucumber | ||||
| 
 | ||||
|   task features: :cucumber do | ||||
|     STDERR.puts "*** The 'features' task is deprecated. See rake -T cucumber ***" | ||||
|   end | ||||
| 
 | ||||
|   # In case we don't have the generic Rails test:prepare hook, append a no-op task that we can depend upon. | ||||
|   task 'test:prepare' do | ||||
|   end | ||||
| 
 | ||||
|   task stats: 'cucumber:statsetup' | ||||
| 
 | ||||
|    | ||||
| rescue LoadError | ||||
|   desc 'cucumber rake task not available (cucumber not installed)' | ||||
|   task :cucumber do | ||||
|     abort 'Cucumber rake task is not available. Be sure to install cucumber as a gem or plugin' | ||||
|   end | ||||
| end | ||||
| 
 | ||||
| end | ||||
| @ -0,0 +1,11 @@ | ||||
| #!/usr/bin/env ruby | ||||
| # frozen_string_literal: true | ||||
| 
 | ||||
| vendored_cucumber_bin = Dir["#{File.dirname(__FILE__)}/../vendor/{gems,plugins}/cucumber*/bin/cucumber"].first | ||||
| if vendored_cucumber_bin | ||||
|   load File.expand_path(vendored_cucumber_bin) | ||||
| else | ||||
|   require 'rubygems' unless ENV['NO_RUBYGEMS'] | ||||
|   require 'cucumber' | ||||
|   load Cucumber::BINARY | ||||
| end | ||||
					Loading…
					
					
				
		Reference in new issue