Fix some bugs, line up the statuses, provide some failure feedback, flip the colour option

This commit is contained in:
Raoul Snyman 2017-10-26 15:05:10 -07:00
parent 93e0a35489
commit f6243f6e88

View File

@ -80,7 +80,7 @@ class JenkinsTrigger(object):
""" """
Create the JenkinsTrigger instance. Create the JenkinsTrigger instance.
""" """
self.build_numbers = {} self.build_number = {}
self.can_use_colour = can_use_colour and not os.name.startswith('nt') self.can_use_colour = can_use_colour and not os.name.startswith('nt')
self.repo_name = get_repo_name() self.repo_name = get_repo_name()
self.server = Jenkins(JENKINS_URL, username=username, password=password) self.server = Jenkins(JENKINS_URL, username=username, password=password)
@ -102,6 +102,7 @@ class JenkinsTrigger(object):
# We just want the name (not the email). # We just want the name (not the email).
name = ' '.join(raw_output.decode().split()[:-1]) name = ' '.join(raw_output.decode().split()[:-1])
cause = 'Build triggered by %s (%s)' % (name, self.repo_name) cause = 'Build triggered by %s (%s)' % (name, self.repo_name)
self.fetch_build_numbers()
self.server.build_job(OpenLPJobs.Branch_Pull, {'BRANCH_NAME': self.repo_name, 'cause': cause}) self.server.build_job(OpenLPJobs.Branch_Pull, {'BRANCH_NAME': self.repo_name, 'cause': cause})
def print_output(self): def print_output(self):
@ -117,6 +118,9 @@ class JenkinsTrigger(object):
for job in OpenLPJobs.Jobs: for job in OpenLPJobs.Jobs:
if not self.__print_build_info(job): if not self.__print_build_info(job):
if self.current_build:
print('Stopping after failure, see {}console for more details'.format(self.current_build['url']))
else:
print('Stopping after failure') print('Stopping after failure')
break break
@ -149,21 +153,22 @@ class JenkinsTrigger(object):
:param job_name: The name of the job we want the information from. For example *Branch-01-Pull*. Use the class :param job_name: The name of the job we want the information from. For example *Branch-01-Pull*. Use the class
variables from the :class:`OpenLPJobs` class. variables from the :class:`OpenLPJobs` class.
""" """
build_info = self._get_build_info(job_name, self.build_number[job_name]) self.current_build = self._get_build_info(job_name, self.build_number[job_name])
print('{} ... '.format(build_info['url']), end='', flush=True) print('{:<60} [RUNNING]'.format(self.current_build['url']), end='', flush=True)
is_success = False is_success = False
while build_info['building'] is True: while self.current_build['building'] is True:
time.sleep(0.5) time.sleep(0.5)
build_info = self.server.get_build_info(job_name, self.build_number[job_name]) self.current_build = self.server.get_build_info(job_name, self.build_number[job_name])
result_string = build_info['result'] result_string = self.current_build['result']
if self.can_use_colour and result_string == 'SUCCESS': is_success = result_string == 'SUCCESS'
if self.can_use_colour:
if is_success:
# Make 'SUCCESS' green. # Make 'SUCCESS' green.
result_string = '%s%s%s' % (Colour.GREEN_START, result_string, Colour.GREEN_END) result_string = '{}{}{}'.format(Colour.GREEN_START, result_string, Colour.GREEN_END)
is_success = True else:
elif self.can_use_colour:
# Make 'FAILURE' red. # Make 'FAILURE' red.
result_string = '%s%s%s' % (Colour.RED_START, result_string, Colour.RED_END) result_string = '{}{}{}'.format(Colour.RED_START, result_string, Colour.RED_END)
print('[{}]'.format(result_string)) print('\b\b\b\b\b\b\b\b\b[{:>7}]'.format(result_string))
return is_success return is_success
@ -203,11 +208,11 @@ def main():
Run the script Run the script
""" """
parser = ArgumentParser() parser = ArgumentParser()
parser.add_argument('-d', '--disable-output', action='store_false', default=True, help='Disable output') parser.add_argument('-d', '--disable-output', action='store_true', default=False, help='Disable output')
parser.add_argument('-b', '--open-browser', action='store_true', default=False, parser.add_argument('-b', '--open-browser', action='store_true', default=False,
help='Opens the jenkins page in your browser') help='Opens the jenkins page in your browser')
parser.add_argument('-c', '--enable-colour', action='store_false', default=True, parser.add_argument('-n', '--no-colour', action='store_true', default=False,
help='Enable coloured output. Disabled on Windows') help='Disable coloured output (always disabled on Windows)')
parser.add_argument('-u', '--username', required=True, help='Your Jenkins username') parser.add_argument('-u', '--username', required=True, help='Your Jenkins username')
parser.add_argument('-p', '--password', required=True, help='Your Jenkins password or personal token') parser.add_argument('-p', '--password', required=True, help='Your Jenkins password or personal token')
args = parser.parse_args() args = parser.parse_args()
@ -215,7 +220,7 @@ def main():
if not get_repo_name(): if not get_repo_name():
print('Not a branch. Have you pushed it to launchpad? Did you cd to the branch?') print('Not a branch. Have you pushed it to launchpad? Did you cd to the branch?')
return return
jenkins_trigger = JenkinsTrigger(username=args.username, password=args.password) jenkins_trigger = JenkinsTrigger(args.username, args.password, not args.no_colour)
jenkins_trigger.trigger_build() jenkins_trigger.trigger_build()
# Open the browser before printing the output. # Open the browser before printing the output.
if args.open_browser: if args.open_browser: