diff options
author | Sam Phippen <samphippen@googlemail.com> | 2017-06-24 15:47:59 -0400 |
---|---|---|
committer | Sam Phippen <samphippen@googlemail.com> | 2017-06-24 15:47:59 -0400 |
commit | eba361824d9eb242f186bb711ef82381ac50ef9e (patch) | |
tree | 3cfceae220ee6201dc009af02917571c1235e7f4 | |
parent | 8cad811b0559661df3c58528ac1e8d5a2e601d4d (diff) | |
download | rails-eba361824d9eb242f186bb711ef82381ac50ef9e.tar.gz rails-eba361824d9eb242f186bb711ef82381ac50ef9e.tar.bz2 rails-eba361824d9eb242f186bb711ef82381ac50ef9e.zip |
Add an option to silence puma in system tests.
This is motivated by our usage of system test in RSpec. Puma lazily
boots the first time a system test is used, but this causes some
unfortunate output to appear in the middle of the user's green dots. An
example of this can be seen in @derekprior's comment
[here](https://github.com/rspec/rspec-rails/pull/1813#issuecomment-309252314).
There are alternatives in RSpec where we attempt to intercept the puma
boot and prevent the output from being made there, but that would
involve some monkey patching. This seems like a cleaner solution.
-rw-r--r-- | actionpack/lib/action_dispatch/system_testing/server.rb | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/actionpack/lib/action_dispatch/system_testing/server.rb b/actionpack/lib/action_dispatch/system_testing/server.rb index 4a214ef713..89ca6944d9 100644 --- a/actionpack/lib/action_dispatch/system_testing/server.rb +++ b/actionpack/lib/action_dispatch/system_testing/server.rb @@ -3,6 +3,12 @@ require "rack/handler/puma" module ActionDispatch module SystemTesting class Server # :nodoc: + class << self + attr_accessor :silence_puma + end + + self.silence_puma = false + def run register setup @@ -11,7 +17,12 @@ module ActionDispatch private def register Capybara.register_server :rails_puma do |app, port, host| - Rack::Handler::Puma.run(app, Port: port, Threads: "0:1") + Rack::Handler::Puma.run( + app, + Port: port, + Threads: "0:1", + Silent: self.class.silence_puma + ) end end |