Donald Meyers / Mbed OS evan
Committer:
djmeyers
Date:
Sat Mar 18 22:37:16 2017 +0000
Revision:
0:06ee5f8a484a
Initial commit

Who changed what in which revision?

UserRevisionLine numberNew contents of line
djmeyers 0:06ee5f8a484a 1 # ==========================================
djmeyers 0:06ee5f8a484a 2 # Unity Project - A Test Framework for C
djmeyers 0:06ee5f8a484a 3 # Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
djmeyers 0:06ee5f8a484a 4 # [Released under MIT License. Please refer to license.txt for details]
djmeyers 0:06ee5f8a484a 5 # ==========================================
djmeyers 0:06ee5f8a484a 6
djmeyers 0:06ee5f8a484a 7 #!/usr/bin/ruby
djmeyers 0:06ee5f8a484a 8 #
djmeyers 0:06ee5f8a484a 9 # unity_test_summary.rb
djmeyers 0:06ee5f8a484a 10 #
djmeyers 0:06ee5f8a484a 11 require 'fileutils'
djmeyers 0:06ee5f8a484a 12 require 'set'
djmeyers 0:06ee5f8a484a 13
djmeyers 0:06ee5f8a484a 14 class UnityTestSummary
djmeyers 0:06ee5f8a484a 15 include FileUtils::Verbose
djmeyers 0:06ee5f8a484a 16
djmeyers 0:06ee5f8a484a 17 attr_reader :report, :total_tests, :failures, :ignored
djmeyers 0:06ee5f8a484a 18
djmeyers 0:06ee5f8a484a 19 def initialize(opts = {})
djmeyers 0:06ee5f8a484a 20 @report = ''
djmeyers 0:06ee5f8a484a 21 @total_tests = 0
djmeyers 0:06ee5f8a484a 22 @failures = 0
djmeyers 0:06ee5f8a484a 23 @ignored = 0
djmeyers 0:06ee5f8a484a 24
djmeyers 0:06ee5f8a484a 25
djmeyers 0:06ee5f8a484a 26 end
djmeyers 0:06ee5f8a484a 27
djmeyers 0:06ee5f8a484a 28 def run
djmeyers 0:06ee5f8a484a 29 # Clean up result file names
djmeyers 0:06ee5f8a484a 30 results = @targets.map {|target| target.gsub(/\\/,'/')}
djmeyers 0:06ee5f8a484a 31
djmeyers 0:06ee5f8a484a 32 # Dig through each result file, looking for details on pass/fail:
djmeyers 0:06ee5f8a484a 33 failure_output = []
djmeyers 0:06ee5f8a484a 34 ignore_output = []
djmeyers 0:06ee5f8a484a 35
djmeyers 0:06ee5f8a484a 36 results.each do |result_file|
djmeyers 0:06ee5f8a484a 37 lines = File.readlines(result_file).map { |line| line.chomp }
djmeyers 0:06ee5f8a484a 38 if lines.length == 0
djmeyers 0:06ee5f8a484a 39 raise "Empty test result file: #{result_file}"
djmeyers 0:06ee5f8a484a 40 else
djmeyers 0:06ee5f8a484a 41 output = get_details(result_file, lines)
djmeyers 0:06ee5f8a484a 42 failure_output << output[:failures] unless output[:failures].empty?
djmeyers 0:06ee5f8a484a 43 ignore_output << output[:ignores] unless output[:ignores].empty?
djmeyers 0:06ee5f8a484a 44 tests,failures,ignored = parse_test_summary(lines)
djmeyers 0:06ee5f8a484a 45 @total_tests += tests
djmeyers 0:06ee5f8a484a 46 @failures += failures
djmeyers 0:06ee5f8a484a 47 @ignored += ignored
djmeyers 0:06ee5f8a484a 48 end
djmeyers 0:06ee5f8a484a 49 end
djmeyers 0:06ee5f8a484a 50
djmeyers 0:06ee5f8a484a 51 if @ignored > 0
djmeyers 0:06ee5f8a484a 52 @report += "\n"
djmeyers 0:06ee5f8a484a 53 @report += "--------------------------\n"
djmeyers 0:06ee5f8a484a 54 @report += "UNITY IGNORED TEST SUMMARY\n"
djmeyers 0:06ee5f8a484a 55 @report += "--------------------------\n"
djmeyers 0:06ee5f8a484a 56 @report += ignore_output.flatten.join("\n")
djmeyers 0:06ee5f8a484a 57 end
djmeyers 0:06ee5f8a484a 58
djmeyers 0:06ee5f8a484a 59 if @failures > 0
djmeyers 0:06ee5f8a484a 60 @report += "\n"
djmeyers 0:06ee5f8a484a 61 @report += "--------------------------\n"
djmeyers 0:06ee5f8a484a 62 @report += "UNITY FAILED TEST SUMMARY\n"
djmeyers 0:06ee5f8a484a 63 @report += "--------------------------\n"
djmeyers 0:06ee5f8a484a 64 @report += failure_output.flatten.join("\n")
djmeyers 0:06ee5f8a484a 65 end
djmeyers 0:06ee5f8a484a 66
djmeyers 0:06ee5f8a484a 67 @report += "\n"
djmeyers 0:06ee5f8a484a 68 @report += "--------------------------\n"
djmeyers 0:06ee5f8a484a 69 @report += "OVERALL UNITY TEST SUMMARY\n"
djmeyers 0:06ee5f8a484a 70 @report += "--------------------------\n"
djmeyers 0:06ee5f8a484a 71 @report += "#{@total_tests} TOTAL TESTS #{@failures} TOTAL FAILURES #{@ignored} IGNORED\n"
djmeyers 0:06ee5f8a484a 72 @report += "\n"
djmeyers 0:06ee5f8a484a 73 end
djmeyers 0:06ee5f8a484a 74
djmeyers 0:06ee5f8a484a 75 def set_targets(target_array)
djmeyers 0:06ee5f8a484a 76 @targets = target_array
djmeyers 0:06ee5f8a484a 77 end
djmeyers 0:06ee5f8a484a 78
djmeyers 0:06ee5f8a484a 79 def set_root_path(path)
djmeyers 0:06ee5f8a484a 80 @root = path
djmeyers 0:06ee5f8a484a 81 end
djmeyers 0:06ee5f8a484a 82
djmeyers 0:06ee5f8a484a 83 def usage(err_msg=nil)
djmeyers 0:06ee5f8a484a 84 puts "\nERROR: "
djmeyers 0:06ee5f8a484a 85 puts err_msg if err_msg
djmeyers 0:06ee5f8a484a 86 puts "\nUsage: unity_test_summary.rb result_file_directory/ root_path/"
djmeyers 0:06ee5f8a484a 87 puts " result_file_directory - The location of your results files."
djmeyers 0:06ee5f8a484a 88 puts " Defaults to current directory if not specified."
djmeyers 0:06ee5f8a484a 89 puts " Should end in / if specified."
djmeyers 0:06ee5f8a484a 90 puts " root_path - Helpful for producing more verbose output if using relative paths."
djmeyers 0:06ee5f8a484a 91 exit 1
djmeyers 0:06ee5f8a484a 92 end
djmeyers 0:06ee5f8a484a 93
djmeyers 0:06ee5f8a484a 94 protected
djmeyers 0:06ee5f8a484a 95
djmeyers 0:06ee5f8a484a 96 def get_details(result_file, lines)
djmeyers 0:06ee5f8a484a 97 results = { :failures => [], :ignores => [], :successes => [] }
djmeyers 0:06ee5f8a484a 98 lines.each do |line|
djmeyers 0:06ee5f8a484a 99 src_file,src_line,test_name,status,msg = line.split(/:/)
djmeyers 0:06ee5f8a484a 100 line_out = ((@root && (@root != 0)) ? "#{@root}#{line}" : line ).gsub(/\//, "\\")
djmeyers 0:06ee5f8a484a 101 case(status)
djmeyers 0:06ee5f8a484a 102 when 'IGNORE' then results[:ignores] << line_out
djmeyers 0:06ee5f8a484a 103 when 'FAIL' then results[:failures] << line_out
djmeyers 0:06ee5f8a484a 104 when 'PASS' then results[:successes] << line_out
djmeyers 0:06ee5f8a484a 105 end
djmeyers 0:06ee5f8a484a 106 end
djmeyers 0:06ee5f8a484a 107 return results
djmeyers 0:06ee5f8a484a 108 end
djmeyers 0:06ee5f8a484a 109
djmeyers 0:06ee5f8a484a 110 def parse_test_summary(summary)
djmeyers 0:06ee5f8a484a 111 if summary.find { |v| v =~ /(\d+) Tests (\d+) Failures (\d+) Ignored/ }
djmeyers 0:06ee5f8a484a 112 [$1.to_i,$2.to_i,$3.to_i]
djmeyers 0:06ee5f8a484a 113 else
djmeyers 0:06ee5f8a484a 114 raise "Couldn't parse test results: #{summary}"
djmeyers 0:06ee5f8a484a 115 end
djmeyers 0:06ee5f8a484a 116 end
djmeyers 0:06ee5f8a484a 117
djmeyers 0:06ee5f8a484a 118 def here; File.expand_path(File.dirname(__FILE__)); end
djmeyers 0:06ee5f8a484a 119
djmeyers 0:06ee5f8a484a 120 end
djmeyers 0:06ee5f8a484a 121
djmeyers 0:06ee5f8a484a 122 if $0 == __FILE__
djmeyers 0:06ee5f8a484a 123
djmeyers 0:06ee5f8a484a 124 #parse out the command options
djmeyers 0:06ee5f8a484a 125 opts, args = ARGV.partition {|v| v =~ /^--\w+/}
djmeyers 0:06ee5f8a484a 126 opts.map! {|v| v[2..-1].to_sym }
djmeyers 0:06ee5f8a484a 127
djmeyers 0:06ee5f8a484a 128 #create an instance to work with
djmeyers 0:06ee5f8a484a 129 uts = UnityTestSummary.new(opts)
djmeyers 0:06ee5f8a484a 130
djmeyers 0:06ee5f8a484a 131 begin
djmeyers 0:06ee5f8a484a 132 #look in the specified or current directory for result files
djmeyers 0:06ee5f8a484a 133 args[0] ||= './'
djmeyers 0:06ee5f8a484a 134 targets = "#{ARGV[0].gsub(/\\/, '/')}**/*.test*"
djmeyers 0:06ee5f8a484a 135 results = Dir[targets]
djmeyers 0:06ee5f8a484a 136 raise "No *.testpass, *.testfail, or *.testresults files found in '#{targets}'" if results.empty?
djmeyers 0:06ee5f8a484a 137 uts.set_targets(results)
djmeyers 0:06ee5f8a484a 138
djmeyers 0:06ee5f8a484a 139 #set the root path
djmeyers 0:06ee5f8a484a 140 args[1] ||= Dir.pwd + '/'
djmeyers 0:06ee5f8a484a 141 uts.set_root_path(ARGV[1])
djmeyers 0:06ee5f8a484a 142
djmeyers 0:06ee5f8a484a 143 #run the summarizer
djmeyers 0:06ee5f8a484a 144 puts uts.run
djmeyers 0:06ee5f8a484a 145 rescue Exception => e
djmeyers 0:06ee5f8a484a 146 uts.usage e.message
djmeyers 0:06ee5f8a484a 147 end
djmeyers 0:06ee5f8a484a 148 end