discourse/lib/tasks/qunit.rake

123 lines
3.0 KiB
Ruby
Raw Normal View History

desc "Runs the qunit test suite"
task "qunit:test", [:timeout, :qunit_path] => :environment do |_, args|
require "rack"
2013-07-29 23:15:20 -05:00
require "socket"
require 'rbconfig'
if RbConfig::CONFIG['host_os'][/darwin|mac os/]
google_chrome_cli = "/Applications/Google\ Chrome.app/Contents/MacOS/Google\ Chrome"
else
google_chrome_cli = "google-chrome"
end
unless system("command -v \"#{google_chrome_cli}\" >/dev/null")
abort "Chrome is not installed. Download from https://www.google.com/chrome/browser/desktop/index.html"
end
if Gem::Version.new(`\"#{google_chrome_cli}\" --version`.match(/[\d\.]+/)[0]) < Gem::Version.new("59")
abort "Chrome 59 or higher is required to run tests in headless mode."
end
unless system("command -v yarn >/dev/null;")
abort "Yarn is not installed. Download from https://yarnpkg.com/lang/en/docs/install/"
end
system("yarn install --dev")
2013-07-29 23:15:20 -05:00
# ensure we have this port available
2017-07-27 20:20:09 -05:00
def port_available?(port)
2013-07-29 23:15:20 -05:00
server = TCPServer.open port
server.close
true
rescue Errno::EADDRINUSE
false
end
port = ENV['TEST_SERVER_PORT'] || 60099
2013-07-29 23:15:20 -05:00
while !port_available? port
port += 1
end
2013-07-29 22:04:29 -05:00
unless pid = fork
Discourse.after_fork
2017-07-27 20:20:09 -05:00
Rack::Server.start(config: "config.ru",
AccessLog: [],
Port: port)
2013-07-29 22:04:29 -05:00
exit
end
begin
success = true
test_path = "#{Rails.root}/vendor/assets/javascripts"
2017-07-27 10:29:18 -05:00
qunit_path = args[:qunit_path] || "/qunit"
cmd = "node #{test_path}/run-qunit.js http://localhost:#{port}#{qunit_path}"
2017-12-20 19:47:32 -06:00
options = { seed: (ENV["QUNIT_SEED"] || Random.new.seed) }
%w{module filter qunit_skip_core qunit_single_plugin}.each do |arg|
options[arg] = ENV[arg.upcase] if ENV[arg.upcase].present?
end
if options.present?
cmd += "?#{options.to_query.gsub('+', '%20').gsub("&", '\\\&')}"
end
if args[:timeout].present?
cmd += " #{args[:timeout]}"
end
2017-07-19 11:04:03 -05:00
@now = Time.now
def elapsed
Time.now - @now
end
# wait for server to accept connections
require 'net/http'
uri = URI("http://localhost:#{port}/assets/test_helper.js")
puts "Warming up Rails server"
begin
Net::HTTP.get(uri)
rescue Errno::ECONNREFUSED, Errno::EADDRNOTAVAIL
2017-07-19 11:04:03 -05:00
sleep 1
retry unless elapsed() > 60
puts "Timed out. Can no connect to forked server!"
exit 1
end
puts "Rails server is warmed up"
# wait for server to respond, will exception out on failure
tries = 0
begin
2013-07-29 22:04:29 -05:00
sh(cmd)
rescue
2016-06-13 23:17:39 -05:00
exit if ENV['RETRY'].present? && ENV['RETRY'] == 'false'
2013-07-29 21:35:41 -05:00
sleep 2
tries += 1
retry unless tries == 3
end
# A bit of a hack until we can figure this out on Travis
tries = 0
2016-11-02 15:46:37 -05:00
while tries < 3 && $?.exitstatus == 124
tries += 1
puts "\nTimed Out. Trying again...\n"
2016-11-15 01:24:19 -06:00
sh(cmd)
end
success &&= $?.success?
ensure
2013-07-29 23:15:20 -05:00
# was having issues with HUP
Process.kill "KILL", pid
end
if success
puts "\nTests Passed"
else
puts "\nTests Failed"
exit(1)
end
end