discourse/lib/tasks/qunit.rake

83 lines
1.6 KiB
Ruby
Raw Normal View History

desc "Runs the qunit test suite"
task "qunit:test" => :environment do
require "rack"
2013-07-30 00:15:20 -04:00
require "socket"
unless %x{which phantomjs > /dev/null 2>&1}
abort "PhantomJS is not installed. Download from http://phantomjs.org"
end
2013-07-30 00:15:20 -04:00
# ensure we have this port available
def port_available? port
server = TCPServer.open port
server.close
true
rescue Errno::EADDRINUSE
false
end
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
Discourse.after_fork
Rack::Server.start(:config => "config.ru",
:AccessLog => [],
:Port => port)
2013-07-29 23:04:29 -04:00
exit
end
begin
success = true
test_path = "#{Rails.root}/vendor/assets/javascripts"
cmd = "phantomjs #{test_path}/run-qunit.js http://localhost:#{port}/qunit"
options = {}
%w{module filter}.each do |arg|
options[arg] = ENV[arg.upcase] if ENV[arg.upcase].present?
end
if options.present?
cmd += "?#{options.to_query.gsub('+', '%20')}"
end
# wait for server to respond, will exception out on failure
tries = 0
begin
2013-07-29 23:04:29 -04:00
sh(cmd)
rescue
2013-07-29 22:35:41 -04:00
sleep 2
tries += 1
2013-07-29 22:35:41 -04:00
retry unless tries == 10
end
# A bit of a hack until we can figure this out on Travis
tries = 0
2014-03-26 15:20:41 -04:00
while tries < 3 && $?.exitstatus == 124 && !quit
tries += 1
puts "\nTimed Out. Trying again...\n"
rake_system(cmd)
end
success &&= $?.success?
ensure
2013-07-30 00:15:20 -04:00
# was having issues with HUP
Process.kill "KILL", pid
end
if success
puts "\nTests Passed"
else
puts "\nTests Failed"
exit(1)
end
end