debian-koji/tests/test_cli/test_buildinfo.py
2022-08-23 09:26:13 +02:00

141 lines
5.5 KiB
Python

from __future__ import absolute_import
import koji
import mock
import os
import time
import copy
import locale
from six.moves import StringIO
from koji_cli.commands import anon_handle_buildinfo
from . import utils
class TestBuildinfo(utils.CliTestCase):
def setUp(self):
# force locale to compare 'expect' value
locale.setlocale(locale.LC_ALL, ('en_US', 'UTF-8'))
self.maxDiff = None
self.options = mock.MagicMock()
self.options.quiet = True
self.options.debug = False
self.session = mock.MagicMock()
self.session.getAPIVersion.return_value = koji.API_VERSION
self.error_format = """Usage: %s buildinfo [options] <n-v-r> [<n-v-r> ...]
(Specify the --help global option for a list of other help options)
%s: error: {message}
""" % (self.progname, self.progname)
self.original_timezone = os.environ.get('TZ')
os.environ['TZ'] = 'UTC'
time.tzset()
self.taskinfo = {'arch': 'noarch',
'id': 8,
'method': 'build',
'request': ['src', 'target', 'opts']}
self.buildinfo = {'build_id': 1,
'id': 1,
'name': 'test-build',
'release': '1',
'task_id': 8,
'version': '1',
'state': 1,
'completion_ts': 1614869140.368759,
'owner_name': 'kojiadmin',
'volume_name': 'DEFAULT'}
def tearDown(self):
locale.resetlocale()
if self.original_timezone is None:
del os.environ['TZ']
else:
os.environ['TZ'] = self.original_timezone
time.tzset()
@mock.patch('sys.stdout', new_callable=StringIO)
def test_buildinfo_valid(self, stdout):
build = 'test-build-1-1'
self.session.getBuild.return_value = self.buildinfo
self.session.getTaskInfo.return_value = self.taskinfo
self.session.listTags.return_value = []
self.session.getMavenBuild.return_value = None
self.session.getWinBuild.return_value = None
self.session.listArchives.return_value = []
self.session.listRPMs.return_value = []
expected_stdout = """BUILD: test-build-1-1 [1]
State: COMPLETE
Built by: kojiadmin
Volume: DEFAULT
Task: 8 build (target, src)
Finished: Thu, 04 Mar 2021 14:45:40 UTC
Tags:
"""
anon_handle_buildinfo(self.options, self.session, [build])
self.assert_console_message(stdout, expected_stdout)
self.session.listTags.assert_called_once_with(build)
self.session.getBuild.assert_called_once_with(build)
self.session.getTaskInfo.assert_called_once_with(self.buildinfo['task_id'], request=True)
self.session.getMavenBuild.assert_called_once_with(self.buildinfo['id'])
self.session.getWinBuild.assert_called_once_with(self.buildinfo['id'])
self.session.listRPMs.assert_called_once_with(buildID=self.buildinfo['id'])
self.assertEqual(self.session.listArchives.call_count, 4)
def test_buildinfo_more_build_with_non_exist_build(self):
build = 'test-build-1-1'
non_exist_build = 'test-build-11-12'
buildinfo = copy.deepcopy(self.buildinfo)
buildinfo['task_id'] = None
self.session.getBuild.side_effect = [None, buildinfo]
self.session.listTags.return_value = []
self.session.getMavenBuild.return_value = None
self.session.getWinBuild.return_value = None
self.session.listArchives.return_value = []
self.session.listRPMs.return_value = []
expected_stdout = """BUILD: test-build-1-1 [1]
State: COMPLETE
Built by: kojiadmin
Volume: DEFAULT
Task: none
Finished: Thu, 04 Mar 2021 14:45:40 UTC
Tags:
"""
arguments = [non_exist_build, build]
self.assert_system_exit(
anon_handle_buildinfo,
self.options, self.session, arguments,
stderr="No such build: %s\n\n" % non_exist_build,
stdout=expected_stdout,
activate_session=None,
exit_code=1)
self.session.listTags.assert_called_once_with(build)
self.session.getMavenBuild.assert_called_once_with(self.buildinfo['id'])
self.session.getWinBuild.assert_called_once_with(self.buildinfo['id'])
self.session.listRPMs.assert_called_once_with(buildID=self.buildinfo['id'])
self.assertEqual(self.session.getBuild.call_count, 2)
self.assertEqual(self.session.listArchives.call_count, 4)
def test_buildinfo_non_exist_build(self):
non_exist_build = 'test-build-11-12'
self.session.getBuild.return_value = None
arguments = [non_exist_build]
self.assert_system_exit(
anon_handle_buildinfo,
self.options, self.session, arguments,
stderr="No such build: %s\n\n" % non_exist_build,
stdout='',
activate_session=None,
exit_code=1)
def test_buildinfo_without_option(self):
arguments = []
self.assert_system_exit(
anon_handle_buildinfo,
self.options, self.session, arguments,
stdout='',
stderr=self.format_error_message("Please specify a build"),
exit_code=2,
activate_session=None)
self.session.listTags.assert_not_called()
self.session.getMavenBuild.assert_not_called()
self.session.getWinBuild.assert_not_called()
self.session.listRPMs.assert_not_called()