Sha256: 28afe543bd731a48ad4694d91777054186f40389741b6c6a2465d511fa10506d
Contents?: true
Size: 1.18 KB
Versions: 8
Compression:
Stored size: 1.18 KB
Contents
HH = '#' * 22 unless defined?(HH) H = '#' * 5 unless defined?(H) def usage puts <<-EOS Ctrl-\\ or ctrl-4 Running all tests Ctrl-C Exit EOS end def run(cmd) puts "#{HH} #{Time.now} #{HH}" puts "#{H} #{cmd}" system "/usr/bin/time --format '#{HH} Elapsed time %E' #{cmd}" end def run_it(type, file) case type when 'test'; run %(ruby -I test #{file}) # when 'spec'; run %(rspec -X #{file}) else; puts "#{H} unknown type: #{type}, file: #{file}" end end def run_all_tests puts "\n#{HH} Running all tests #{HH}\n" %w[test spec].each { |dir| run "rake #{dir}" if File.exist?(dir) } end def run_matching_files(base) base = base.split('_').first %w[test spec].each { |type| files = Dir["#{type}/**/*.rb"].select { |file| file =~ /#{base}_.*\.rb/ } run_it type, files.join(' ') unless files.empty? } end %w[test spec].each { |type| watch("#{type}/#{type}_helper\.rb") { run_all_tests } watch('lib/.*\.rb') { run_all_tests } watch("#{type}/.*/*_#{type}\.rb") { |match| run_it type, match[0] } } # Ctrl-\ or ctrl-4 Signal.trap('QUIT') { run_all_tests } # Ctrl-C Signal.trap('INT') { abort("Interrupted\n") } usage
Version data entries
8 entries across 8 versions & 5 rubygems