discourse/config/boot.rb

57 lines
1.6 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
if ENV['DISCOURSE_DUMP_HEAP'] == "1"
require 'objspace'
2016-06-09 23:00:15 -04:00
ObjectSpace.trace_object_allocations_start
end
2013-02-05 14:16:51 -05:00
require 'rubygems'
# Set up gems listed in the Gemfile.
ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../../Gemfile', __FILE__)
require 'bundler/setup' if File.exists?(ENV['BUNDLE_GEMFILE'])
if ENV['RAILS_ENV'] != 'production' && ENV['RAILS_ENV'] != 'profile'
2018-02-25 18:29:25 -05:00
begin
require 'bootsnap'
rescue LoadError
# not a strong requirement
end
2017-05-11 13:51:38 -04:00
2018-02-25 18:29:25 -05:00
if defined? Bootsnap
Bootsnap.setup(
2018-12-04 04:48:16 -05:00
cache_dir: 'tmp/cache', # Path to your cache
load_path_cache: true, # Should we optimize the LOAD_PATH with a cache?
autoload_paths_cache: true, # Should we optimize ActiveSupport autoloads with cache?
disable_trace: false, # Sets `RubyVM::InstructionSequence.compile_option = { trace_instruction: false }`
compile_cache_iseq: true, # Should compile Ruby code into ISeq cache?
compile_cache_yaml: false # Skip YAML cache for now, cause we were seeing issues with it
2018-02-25 18:29:25 -05:00
)
end
end
# Parallel spec system
if ENV['RAILS_ENV'] == "test" && ENV['TEST_ENV_NUMBER']
if ENV['TEST_ENV_NUMBER'] == ''
n = 1
else
n = ENV['TEST_ENV_NUMBER'].to_i
end
port = 10000 + n
STDERR.puts "Setting up parallel test mode - starting Redis #{n} on port #{port}"
`rm -rf tmp/test_data_#{n} && mkdir -p tmp/test_data_#{n}/redis`
pid = Process.spawn("redis-server --dir tmp/test_data_#{n}/redis --port #{port}", out: "/dev/null")
ENV["DISCOURSE_REDIS_PORT"] = port.to_s
ENV["RAILS_DB"] = "discourse_test_#{n}"
at_exit do
Process.kill("SIGTERM", pid)
Process.wait
end
end