# This file is copied to spec/ when you run 'rails generate rspec:install' ENV["RAILS_ENV"] ||= 'test' require 'simplecov' SimpleCov.start do add_filter '/app/assets/' add_filter '/app/views/' add_filter '/config/' add_filter '/db/' add_filter '/doc/' add_filter '/log/' add_filter '/public/' add_filter '/script/' add_filter '/spec/' end require File.expand_path("../../config/environment", __FILE__) require 'rspec/rails' Dir[Rails.root.join("spec/support/**/*.rb")].each { |f| require f } require 'rspec/autorun' require 'capybara/rails' require 'capybara/rspec' require 'capybara/rspec' require 'capybara/poltergeist' require 'database_cleaner' Capybara.register_driver :poltergeist_with_long_timeout do |app| Capybara::Poltergeist::Driver.new(app, timeout: 30) end Capybara.javascript_driver = :poltergeist_with_long_timeout # Requires supporting ruby files with custom matchers and macros, etc, # in spec/support/ and its subdirectories. Dir[Rails.root.join("spec/support/**/*.rb")].each { |f| require f } # Checks for pending migrations before tests are run. # If you are not using ActiveRecord, you can remove this line. ActiveRecord::Migration.check_pending! if defined?(ActiveRecord::Migration) RSpec.configure do |config| # If you're not using ActiveRecord, or you'd prefer not to run each of your # examples within a transaction, remove the following line or assign false # instead of true. config.use_transactional_fixtures = false # If true, the base class of anonymous controllers will be inferred # automatically. This will be the default behavior in future versions of # rspec-rails. config.infer_base_class_for_anonymous_controllers = false # Run specs in random order to surface order dependencies. If you find an # order dependency and want to debug it, you can fix the order by providing # the seed, which is printed after each run. # --seed 1234 config.order = "random" config.include CapybaraExt #config.extend AuthorizationHelpers::Controller, type: :controller config.include FactoryGirl::Syntax::Methods config.before(:suite) do DatabaseCleaner.strategy = :transaction DatabaseCleaner.clean_with(:truncation) end # Feature specs cannot use a transaction because Capybara runs in a # separate thread with a different database connection. config.before type: :request do DatabaseCleaner.strategy = :truncation end # Reset so other non-feature specs don't have to deal with slow truncation. config.after type: :request do DatabaseCleaner.strategy = :transaction end config.before do DatabaseCleaner.start ActionMailer::Base.deliveries.clear end config.after do DatabaseCleaner.clean end end