Module: Jasmine::Phantom::Server

Defined in:
lib/jasmine-phantom/server.rb

Class Method Summary collapse

Class Method Details

.startObject



4
5
6
7
8
9
10
11
12
# File 'lib/jasmine-phantom/server.rb', line 4

def self.start
  require 'jasmine/version'

  case Jasmine::VERSION
  when '1.2.0' then start_1_2_0
  when '1.2.1'..'1.3.0' then start_1_2_1
  else start_latest
  end
end

.start_1_2_0Object



49
50
51
52
53
54
55
# File 'lib/jasmine-phantom/server.rb', line 49

def self.start_1_2_0
  config = Jasmine::Config.new
  config.start_jasmine_server

  # omg config.jasmine_port finds a new unused port every time!
  config.instance_variable_get :@jasmine_server_port
end

.start_1_2_1Object



32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
# File 'lib/jasmine-phantom/server.rb', line 32

def self.start_1_2_1
  jasmine_runner_config = Jasmine::RunnerConfig.new
  server = Jasmine::Server.new(jasmine_runner_config.port, Jasmine::Application.app(jasmine_runner_config))

  t = Thread.new do
    begin
      server.start
    rescue ChildProcess::TimeoutError
    end
    # ignore bad exits
  end
  t.abort_on_exception = true
  Jasmine::wait_for_listener(jasmine_runner_config.port, "jasmine server")

  jasmine_runner_config.port
end

.start_latestObject



14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
# File 'lib/jasmine-phantom/server.rb', line 14

def self.start_latest
  Jasmine.load_configuration_from_yaml
  config = Jasmine.config

  server = Jasmine::Server.new(config.port, Jasmine::Application.app(config))
  t = Thread.new do
    begin
      server.start
    rescue ChildProcess::TimeoutError
    end
    # ignore bad exits
  end
  t.abort_on_exception = true
  Jasmine::wait_for_listener(config.port, "jasmine server")

  config.port
end