Class: RSpec::Core::Runner
- Defined in:
- lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb
Overview
Provides the main entry point to run a suite of RSpec examples.
Instance Attribute Summary collapse
- #configuration ⇒ Object readonly
- #options ⇒ Object readonly
- #world ⇒ Object readonly
Class Method Summary collapse
-
.autorun ⇒ Object
Register an ‘at_exit` hook that runs the suite when the process exits.
- .autorun_disabled? ⇒ Boolean
- .disable_autorun! ⇒ Object
- .handle_interrupt ⇒ Object
- .installed_at_exit? ⇒ Boolean
-
.invoke ⇒ Object
Runs the suite of specs and exits the process with an appropriate exit code.
- .perform_at_exit ⇒ Object
-
.run(args, err = $stderr, out = $stdout) ⇒ Fixnum
Run a suite of RSpec examples.
- .running_in_drb? ⇒ Boolean
- .trap_interrupt ⇒ Object
Instance Method Summary collapse
- #configure(err, out) ⇒ Object
- #exit_code(examples_passed = false) ⇒ Object
-
#initialize(options, configuration = RSpec.configuration, world = RSpec.world) ⇒ Runner
constructor
A new instance of Runner.
-
#run(err, out) ⇒ Object
Configures and runs a spec suite.
-
#run_specs(example_groups) ⇒ Fixnum
Runs the provided example groups.
-
#setup(err, out) ⇒ Object
Wires together the various configuration objects and state holders.
Constructor Details
#initialize(options, configuration = RSpec.configuration, world = RSpec.world) ⇒ Runner
Returns a new instance of Runner.
75 76 77 78 79 |
# File 'lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb', line 75 def initialize(, configuration=RSpec.configuration, world=RSpec.world) @options = @configuration = configuration @world = world end |
Instance Attribute Details
#configuration ⇒ Object (readonly)
7 8 9 |
# File 'lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb', line 7 def configuration @configuration end |
#options ⇒ Object (readonly)
7 8 9 |
# File 'lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb', line 7 def @options end |
#world ⇒ Object (readonly)
7 8 9 |
# File 'lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb', line 7 def world @world end |
Class Method Details
.autorun ⇒ Object
This is not generally needed. The ‘rspec` command takes care of running examples for you without involving an `at_exit` hook. This is only needed if you are running specs using the `ruby` command, and even then, the normal way to invoke this is by requiring `rspec/autorun`.
Register an ‘at_exit` hook that runs the suite when the process exits.
16 17 18 19 20 21 22 23 24 25 26 |
# File 'lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb', line 16 def self.autorun if autorun_disabled? RSpec.deprecate("Requiring `rspec/autorun` when running RSpec via the `rspec` command") return elsif installed_at_exit? || running_in_drb? return end at_exit { perform_at_exit } @installed_at_exit = true end |
.autorun_disabled? ⇒ Boolean
141 142 143 |
# File 'lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb', line 141 def self.autorun_disabled? @autorun_disabled ||= false end |
.disable_autorun! ⇒ Object
136 137 138 |
# File 'lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb', line 136 def self.disable_autorun! @autorun_disabled = true end |
.handle_interrupt ⇒ Object
180 181 182 183 184 185 186 187 |
# File 'lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb', line 180 def self.handle_interrupt if RSpec.world.wants_to_quit exit!(1) else RSpec.world.wants_to_quit = true $stderr.puts "\nRSpec is shutting down and will print the summary report... Interrupt again to force quit." end end |
.installed_at_exit? ⇒ Boolean
146 147 148 |
# File 'lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb', line 146 def self.installed_at_exit? @installed_at_exit ||= false end |
.invoke ⇒ Object
Runs the suite of specs and exits the process with an appropriate exit code.
43 44 45 46 47 |
# File 'lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb', line 43 def self.invoke disable_autorun! status = run(ARGV, $stderr, $stdout).to_i exit(status) if status != 0 end |
.perform_at_exit ⇒ Object
29 30 31 32 33 34 35 36 37 38 39 |
# File 'lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb', line 29 def self.perform_at_exit # Don't bother running any specs and just let the program terminate # if we got here due to an unrescued exception (anything other than # SystemExit, which is raised when somebody calls Kernel#exit). return unless $!.nil? || $!.is_a?(SystemExit) # We got here because either the end of the program was reached or # somebody called Kernel#exit. Run the specs and then override any # existing exit status with RSpec's exit status if any specs failed. invoke end |
.run(args, err = $stderr, out = $stdout) ⇒ Fixnum
Run a suite of RSpec examples. Does not exit.
This is used internally by RSpec to run a suite, but is available for use by any other automation tool.
If you want to run this multiple times in the same process, and you want files like ‘spec_helper.rb` to be reloaded, be sure to load `load` instead of `require`.
64 65 66 67 68 69 70 71 72 73 |
# File 'lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb', line 64 def self.run(args, err=$stderr, out=$stdout) trap_interrupt = ConfigurationOptions.new(args) if .[:runner] .[:runner].call(, err, out) else new().run(err, out) end end |
.running_in_drb? ⇒ Boolean
151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 |
# File 'lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb', line 151 def self.running_in_drb? return false unless defined?(DRb) server = begin DRb.current_server rescue DRb::DRbServerNotFound return false end return false unless server && server.alive? require 'socket' require 'uri' local_ipv4 = begin IPSocket.getaddress(Socket.gethostname) rescue SocketError return false end ["127.0.0.1", "localhost", local_ipv4].any? { |addr| addr == URI(DRb.current_server.uri).host } end |
.trap_interrupt ⇒ Object
175 176 177 |
# File 'lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb', line 175 def self.trap_interrupt trap('INT') { handle_interrupt } end |
Instance Method Details
#configure(err, out) ⇒ Object
129 130 131 132 133 |
# File 'lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb', line 129 def configure(err, out) @configuration.error_stream = err @configuration.output_stream = out if @configuration.output_stream == $stdout @options.configure(@configuration) end |
#exit_code(examples_passed = false) ⇒ Object
190 191 192 193 194 195 |
# File 'lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb', line 190 def exit_code(examples_passed=false) return @configuration.error_exit_code || @configuration.failure_exit_code if @world.non_example_failure return @configuration.failure_exit_code unless examples_passed 0 end |
#run(err, out) ⇒ Object
Configures and runs a spec suite.
85 86 87 88 89 90 91 92 |
# File 'lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb', line 85 def run(err, out) setup(err, out) return @configuration.reporter.exit_early(exit_code) if RSpec.world.wants_to_quit run_specs(@world.ordered_example_groups).tap do persist_example_statuses end end |
#run_specs(example_groups) ⇒ Fixnum
Runs the provided example groups.
113 114 115 116 117 118 119 120 121 122 123 124 125 126 |
# File 'lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb', line 113 def run_specs(example_groups) examples_count = @world.example_count(example_groups) examples_passed = @configuration.reporter.report(examples_count) do |reporter| @configuration.with_suite_hooks do if examples_count == 0 && @configuration.fail_if_no_examples return @configuration.failure_exit_code end example_groups.map { |g| g.run(reporter) }.all? end end exit_code(examples_passed) end |
#setup(err, out) ⇒ Object
Wires together the various configuration objects and state holders.
98 99 100 101 102 103 104 105 |
# File 'lib/rubypitaya/app-template/vendor/bundle/ruby/3.1.0/gems/rspec-core-3.12.0/lib/rspec/core/runner.rb', line 98 def setup(err, out) configure(err, out) return if RSpec.world.wants_to_quit @configuration.load_spec_files ensure @world.announce_filters end |