Make retry URL configurable (two flavors)

ubuntu/rebased
Paul Gevers 7 years ago
parent 9a28ec184b
commit def9d81c76
No known key found for this signature in database
GPG Key ID: 9C5C99EB05BD750A

@ -101,3 +101,4 @@ ADT_CI_URL = https://ci.debian.net/
ADT_REGRESSION_PENALTY = 10 ADT_REGRESSION_PENALTY = 10
ADT_SUCCESS_BOUNTY = 3 ADT_SUCCESS_BOUNTY = 3
ADT_BASELINE = reference ADT_BASELINE = reference
ADT_RETRY_URL_MECH = run_id

@ -553,6 +553,9 @@ class Britney(object):
self.options.ignore_cruft == "0": self.options.ignore_cruft == "0":
self.options.ignore_cruft = False self.options.ignore_cruft = False
if not hasattr(self.options, 'adt_retry_url_mech'):
self.options.adt_retry_url_mech = ''
self.policies.append(RCBugPolicy(self.options, self.suite_info)) self.policies.append(RCBugPolicy(self.options, self.suite_info))
self.policies.append(PiupartsPolicy(self.options, self.suite_info)) self.policies.append(PiupartsPolicy(self.options, self.suite_info))
if getattr(self.options, 'adt_enable') == 'yes': if getattr(self.options, 'adt_enable') == 'yes':

@ -228,8 +228,8 @@ class AutopkgtestPolicy(BasePolicy):
pass pass
for (testsrc, testver) in tests: for (testsrc, testver) in tests:
self.pkg_test_request(testsrc, arch, trigger, huge=is_huge) self.pkg_test_request(testsrc, arch, trigger, huge=is_huge)
(result, real_ver, url) = self.pkg_test_result(testsrc, testver, arch, trigger) (result, real_ver, run_id, url) = self.pkg_test_result(testsrc, testver, arch, trigger)
pkg_arch_result.setdefault((testsrc, real_ver), {})[arch] = (result, url) pkg_arch_result.setdefault((testsrc, real_ver), {})[arch] = (result, run_id, url)
# add test result details to Excuse # add test result details to Excuse
cloud_url = self.options.adt_ci_url + "packages/%(h)s/%(s)s/%(r)s/%(a)s" cloud_url = self.options.adt_ci_url + "packages/%(h)s/%(s)s/%(r)s/%(a)s"
@ -252,7 +252,7 @@ class AutopkgtestPolicy(BasePolicy):
html_archmsg = [] html_archmsg = []
for arch in sorted(arch_results): for arch in sorted(arch_results):
(status, log_url) = arch_results[arch] (status, run_id, log_url) = arch_results[arch]
artifact_url = None artifact_url = None
retry_url = None retry_url = None
history_url = None history_url = None
@ -264,12 +264,15 @@ class AutopkgtestPolicy(BasePolicy):
'h': srchash(testsrc), 's': testsrc, 'h': srchash(testsrc), 's': testsrc,
'r': self.options.series, 'a': arch} 'r': self.options.series, 'a': arch}
if status == 'REGRESSION': if status == 'REGRESSION':
retry_url = self.options.adt_ci_url + 'request.cgi?' + \ if self.options.adt_retry_url_mech == 'run_id':
urllib.parse.urlencode([('release', self.options.series), retry_url = self.options.adt_ci_url + 'api/v1/retry/' + run_id
('arch', arch), else:
('package', testsrc), retry_url = self.options.adt_ci_url + 'request.cgi?' + \
('trigger', trigger)] + urllib.parse.urlencode([('release', self.options.series),
[('ppa', p) for p in self.options.adt_ppas]) ('arch', arch),
('package', testsrc),
('trigger', trigger)] +
[('ppa', p) for p in self.options.adt_ppas])
if testver: if testver:
testname = '%s/%s' % (testsrc, testver) testname = '%s/%s' % (testsrc, testver)
else: else:
@ -767,12 +770,13 @@ class AutopkgtestPolicy(BasePolicy):
def pkg_test_result(self, src, ver, arch, trigger): def pkg_test_result(self, src, ver, arch, trigger):
'''Get current test status of a particular package '''Get current test status of a particular package
Return (status, real_version, log_url) tuple; status is a key in Return (status, real_version, run_id, log_url) tuple; status is a key in
EXCUSES_LABELS. log_url is None if the test is still running. EXCUSES_LABELS. run_id is None if the test is still running.
''' '''
# determine current test result status # determine current test result status
ever_passed = self.passed_in_baseline(src, arch) ever_passed = self.passed_in_baseline(src, arch)
url = None url = None
run_id = None
try: try:
r = self.test_results[trigger][src][arch] r = self.test_results[trigger][src][arch]
ver = r[1] ver = r[1]
@ -827,7 +831,7 @@ class AutopkgtestPolicy(BasePolicy):
raise RuntimeError('Result for %s/%s/%s (triggered by %s) is neither known nor pending!' % raise RuntimeError('Result for %s/%s/%s (triggered by %s) is neither known nor pending!' %
(src, ver, arch, trigger)) (src, ver, arch, trigger))
return (result, ver, url) return (result, ver, run_id, url)
def has_force_badtest(self, src, ver, arch): def has_force_badtest(self, src, ver, arch):
'''Check if src/ver/arch has a force-badtest hint''' '''Check if src/ver/arch has a force-badtest hint'''

Loading…
Cancel
Save