forked from RazTamir/bugzilla-reports-tool
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrelease_readiness_criteria.py
99 lines (85 loc) · 3.17 KB
/
release_readiness_criteria.py
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
87
88
89
90
91
92
93
94
95
96
97
98
99
#!/usr/bin/env python
import time
from helpers import *
import datetime
now = datetime.datetime.now()
g = gapi.GoogleSpreadSheetAPI(SPREADSHEET_NAME, "Release Readiness Criteria")
qe_backlog = len(get_qe_backlog())
g.update_sheet(6, 3, qe_backlog)
dev_backlog = len(get_dev_backlog(BUGZILLA_VERSION_FLAG))
g.update_sheet(6, 4, dev_backlog)
blockers = len(get_open_blockers())
g.update_sheet(6, 5, blockers)
candidate_blockers = len(get_open_candidate_blockers())
g.update_sheet(6, 6, candidate_blockers)
critical_bugs = len(get_critical_bugs())
g.update_sheet(6, 7, critical_bugs)
regressions = len(get_regression_bugs())
g.update_sheet(6, 8, regressions)
untriaged = len(get_untriaged_bugs(BUGZILLA_VERSION_FLAG))
g.update_sheet(6, 9, untriaged)
dec_bugs = len(get_doc_bugs())
g.update_sheet(6, 10, dec_bugs)
# Sleep to ensure no exception will raise from Google API due to writes limit
time.sleep(40)
bugs_for_pm_score = filter_only_bugs(get_dev_backlog(""))
top_10_bugs = sort_by_pm_score(bugs_for_pm_score)[:10]
for idx, bug in enumerate(top_10_bugs):
row = 10 + idx
column = 7
g.update_sheet(
row,
column,
(
f'=HYPERLINK("https://bugzilla.redhat.com/show_bug'
f'.cgi?id={bug.bug_id}", "{bug.bug_id}")'
)
)
g.update_sheet(row, column+1, bug.summary)
g.update_sheet(row, column+6, bug.status)
g.update_sheet(row, column+7, bug.component)
g.update_sheet(row, column+8, bug.severity)
converted = datetime.datetime.strptime(
bug.creation_time.value, "%Y%m%dT%H:%M:%S"
)
g.update_sheet(row, column + 9, (now - converted).days)
# Regression rate
all_bugs = len(get_all_bugs_in_version(version=VERSION))
all_regressions = len(get_all_regression_bugs(version=VERSION))
if all_bugs > 0:
regression_rate = round((all_regressions / float(all_bugs)), 4)
g.update_sheet(10, 2, regression_rate)
# FailedQA rate
all_bug_to_version = get_all_bugs_targeted_to_version()
all_failed_qa = get_all_failedqa_bugs(version=BUGZILLA_VERSION_FLAG)
failed_qa_count = 0
for bz in all_failed_qa:
failed_qa_count += str(bz.get_history_raw()).count(
"'removed': 'ON_QA', 'added': 'ASSIGNED'"
)
fixed_bugs = 0
for bz in all_bug_to_version:
fixed_bugs += str(bz.get_history_raw()).count("'added': 'ON_QA'")
if fixed_bugs > 0:
failed_qa_rate = round((failed_qa_count / float(fixed_bugs)), 4)
g.update_sheet(13, 2, failed_qa_rate)
# Verification rate
all_verified = len(get_all_verified_bugs(version=BUGZILLA_VERSION_FLAG))
all_ready_for_testing = len(get_all_ready_for_testing_bugs(
version=BUGZILLA_VERSION_FLAG
))
if all_ready_for_testing > 0:
failed_qa_rate = round((all_verified / float(all_ready_for_testing)), 4)
g.update_sheet(16, 2, failed_qa_rate)
# Verification rate weekly
verified_weekly = 0
for c_from, c_to in [
('-1w', 'Now'), ('-2w', '-1w'), ('-3w', '-2w'), ('-4w', '-3w'),
('-5w', '-4w'), ('-6w', '-5w'), ('-7w', '-6w'), ('-8w', '-7w')
]:
this_week = len(get_verified_bugs(
changed_from=c_from, changed_to=c_to
))
verified_weekly += this_week
g.update_sheet(19, 2, verified_weekly / 8)
g.update_sheet(1, 1, f'Last update: {now.strftime("%Y-%m-%d %H:%M")}')