Sha256: d017d5489f3a51c06f84004ba31b0921f474f0cbfd2d6f2cb44f11e4e1b1907e
Contents?: true
Size: 1.75 KB
Versions: 3
Compression:
Stored size: 1.75 KB
Contents
module JstdRunner class Server include Monitorable class StartupError < StandardError end class StopError < StandardError end JAR = File.expand_path("../JsTestDriver-1.3.3d.jar", __FILE__) LAUNCH_TIMEOUT = 120 # this is huge, but I've seen it happen attr_reader :host, :port def initialize(port) @host = "127.0.0.1" @port = Integer(port) @restarting = false end def start Log.info "starting JsTestDriver" if immediate_poller.connected? raise StartupError, "JsTestDriver already running on #{@host}:#{@port}" end process.start unless long_poller.connected? process.stop rescue nil raise StartupError, "could not launch JsTestDriver server on #{@host}:#{@port} within #{LAUNCH_TIMEOUT} seconds" end end def restart @restarting = true Log.info "restaring server" stop rescue nil @process = nil start @restarting = false end def stop Log.info "stopping JsTestDriver" process.stop unless long_poller.closed? raise StopError, "could not stop JsTestDriver server on port #{@host}:#{@port} witin #{LAUNCH_TIMEOUT} seconds" end end def running? process.alive? && immediate_poller.connected? end private def process @process ||= ( proc = ChildProcess.new("java", "-jar", JAR, "--port", @port.to_s) proc.io.inherit! if $DEBUG proc ) end def long_poller @long_poller ||= Selenium::WebDriver::SocketPoller.new(@host, @port, LAUNCH_TIMEOUT) end def immediate_poller @immediate_poller ||= Selenium::WebDriver::SocketPoller.new(@host, @port, 5) end end end
Version data entries
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
jstd-runner-0.0.6 | lib/jstd-runner/server.rb |
jstd-runner-0.0.5 | lib/jstd-runner/server.rb |
jstd-runner-0.0.4 | lib/jstd-runner/server.rb |