-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathcheck_buildfarm.rb
executable file
·86 lines (73 loc) · 2.83 KB
/
check_buildfarm.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
#!/usr/bin/env ruby
require_relative 'lib/buildfarm_tools'
require "optparse"
require "ostruct"
options = {}
optparser = OptionParser.new do |o|
o.banner = "Usage: #{$0} \"performance connext rep fastrtps-dynamic\""
o.on "-e", "--exclude EXCLUDE_JOBS", "A list of string separated by spaces that represent the regex on a job name that you want to exclude" do |exclude|
options[:exclude] = exclude.split(" ")
end
o.on("-h", "--help", "Prints this help") do
puts o
exit
end
end
optparser.parse!(ARGV)
if options[:exclude].nil?
options[:exclude] = []
end
def get_issues_list(jobs_to_filter = [])
# This function returns a map of possible problems in the buildfarm
# The key of the map is the hash value of the flakiness output
# The value is an Array of hashes with information about each test regression that belongs to the same problem
test_regressions_today = BuildfarmToolsLib::test_regressions_today.filter { |e| !jobs_to_filter.include?(e['job_name'])}
if test_regressions_today.nil?
puts "No test regressions found"
return {}
end
issues_map = Hash.new
test_regressions_today.each do |tr|
tr_flakiness_output = BuildfarmToolsLib::test_regression_flakiness(tr['error_name'])
next if tr_flakiness_output.empty?
tr_hash = tr_flakiness_output.hash
tr_flakiness_output.uniq! { |item| item["job_name"] }
tr_flakiness_output.map! { |item|
item['error_name'] = tr['error_name']
item['github_issues'] = BuildfarmToolsLib::test_regression_reported_issues(tr['error_name'])
if item['job_name'] != tr['job_name']
item['error_name'] = " (also in: \"#{item['job_name']}\" job)"
item['job_name'] = tr['job_name']
end
item
}
issues_map[tr_hash] = [] unless issues_map.has_key?(tr_hash)
# Group all issues by flakiness output
issues_map[tr_hash] += tr_flakiness_output
end
issues_map.each_pair do |key, value|
value.sort_by! { |item| item['error_name'] }.uniq! { |item| item['error_name'] }
end
end
def print_issues(issue_list)
# This function prints the hash returned by get_issues_list function in a human readable format
i = 1
issue_list.each do |value|
puts "Issue ##{i} in #{value[0]['job_name']}"
puts "- Failing #{value[0]['failure_percentage']}% in #{value[0]['failure_count']} out of #{value[0]['build_count']} builds"
value.each do |tr|
print "\t#{tr['error_name']}"
unless tr["github_issues"].empty?
print " (known issue in: #{tr['github_issues'].map { |item| "#{item['github_issue']} - #{item['status']}" }.join(" | ")})"
end
puts
end
puts
i += 1
end
end
unless options[:exclude].empty?
puts "Excluding '#{options[:exclude].join(", ")}' jobs"
end
issues = get_issues_list(options[:exclude]).values.sort_by { |issue| issue[0]['failure_count'].to_f }.reverse
print_issues(issues)