Class: Sauce::Utilities::RailsServer
- Inherits:
-
Object
- Object
- Sauce::Utilities::RailsServer
show all
- Includes:
- Sauce::Utilities
- Defined in:
- lib/sauce/utilities/rails_server.rb
Instance Attribute Summary collapse
Class Method Summary
collapse
Instance Method Summary
collapse
incorrectly_integrated_warning, page_deprecation_message, #silence_stream, #wait_for_server_on_port, warn_if_suspect_misconfiguration
Instance Attribute Details
#port ⇒ Object
Returns the value of attribute port.
55
56
57
|
# File 'lib/sauce/utilities/rails_server.rb', line 55
def port
@port
end
|
Class Method Details
.is_rails_app? ⇒ Boolean
22
23
24
|
# File 'lib/sauce/utilities/rails_server.rb', line 22
def self.is_rails_app?
return !major_version.nil?
end
|
.major_version ⇒ Object
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
|
# File 'lib/sauce/utilities/rails_server.rb', line 26
def self.major_version
paths = ["script/server", "script/rails", "bin/rails"]
startup_script = paths.detect {|path| File.exists? path}
case startup_script
when 'script/server'
return 2
when 'script/rails'
return 3
when 'bin/rails'
return 4
else
return nil
end
end
|
.process_arguments ⇒ Object
42
43
44
45
46
47
48
49
|
# File 'lib/sauce/utilities/rails_server.rb', line 42
def self.process_arguments
case major_version
when 2
["ruby", "script/server"]
else
["bundle", "exec", "rails", "server"]
end
end
|
.server_pool ⇒ Object
51
52
53
|
# File 'lib/sauce/utilities/rails_server.rb', line 51
def self.server_pool
@@server_pool ||= {}
end
|
.start_if_required(config) ⇒ Object
9
10
11
12
13
14
15
16
17
18
19
20
|
# File 'lib/sauce/utilities/rails_server.rb', line 9
def self.start_if_required(config)
if config[:start_local_application] && self.is_rails_app?
Sauce.logger.debug "App is a Rails app and config[:start_local_application] was trueish."
Sauce.logger.info "#{Thread.current.object_id} - Starting Rails app server."
server = new
server.start
return server
end
return server
end
|
Instance Method Details
#start ⇒ Object
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
|
# File 'lib/sauce/utilities/rails_server.rb', line 57
def start
@port = Sauce::Config.new[:application_port]
if ENV["TEST_ENV_NUMBER"]
@test_env = ENV["TEST_ENV_NUMBER"].to_i
end
STDERR.puts "Starting Rails server on port #{@port}..."
@process_args = RailsServer.process_arguments
@process_args.push *["-e", "test", "--port", "#{@port}"]
if @test_env
@process_args.push *["--pid", "#{Dir.pwd}/tmp/pids/server-#{@test_env}"]
end
@server = ChildProcess.build *@process_args
@server.io.inherit!
@server.start
wait_for_server_on_port(@port)
at_exit do
Sauce.logger.debug "#{Thread.current.object_id} - At exit hook called in Sauce::Utilities::RailsServer."
Sauce.logger.info "Stopping Rails App Server."
@server.stop(3, "INT")
RailsServer.server_pool.delete Thread.current.object_id
end
Sauce.logger.info "Rails server running!"
RailsServer.server_pool[Thread.current.object_id] = @server
end
|
#stop ⇒ Object
90
91
92
93
94
95
96
97
|
# File 'lib/sauce/utilities/rails_server.rb', line 90
def stop
Sauce.logger.debug "#{Thread.current.object_id} - Stopping Rails app server with #stop method."
begin
@server.stop(3, "INT")
rescue
Sauce.logger.error "#{Thread.current.object_id} - Rails server could not be killed. Did it fail to start?"
end
end
|