Keep a blank line before and after private Keep a blank line before and after protected Remove extra empty line at class body end Remove extra blank line Add final newline Use 2 (not 3) spaces for indentation Use 2 (not 4) spaces for indentation Remove space before comma Add space after comma Remove trailing whitespaces Remove unnecessary spacing Use snake_case for variable names Do not use then for multi-line if Remove unused block argument - i Use the new Ruby 1.9 hash syntax Remove unused assignment to variable Indent when as deep as case Align attributes Align end with def
107 lines
3.6 KiB
Ruby
107 lines
3.6 KiB
Ruby
require 'factory_girl_rails'
|
|
require 'database_cleaner'
|
|
require 'email_spec'
|
|
require 'devise'
|
|
Dir["./spec/support/**/*.rb"].sort.each { |f| require f }
|
|
|
|
RSpec.configure do |config|
|
|
config.use_transactional_fixtures = false
|
|
|
|
config.filter_run :focus
|
|
config.run_all_when_everything_filtered = true
|
|
config.include Devise::TestHelpers, type: :controller
|
|
config.include FactoryGirl::Syntax::Methods
|
|
config.include(EmailSpec::Helpers)
|
|
config.include(EmailSpec::Matchers)
|
|
config.include(CommonActions)
|
|
config.before(:suite) do
|
|
DatabaseCleaner.clean_with :truncation
|
|
end
|
|
|
|
config.before(:suite) do
|
|
if config.use_transactional_fixtures?
|
|
raise(<<-MSG)
|
|
Delete line `config.use_transactional_fixtures = true` from rails_helper.rb
|
|
(or set it to false) to prevent uncommitted transactions being used in
|
|
JavaScript-dependent specs.
|
|
|
|
During testing, the app-under-test that the browser driver connects to
|
|
uses a different database connection to the database connection used by
|
|
the spec. The app's database connection would not be able to access
|
|
uncommitted transaction data setup over the spec's database connection.
|
|
MSG
|
|
end
|
|
DatabaseCleaner.clean_with(:truncation)
|
|
end
|
|
|
|
config.before(:each) do |example|
|
|
DatabaseCleaner.strategy = :transaction
|
|
I18n.locale = :en
|
|
load "#{Rails.root}/db/seeds.rb"
|
|
end
|
|
|
|
config.before(:each, type: :feature) do
|
|
# :rack_test driver's Rack app under test shares database connection
|
|
# with the specs, so continue to use transaction strategy for speed.
|
|
driver_shares_db_connection_with_specs = Capybara.current_driver == :rack_test
|
|
|
|
if !driver_shares_db_connection_with_specs
|
|
# Driver is probably for an external browser with an app
|
|
# under test that does *not* share a database connection with the
|
|
# specs, so use truncation strategy.
|
|
DatabaseCleaner.strategy = :truncation
|
|
end
|
|
end
|
|
|
|
config.before(:each) do
|
|
DatabaseCleaner.start
|
|
end
|
|
|
|
config.append_after(:each) do
|
|
DatabaseCleaner.clean
|
|
end
|
|
|
|
config.before(:each, type: :feature) do
|
|
Bullet.start_request
|
|
allow(InvisibleCaptcha).to receive(:timestamp_threshold).and_return(0)
|
|
end
|
|
|
|
config.after(:each, type: :feature) do
|
|
Bullet.perform_out_of_channel_notifications if Bullet.notification?
|
|
Bullet.end_request
|
|
end
|
|
|
|
# Allows RSpec to persist some state between runs in order to support
|
|
# the `--only-failures` and `--next-failure` CLI options.
|
|
config.example_status_persistence_file_path = "spec/examples.txt"
|
|
|
|
# Many RSpec users commonly either run the entire suite or an individual
|
|
# file, and it's useful to allow more verbose output when running an
|
|
# individual spec file.
|
|
if config.files_to_run.one?
|
|
# Use the documentation formatter for detailed output,
|
|
# unless a formatter has already been configured
|
|
# (e.g. via a command-line flag).
|
|
config.default_formatter = 'doc'
|
|
end
|
|
|
|
# Print the 10 slowest examples and example groups at the
|
|
# end of the spec run, to help surface which specs are running
|
|
# particularly slow.
|
|
config.profile_examples = 10
|
|
|
|
# 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
|
|
|
|
# Seed global randomization in this process using the `--seed` CLI option.
|
|
# Setting this allows you to use `--seed` to deterministically reproduce
|
|
# test failures related to randomization by passing the same `--seed` value
|
|
# as the one that triggered the failure.
|
|
Kernel.srand config.seed
|
|
|
|
|
|
end
|