2013-06-18 13:44:20 -04:00
|
|
|
desc "Runs the qunit test suite"
|
|
|
|
|
2017-08-18 14:08:58 -04:00
|
|
|
task "qunit:test", [:timeout, :qunit_path] => :environment do |_, args|
|
2013-06-18 13:44:20 -04:00
|
|
|
require "rack"
|
2013-07-30 00:15:20 -04:00
|
|
|
require "socket"
|
2018-01-10 08:51:08 -05:00
|
|
|
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
|
2013-06-18 13:44:20 -04:00
|
|
|
|
2018-01-10 08:51:08 -05:00
|
|
|
unless system("command -v \"#{google_chrome_cli}\" >/dev/null")
|
2017-12-19 02:59:41 -05:00
|
|
|
abort "Chrome is not installed. Download from https://www.google.com/chrome/browser/desktop/index.html"
|
2013-06-18 13:44:20 -04:00
|
|
|
end
|
|
|
|
|
2018-01-10 08:51:08 -05:00
|
|
|
if Gem::Version.new(`\"#{google_chrome_cli}\" --version`.match(/[\d\.]+/)[0]) < Gem::Version.new("59")
|
2017-12-19 02:59:41 -05:00
|
|
|
abort "Chrome 59 or higher is required to run tests in headless mode."
|
|
|
|
end
|
|
|
|
|
2017-12-21 20:11:49 -05:00
|
|
|
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")
|
2017-12-19 02:59:41 -05:00
|
|
|
|
2013-07-30 00:15:20 -04:00
|
|
|
# ensure we have this port available
|
2017-07-27 21:20:09 -04:00
|
|
|
def port_available?(port)
|
2013-07-30 00:15:20 -04:00
|
|
|
server = TCPServer.open port
|
|
|
|
server.close
|
|
|
|
true
|
|
|
|
rescue Errno::EADDRINUSE
|
|
|
|
false
|
|
|
|
end
|
|
|
|
|
2013-06-18 13:44:20 -04:00
|
|
|
port = ENV['TEST_SERVER_PORT'] || 60099
|
2013-07-30 00:15:20 -04:00
|
|
|
|
|
|
|
while !port_available? port
|
|
|
|
port += 1
|
|
|
|
end
|
|
|
|
|
2013-07-29 23:04:29 -04:00
|
|
|
unless pid = fork
|
2014-05-30 00:17:35 -04:00
|
|
|
Discourse.after_fork
|
2017-07-27 21:20:09 -04:00
|
|
|
Rack::Server.start(config: "config.ru",
|
|
|
|
AccessLog: [],
|
|
|
|
Port: port)
|
2013-07-29 23:04:29 -04:00
|
|
|
exit
|
2013-06-18 13:44:20 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
begin
|
|
|
|
success = true
|
|
|
|
test_path = "#{Rails.root}/vendor/assets/javascripts"
|
2017-07-27 11:29:18 -04:00
|
|
|
qunit_path = args[:qunit_path] || "/qunit"
|
2017-12-19 02:59:41 -05:00
|
|
|
cmd = "node #{test_path}/run-qunit.js http://localhost:#{port}#{qunit_path}"
|
2017-12-20 20:47:32 -05:00
|
|
|
options = { seed: (ENV["QUNIT_SEED"] || Random.new.seed) }
|
2016-06-13 22:06:11 -04:00
|
|
|
|
2017-07-26 09:07:46 -04:00
|
|
|
%w{module filter qunit_skip_core qunit_single_plugin}.each do |arg|
|
2016-06-13 22:06:11 -04:00
|
|
|
options[arg] = ENV[arg.upcase] if ENV[arg.upcase].present?
|
|
|
|
end
|
|
|
|
|
|
|
|
if options.present?
|
2017-07-26 09:07:46 -04:00
|
|
|
cmd += "?#{options.to_query.gsub('+', '%20').gsub("&", '\\\&')}"
|
2016-06-13 22:06:11 -04:00
|
|
|
end
|
|
|
|
|
2017-02-23 18:19:34 -05:00
|
|
|
if args[:timeout].present?
|
|
|
|
cmd += " #{args[:timeout]}"
|
|
|
|
end
|
|
|
|
|
2017-07-19 12:04:03 -04: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)
|
2017-07-25 11:31:30 -04:00
|
|
|
rescue Errno::ECONNREFUSED, Errno::EADDRNOTAVAIL
|
2017-07-19 12:04:03 -04: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"
|
|
|
|
|
2013-07-29 22:32:12 -04:00
|
|
|
# wait for server to respond, will exception out on failure
|
|
|
|
tries = 0
|
|
|
|
begin
|
2013-07-29 23:04:29 -04:00
|
|
|
sh(cmd)
|
2013-07-29 22:32:12 -04:00
|
|
|
rescue
|
2016-06-14 00:17:39 -04:00
|
|
|
exit if ENV['RETRY'].present? && ENV['RETRY'] == 'false'
|
2013-07-29 22:35:41 -04:00
|
|
|
sleep 2
|
2013-07-29 22:32:12 -04:00
|
|
|
tries += 1
|
2016-11-15 02:23:53 -05:00
|
|
|
retry unless tries == 3
|
2013-07-29 22:32:12 -04:00
|
|
|
end
|
2013-06-18 13:44:20 -04:00
|
|
|
|
|
|
|
# A bit of a hack until we can figure this out on Travis
|
|
|
|
tries = 0
|
2016-11-02 16:46:37 -04:00
|
|
|
while tries < 3 && $?.exitstatus == 124
|
2013-06-18 13:44:20 -04:00
|
|
|
tries += 1
|
|
|
|
puts "\nTimed Out. Trying again...\n"
|
2016-11-15 02:24:19 -05:00
|
|
|
sh(cmd)
|
2013-06-18 13:44:20 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
success &&= $?.success?
|
|
|
|
|
|
|
|
ensure
|
2013-07-30 00:15:20 -04:00
|
|
|
# was having issues with HUP
|
|
|
|
Process.kill "KILL", pid
|
2013-06-18 13:44:20 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
if success
|
|
|
|
puts "\nTests Passed"
|
|
|
|
else
|
|
|
|
puts "\nTests Failed"
|
|
|
|
exit(1)
|
|
|
|
end
|
|
|
|
|
2013-07-29 22:32:12 -04:00
|
|
|
end
|