Register an at_exit hook that runs the suite.
# File lib/rspec/core/runner.rb, line 6 def self.autorun return if autorun_disabled? || installed_at_exit? || running_in_drb? at_exit { exit run(ARGV, $stderr, $stdout).to_i unless $! } @installed_at_exit = true end
# File lib/rspec/core/runner.rb, line 17 def self.autorun_disabled? @autorun_disabled ||= false end
# File lib/rspec/core/runner.rb, line 13 def self.disable_autorun! @autorun_disabled = true end
# File lib/rspec/core/runner.rb, line 21 def self.installed_at_exit? @installed_at_exit ||= false end
Run a suite of RSpec examples.
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`.
#### Parameters
args - an array of command-line-supported arguments
err - error stream (Default: $stderr)
out - output stream (Default: $stdout)
#### Returns
Fixnum - exit status code (0/1)
# File lib/rspec/core/runner.rb, line 55 def self.run(args, err=$stderr, out=$stdout) trap_interrupt options = ConfigurationOptions.new(args) options.parse_options if options.options[:drb] require 'rspec/core/drb_command_line' begin DRbCommandLine.new(options).run(err, out) rescue DRb::DRbConnError err.puts "No DRb server is running. Running in local process instead ..." CommandLine.new(options).run(err, out) end else CommandLine.new(options).run(err, out) end ensure RSpec.reset end
Generated with the Darkfish Rdoc Generator 2.