2023-02-21 19:55:31 -05:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-05-09 23:59:58 +09:00
|
|
|
if ENV['DISABLE_SIMPLECOV'] != 'true'
|
|
|
|
require 'simplecov'
|
|
|
|
SimpleCov.start 'rails' do
|
2023-07-12 03:51:59 -04:00
|
|
|
add_filter 'lib/linter'
|
2023-02-27 10:35:47 -05:00
|
|
|
add_group 'Policies', 'app/policies'
|
2018-05-09 23:59:58 +09:00
|
|
|
add_group 'Presenters', 'app/presenters'
|
2023-02-27 10:35:47 -05:00
|
|
|
add_group 'Serializers', 'app/serializers'
|
|
|
|
add_group 'Services', 'app/services'
|
2018-05-09 23:59:58 +09:00
|
|
|
add_group 'Validators', 'app/validators'
|
|
|
|
end
|
2016-02-25 00:17:01 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
RSpec.configure do |config|
|
2023-02-18 17:38:14 -05:00
|
|
|
config.example_status_persistence_file_path = 'tmp/rspec/examples.txt'
|
2016-02-25 00:17:01 +01:00
|
|
|
config.expect_with :rspec do |expectations|
|
|
|
|
expectations.include_chain_clauses_in_custom_matcher_descriptions = true
|
|
|
|
end
|
|
|
|
|
|
|
|
config.mock_with :rspec do |mocks|
|
|
|
|
mocks.verify_partial_doubles = true
|
2017-04-15 21:40:33 -04:00
|
|
|
|
|
|
|
config.around(:example, :without_verify_partial_doubles) do |example|
|
|
|
|
mocks.verify_partial_doubles = false
|
|
|
|
example.call
|
|
|
|
mocks.verify_partial_doubles = true
|
|
|
|
end
|
2016-02-25 00:17:01 +01:00
|
|
|
end
|
2016-09-05 17:46:36 +02:00
|
|
|
|
2018-02-09 23:04:47 +01:00
|
|
|
config.before :suite do
|
2019-07-19 01:44:42 +02:00
|
|
|
Rails.application.load_seed
|
2018-02-09 23:04:47 +01:00
|
|
|
Chewy.strategy(:bypass)
|
|
|
|
end
|
|
|
|
|
2017-01-29 12:25:10 +01:00
|
|
|
config.after :suite do
|
2023-05-03 23:50:40 -04:00
|
|
|
FileUtils.rm_rf(Dir[Rails.root.join('spec', 'test_files')])
|
2016-09-05 17:46:36 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def body_as_json
|
|
|
|
json_str_to_hash(response.body)
|
|
|
|
end
|
|
|
|
|
|
|
|
def json_str_to_hash(str)
|
2016-09-21 22:07:18 +02:00
|
|
|
JSON.parse(str, symbolize_names: true)
|
2016-02-25 00:17:01 +01:00
|
|
|
end
|
2022-02-10 19:42:45 +01:00
|
|
|
|
|
|
|
def expect_push_bulk_to_match(klass, matcher)
|
|
|
|
expect(Sidekiq::Client).to receive(:push_bulk).with(hash_including({
|
2023-02-18 17:38:14 -05:00
|
|
|
'class' => klass,
|
|
|
|
'args' => matcher,
|
2022-02-10 19:42:45 +01:00
|
|
|
}))
|
|
|
|
end
|
2023-07-28 23:09:49 +02:00
|
|
|
|
|
|
|
class StreamingServerManager
|
|
|
|
@running_thread = nil
|
|
|
|
|
|
|
|
def initialize
|
|
|
|
at_exit { stop }
|
|
|
|
end
|
|
|
|
|
|
|
|
def start(port: 4020)
|
|
|
|
return if @running_thread
|
|
|
|
|
|
|
|
queue = Queue.new
|
|
|
|
|
|
|
|
@queue = queue
|
|
|
|
|
|
|
|
@running_thread = Thread.new do
|
|
|
|
Open3.popen2e(
|
|
|
|
{
|
|
|
|
'REDIS_NAMESPACE' => ENV.fetch('REDIS_NAMESPACE'),
|
|
|
|
'DB_NAME' => "#{ENV.fetch('DB_NAME', 'mastodon')}_test#{ENV.fetch('TEST_ENV_NUMBER', '')}",
|
|
|
|
'RAILS_ENV' => ENV.fetch('RAILS_ENV', 'test'),
|
|
|
|
'NODE_ENV' => ENV.fetch('STREAMING_NODE_ENV', 'development'),
|
|
|
|
'PORT' => port.to_s,
|
|
|
|
},
|
|
|
|
'node index.js', # must not call yarn here, otherwise it will fail because yarn does not send signals to its child process
|
|
|
|
chdir: Rails.root.join('streaming')
|
|
|
|
) do |_stdin, stdout_err, process_thread|
|
|
|
|
status = :starting
|
|
|
|
|
|
|
|
# Spawn a thread to listen on streaming server output
|
|
|
|
output_thread = Thread.new do
|
|
|
|
stdout_err.each_line do |line|
|
|
|
|
Rails.logger.info "Streaming server: #{line}"
|
|
|
|
|
|
|
|
if status == :starting && line.match('Streaming API now listening on')
|
|
|
|
status = :started
|
|
|
|
@queue.enq 'started'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# And another thread to listen on commands from the main thread
|
|
|
|
loop do
|
|
|
|
msg = queue.pop
|
|
|
|
|
|
|
|
case msg
|
|
|
|
when 'stop'
|
|
|
|
# we need to properly stop the reading thread
|
|
|
|
output_thread.kill
|
|
|
|
|
|
|
|
# Then stop the node process
|
|
|
|
Process.kill('KILL', process_thread.pid)
|
|
|
|
|
|
|
|
# And we stop ourselves
|
|
|
|
@running_thread.kill
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# wait for 10 seconds for the streaming server to start
|
|
|
|
Timeout.timeout(10) do
|
|
|
|
loop do
|
|
|
|
break if @queue.pop == 'started'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def stop
|
|
|
|
return unless @running_thread
|
|
|
|
|
|
|
|
@queue.enq 'stop'
|
|
|
|
|
|
|
|
# Wait for the thread to end
|
|
|
|
@running_thread.join
|
|
|
|
end
|
|
|
|
end
|