Class | Autotest::Rspec |
In: |
lib/autotest/rspec.rb
|
Parent: | Autotest |
# File lib/autotest/rspec.rb, line 22 22: def initialize 23: super 24: self.failed_results_re = /^\d+\)\n(?:\e\[\d*m)?(?:.*?Error in )?'([^\n]*)'(?: FAILED)?(?:\e\[\d*m)?\n(.*?)\n\n/m 25: self.completed_re = /\n(?:\e\[\d*m)?\d* examples?/m 26: end
# File lib/autotest/rspec.rb, line 28 28: def consolidate_failures(failed) 29: filters = new_hash_of_arrays 30: failed.each do |spec, trace| 31: if trace =~ /\n(\.\/)?(.*\.rb):[\d]+:\Z?/ 32: filters[$2] << spec 33: end 34: end 35: return filters 36: end
# File lib/autotest/rspec.rb, line 38 38: def make_test_cmd(files_to_test) 39: return "#{ruby} -S #{spec_command} #{add_options_if_present} #{files_to_test.keys.flatten.join(' ')}" 40: end
Finds the proper spec command to use. Precendence is set in the lazily-evaluated method spec_commands. Alias + Override that in ~/.autotest to provide a different spec command then the default paths provided.
# File lib/autotest/rspec.rb, line 50 50: def spec_command(separator=File::ALT_SEPARATOR) 51: unless defined? @spec_command then 52: @spec_command = spec_commands.find { |cmd| File.exists? cmd } 53: 54: raise RspecCommandError, "No spec command could be found!" unless @spec_command 55: 56: @spec_command.gsub! File::SEPARATOR, separator if separator 57: end 58: @spec_command 59: end
Autotest will look for spec commands in the following locations, in this order:
* bin/spec * default spec bin/loader installed in Rubygems
# File lib/autotest/rspec.rb, line 66 66: def spec_commands 67: [ 68: File.expand_path(File.join(File.dirname(__FILE__), '..', '..', 'bin', 'spec')), 69: File.join(Config::CONFIG['bindir'], 'spec') 70: ] 71: end