250 lines
7.0 KiB
Ruby
250 lines
7.0 KiB
Ruby
|
|
# temporary to debug failing tests on the build server
|
|
def bputs(msg)
|
|
if ENV["BUILD_PUTS"] == "1"
|
|
puts msg
|
|
end
|
|
end
|
|
|
|
bputs "before simplecov"
|
|
|
|
require 'simplecov'
|
|
bputs "before rubygems"
|
|
require 'rubygems'
|
|
bputs "before omniauth"
|
|
#require 'spork'
|
|
require 'omniauth'
|
|
#uncomment the following line to use spork with the debugger
|
|
#require 'spork/ext/ruby-debug'
|
|
|
|
|
|
ENV["RAILS_ENV"] ||= 'test'
|
|
|
|
bputs "before activerecord load"
|
|
|
|
require 'active_record'
|
|
require 'action_mailer'
|
|
require 'jam_db'
|
|
require "#{File.dirname(__FILE__)}/spec_db"
|
|
|
|
bputs "before db_config load"
|
|
|
|
# recreate test database and migrate it
|
|
db_config = YAML::load(File.open('config/database.yml'))["test"]
|
|
# initialize ActiveRecord's db connection\
|
|
|
|
bputs "before recreate db"
|
|
SpecDb::recreate_database(db_config)
|
|
|
|
bputs "before connect db"
|
|
ActiveRecord::Base.establish_connection(YAML::load(File.open('config/database.yml'))["test"])
|
|
|
|
bputs "before load jam_ruby"
|
|
require 'jam_ruby'
|
|
|
|
# uncomment this to see active record logs
|
|
# ActiveRecord::Base.logger = Logger.new(STDOUT) if defined?(ActiveRecord::Base)
|
|
|
|
include JamRuby
|
|
# put ActionMailer into test mode
|
|
ActionMailer::Base.delivery_method = :test
|
|
RecordedTrack.observers.disable :all # only a few tests want this observer active
|
|
|
|
# a way to kill tests if they aren't running. capybara is hanging intermittently, I think
|
|
tests_started = false
|
|
|
|
Thread.new {
|
|
if ENV['BUILD_NUMBER']
|
|
sleep 240
|
|
else
|
|
sleep 30
|
|
end
|
|
|
|
unless tests_started
|
|
bputs "tests are hung. exiting..."
|
|
puts "tests are hung. exiting..."
|
|
exit! 20
|
|
end
|
|
}
|
|
|
|
bputs "before load websocket server"
|
|
|
|
current = Thread.current
|
|
Thread.new do
|
|
ActiveRecord::Base.connection.disconnect!
|
|
ActiveRecord::Base.establish_connection(YAML::load(File.open('config/database.yml'))["test"])
|
|
require 'jam_websockets'
|
|
begin
|
|
JamWebsockets::Server.new.run(
|
|
:port => 6759,
|
|
:emwebsocket_debug => false,
|
|
:connect_time_stale_client => 4,
|
|
:connect_time_expire_client => 6,
|
|
:connect_time_stale_browser => 4,
|
|
:connect_time_expire_browser => 6,
|
|
:max_connections_per_user => 20,
|
|
:rabbitmq_host => 'localhost',
|
|
:rabbitmq_port => 5672,
|
|
:calling_thread => current,
|
|
:cidr => ['0.0.0.0/0'],
|
|
:gateway_name => 'default')
|
|
rescue Exception => e
|
|
puts "websocket-gateway failed: #{e}"
|
|
end
|
|
end
|
|
|
|
bputs "before websocket thread wait"
|
|
Thread.stop
|
|
|
|
bputs "before connection reestablish"
|
|
|
|
ActiveRecord::Base.connection.disconnect!
|
|
bputs "before connection reestablishing"
|
|
ActiveRecord::Base.establish_connection(YAML::load(File.open('config/database.yml'))["test"])
|
|
#Spork.prefork do
|
|
# Loading more in this block will cause your tests to run faster. However,
|
|
# if you change any configuration or code from libraries loaded here, you'll
|
|
# need to restart spork for it take effect.
|
|
# This file is copied to spec/ when you run 'rails generate rspec:install'
|
|
bputs "before load environment"
|
|
begin
|
|
require File.expand_path("../../config/environment", __FILE__)
|
|
rescue => e
|
|
bputs "exception in load environment"
|
|
bputs "e: #{e}"
|
|
end
|
|
|
|
bputs "before loading rails"
|
|
require 'rspec/rails'
|
|
bputs "before connection autorun"
|
|
require 'rspec/autorun'
|
|
|
|
|
|
bputs "before load capybara"
|
|
require 'capybara'
|
|
require 'capybara/rspec'
|
|
require 'capybara-screenshot/rspec'
|
|
bputs "before load poltergeist"
|
|
require 'capybara/poltergeist'
|
|
bputs "before register capybara"
|
|
Capybara.register_driver :poltergeist do |app|
|
|
driver = Capybara::Poltergeist::Driver.new(app, { debug: false, phantomjs_logger: File.open('log/phantomjs.out', 'w') })
|
|
end
|
|
Capybara.javascript_driver = :poltergeist
|
|
Capybara.default_wait_time = 10
|
|
|
|
if defined?(TEST_CONNECT_STATES) && TEST_CONNECT_STATES
|
|
TEST_CONNECT_STATE_JS_CONSOLE_IO = File.open(TEST_CONNECT_STATE_JS_CONSOLE, 'w')
|
|
Capybara.register_driver :poltergeist do |app|
|
|
Capybara::Poltergeist::Driver.new(app, { phantomjs_logger: TEST_CONNECT_STATE_JS_CONSOLE_IO })
|
|
end
|
|
Capybara.javascript_driver = :poltergeist
|
|
end
|
|
Capybara.configure do |config|
|
|
config.match = :one
|
|
config.exact_options = true
|
|
config.ignore_hidden_elements = true
|
|
config.visible_text_only = true
|
|
end
|
|
|
|
# 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}
|
|
|
|
ActiveRecord::Base.logger = Logger.new(STDOUT) if defined?(ActiveRecord::Base)
|
|
|
|
RSpec.configure do |config|
|
|
# ## Mock Framework
|
|
#
|
|
# If you prefer to use mocha, flexmock or RR, uncomment the appropriate line:
|
|
#
|
|
# config.mock_with :mocha
|
|
# config.mock_with :flexmock
|
|
# config.mock_with :rr
|
|
config.mock_with :rspec
|
|
config.color_enabled = true
|
|
|
|
# by default, do not run tests marked as 'slow'
|
|
config.filter_run_excluding slow: true unless ENV['RUN_SLOW_TESTS'] == "1" || ENV['SLOW'] == "1" || ENV['ALL_TESTS'] == "1"
|
|
config.filter_run_excluding aws: true unless ENV['RUN_AWS_TESTS'] == "1" || ENV['AWS'] == "1" || ENV['ALL_TESTS'] == "1"
|
|
|
|
# Remove this line if you're not using ActiveRecord or ActiveRecord fixtures
|
|
config.fixture_path = "#{::Rails.root}/spec/fixtures"
|
|
|
|
# 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
|
|
|
|
config.include Requests::JsonHelpers, type: :request
|
|
config.include Requests::FeatureHelpers, type: :feature
|
|
|
|
config.before(:suite) do
|
|
tests_started = true
|
|
end
|
|
|
|
config.before(:all) do
|
|
end
|
|
|
|
config.before(:each) do
|
|
if example.metadata[:js]
|
|
page.driver.resize(1920, 1080)
|
|
page.driver.headers = { 'User-Agent' => 'Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:25.0) Gecko/20100101 Firefox/25.0' }
|
|
end
|
|
end
|
|
|
|
config.before(:each, :js => true) do
|
|
#
|
|
#Timeout.timeout(Capybara.default_wait_time) do
|
|
# until (i = page.evaluate_script("$.active")).zero?
|
|
# Rails.logger.info "example [#{example.description}] has #{i} outstanding XHR(s)"
|
|
# sleep 0.1
|
|
# end
|
|
#end
|
|
end
|
|
|
|
config.append_after(:each) do
|
|
|
|
Capybara.reset_sessions!
|
|
reset_session_mapper
|
|
|
|
end
|
|
|
|
config.after(:each) do
|
|
|
|
if example.metadata[:js]
|
|
end
|
|
|
|
# dump response.body if an example fails
|
|
if example.metadata[:type] == :controller && example.exception
|
|
puts "'#{determine_test_name(example.metadata)}' controller test failed."
|
|
puts "response.status = #{response.status}, response.body = " + response.body
|
|
end
|
|
end
|
|
|
|
config.after(:all) do
|
|
|
|
end
|
|
|
|
config.after(:suite) do
|
|
wipe_s3_test_bucket
|
|
end
|
|
end
|
|
#end
|
|
|
|
#Spork.each_run do
|
|
# This code will be run each time you run your specs.
|
|
|
|
#end
|
|
|
|
|
|
|
|
|
|
|
|
|