2019-05-02 18:17:27 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2013-11-01 18:57:50 -04:00
|
|
|
require "autospec/rspec_runner"
|
|
|
|
|
2013-10-23 19:06:05 -04:00
|
|
|
module Autospec
|
2013-11-01 18:57:50 -04:00
|
|
|
class SimpleRunner < RspecRunner
|
2018-06-17 23:20:23 -04:00
|
|
|
def initialize
|
|
|
|
@mutex = Mutex.new
|
|
|
|
end
|
2013-11-01 18:57:50 -04:00
|
|
|
|
|
|
|
def run(specs)
|
2019-05-02 18:17:27 -04:00
|
|
|
puts "Running Rspec: #{specs}"
|
2013-11-01 18:57:50 -04:00
|
|
|
# kill previous rspec instance
|
2018-06-17 23:20:23 -04:00
|
|
|
@mutex.synchronize { self.abort }
|
2013-11-01 18:57:50 -04:00
|
|
|
# we use our custom rspec formatter
|
2019-06-20 20:59:01 -04:00
|
|
|
args = ["-r", "#{File.dirname(__FILE__)}/formatter.rb", "-f", "Autospec::Formatter"]
|
2019-04-01 08:03:51 -04:00
|
|
|
|
|
|
|
command =
|
|
|
|
begin
|
2020-11-11 14:13:32 -05:00
|
|
|
line_specified = specs.split.any? { |s| s =~ /\:/ } # Parallel spec can't run specific line
|
2021-05-20 21:43:47 -04:00
|
|
|
multiple_files = specs.split.count > 1 || specs == "spec" # Only parallelize multiple files
|
2020-11-11 14:13:32 -05:00
|
|
|
if ENV["PARALLEL_SPEC"] == "1" && multiple_files && !line_specified
|
2019-06-20 20:59:01 -04:00
|
|
|
"bin/turbo_rspec #{args.join(" ")} #{specs.split.join(" ")}"
|
2019-04-01 08:03:51 -04:00
|
|
|
else
|
|
|
|
"bin/rspec #{args.join(" ")} #{specs.split.join(" ")}"
|
2023-01-09 07:10:19 -05:00
|
|
|
end
|
2019-04-01 08:03:51 -04:00
|
|
|
end
|
|
|
|
|
2013-11-01 18:57:50 -04:00
|
|
|
# launch rspec
|
2020-03-26 11:32:41 -04:00
|
|
|
Dir.chdir(Rails.root) do # rubocop:disable Discourse/NoChdir because this is not part of the app
|
2017-06-08 18:02:30 -04:00
|
|
|
env = { "RAILS_ENV" => "test" }
|
|
|
|
if specs.split(" ").any? { |s| s =~ %r{^(./)?plugins} }
|
|
|
|
env["LOAD_PLUGINS"] = "1"
|
|
|
|
puts "Loading plugins while running specs"
|
|
|
|
end
|
2019-04-01 08:03:51 -04:00
|
|
|
pid = @mutex.synchronize { @pid = Process.spawn(env, command) }
|
2018-06-17 23:20:23 -04:00
|
|
|
|
|
|
|
_, status = Process.wait2(pid)
|
|
|
|
|
2017-04-13 17:24:58 -04:00
|
|
|
status.exitstatus
|
|
|
|
end
|
2013-11-01 18:57:50 -04:00
|
|
|
end
|
2013-10-23 19:06:05 -04:00
|
|
|
|
|
|
|
def abort
|
2018-06-17 23:20:23 -04:00
|
|
|
if pid = @pid
|
2023-01-09 07:10:19 -05:00
|
|
|
begin
|
2018-06-17 23:20:23 -04:00
|
|
|
Process.kill("TERM", pid)
|
|
|
|
rescue StandardError
|
|
|
|
nil
|
2023-01-09 07:10:19 -05:00
|
|
|
end
|
2018-06-17 23:20:23 -04:00
|
|
|
wait_for_done(pid)
|
|
|
|
pid = nil
|
2013-10-23 19:06:05 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def stop
|
2018-06-17 23:20:23 -04:00
|
|
|
# assume sigint on child will take care of this?
|
|
|
|
if pid = @pid
|
|
|
|
wait_for_done(pid)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def wait_for_done(pid)
|
|
|
|
i = 3000
|
|
|
|
while (
|
2023-01-09 07:10:19 -05:00
|
|
|
begin
|
2018-06-17 23:20:23 -04:00
|
|
|
i > 0 && Process.getpgid(pid)
|
|
|
|
rescue StandardError
|
|
|
|
nil
|
2023-01-09 07:10:19 -05:00
|
|
|
end
|
2018-06-17 23:20:23 -04:00
|
|
|
)
|
|
|
|
sleep 0.001
|
|
|
|
i -= 1
|
|
|
|
end
|
|
|
|
if (
|
2023-01-09 07:10:19 -05:00
|
|
|
begin
|
2018-06-17 23:20:23 -04:00
|
|
|
Process.getpgid(pid)
|
|
|
|
rescue StandardError
|
|
|
|
nil
|
2023-01-09 07:10:19 -05:00
|
|
|
end
|
2018-06-17 23:20:23 -04:00
|
|
|
)
|
|
|
|
STDERR.puts "Terminating rspec #{pid} by force cause it refused graceful termination"
|
|
|
|
Process.kill("KILL", pid)
|
|
|
|
end
|
2013-10-23 19:06:05 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|