class RSpec::Core::Runner
Provides the main entry point to run a suite of RSpec examples.
def self.autorun
- Note: - This is not generally needed. The `rspec` command takes care
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
def self.autorun_disabled?
- Private: -
def self.autorun_disabled? @autorun_disabled ||= false end
def self.disable_autorun!
- Private: -
def self.disable_autorun! @autorun_disabled = true end
def self.handle_interrupt
- Private: -
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
def self.installed_at_exit?
- Private: -
def self.installed_at_exit? @installed_at_exit ||= false end
def self.invoke
Runs the suite of specs and exits the process with an appropriate exit
def self.invoke disable_autorun! status = run(ARGV, $stderr, $stdout).to_i exit(status) if status != 0 end
def self.perform_at_exit
- Private: -
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
def self.run(args, err=$stderr, out=$stdout)
-
(Fixnum)
- exit status code. 0 if all specs passed,
Parameters:
-
out
(IO
) -- output stream -
err
(IO
) -- error stream -
args
(Array
) -- command-line-supported arguments
def self.run(args, err=$stderr, out=$stdout) trap_interrupt options = ConfigurationOptions.new(args) if options.options[:drb] require 'rspec/core/drb' begin DRbRunner.new(options).run(err, out) return rescue DRb::DRbConnError err.puts "No DRb server is running. Running in local process instead ..." end end new(options).run(err, out) end
def self.running_in_drb?
- Private: -
def self.running_in_drb? if defined?(DRb) && DRb.current_server require 'socket' require 'uri' local_ipv4 = IPSocket.getaddress(Socket.gethostname) local_drb = ["127.0.0.1", "localhost", local_ipv4].any? { |addr| addr == URI(DRb.current_server.uri).host } end rescue DRb::DRbServerNotFound ensure return local_drb || false end
def self.trap_interrupt
- Private: -
def self.trap_interrupt trap('INT') { handle_interrupt } end
def initialize(options, configuration=RSpec.configuration, world=RSpec.world)
def initialize(options, configuration=RSpec.configuration, world=RSpec.world) @options = options @configuration = configuration @world = world end
def persist_example_statuses
def persist_example_statuses return unless (path = @configuration.example_status_persistence_file_path) ExampleStatusPersister.persist(@world.all_examples, path) rescue SystemCallError => e RSpec.warning "Could not write example statuses to #{path} (configured as " \ "`config.example_status_persistence_file_path`) due to a " \ "system error: #{e.inspect}. Please check that the config " \ "option is set to an accessible, valid file path", :call_site => nil end
def run(err, out)
-
out
(IO
) -- output stream -
err
(IO
) -- error stream
def run(err, out) setup(err, out) run_specs(@world.ordered_example_groups).tap do persist_example_statuses end end
def run_specs(example_groups)
-
(Fixnum)
- exit status code. 0 if all specs passed,
Parameters:
-
example_groups
(Array
) -- groups to run
def run_specs(example_groups) @configuration.reporter.report(@world.example_count(example_groups)) do |reporter| @configuration.with_suite_hooks do example_groups.map { |g| g.run(reporter) }.all? ? 0 : @configuration.failure_exit_code end end end
def setup(err, out)
-
out
(IO
) -- output stream -
err
(IO
) -- error stream
def setup(err, out) @configuration.error_stream = err @configuration.output_stream = out if @configuration.output_stream == $stdout @options.configure(@configuration) @configuration.load_spec_files @world.announce_filters end