improve coverage rate in existing test cases.
This commit is contained in:
parent
8a273b2cae
commit
bdcb8065d2
2 changed files with 57 additions and 3 deletions
|
|
@ -5,11 +5,20 @@ import six
|
|||
import unittest
|
||||
|
||||
from koji_cli.commands import handle_block_group
|
||||
from . import utils
|
||||
|
||||
class TestBlockGroup(unittest.TestCase):
|
||||
|
||||
class TestBlockGroup(utils.CliTestCase):
|
||||
# Show long diffs in error output...
|
||||
maxDiff = None
|
||||
|
||||
def setUp(self):
|
||||
self.error_format = """Usage: %s block-group <tag> <group>
|
||||
(Specify the --help global option for a list of other help options)
|
||||
|
||||
%s: error: {message}
|
||||
""" % (self.progname, self.progname)
|
||||
|
||||
@mock.patch('sys.stdout', new_callable=six.StringIO)
|
||||
@mock.patch('koji_cli.commands.activate_session')
|
||||
def test_handle_block_group_nonexistent_tag(self, activate_session_mock, stdout):
|
||||
|
|
@ -67,7 +76,7 @@ class TestBlockGroup(unittest.TestCase):
|
|||
|
||||
@mock.patch('sys.stdout', new_callable=six.StringIO)
|
||||
@mock.patch('koji_cli.commands.activate_session')
|
||||
def test_handle_block_group_nonexistent_group(self, activate_session_mock, stdout):
|
||||
def test_handle_block_group(self, activate_session_mock, stdout):
|
||||
tag = 'tag'
|
||||
group = 'group'
|
||||
arguments = [tag, group]
|
||||
|
|
@ -93,3 +102,28 @@ class TestBlockGroup(unittest.TestCase):
|
|||
session.getTagGroups.assert_called_once_with(tag, inherit=False)
|
||||
session.groupListBlock.assert_called_once_with(tag, group)
|
||||
self.assertEqual(rv, None)
|
||||
|
||||
@mock.patch('sys.stdout', new_callable=six.StringIO)
|
||||
@mock.patch('koji_cli.commands.activate_session')
|
||||
def test_handle_block_group_error_handling(self, activate_session_mock, stdout):
|
||||
session = mock.MagicMock()
|
||||
options = mock.MagicMock()
|
||||
|
||||
expected = self.format_error_message(
|
||||
"Please specify a tag name and a group name")
|
||||
for args in [[], ['tag'], ['tag', 'grp', 'etc']]:
|
||||
self.assert_system_exit(
|
||||
handle_block_group,
|
||||
options,
|
||||
session,
|
||||
args,
|
||||
stderr=expected,
|
||||
activate_session=None)
|
||||
|
||||
# if we don't have 'admin' permission
|
||||
session.hasPerm.return_value = False
|
||||
rv = handle_block_group(options, session, ['tag', 'grp'])
|
||||
self.assert_console_message(
|
||||
stdout, 'This action requires admin privileges\n')
|
||||
self.assertEqual(rv, 1)
|
||||
activate_session_mock.assert_called_with(session, options)
|
||||
|
|
|
|||
|
|
@ -1,13 +1,33 @@
|
|||
# coding=utf-8
|
||||
from __future__ import absolute_import
|
||||
import mock
|
||||
import six
|
||||
import unittest
|
||||
import koji
|
||||
|
||||
from koji_cli.commands import handle_moshimoshi
|
||||
from koji_cli.commands import handle_moshimoshi, _printable_unicode
|
||||
from . import utils
|
||||
|
||||
|
||||
class TestPrintUnicode(utils.CliTestCase):
|
||||
|
||||
greetings = ('hello',
|
||||
'bonjour',
|
||||
u'céad míle fáilte',
|
||||
u'hylô',
|
||||
u'你好',
|
||||
u'こんにちは',
|
||||
u'안녕하세요')
|
||||
|
||||
def test_printable_unicode(self):
|
||||
for s in self.greetings:
|
||||
result = _printable_unicode(s)
|
||||
if six.PY2:
|
||||
self.assertEqual(type(result), type(str()))
|
||||
else:
|
||||
self.assertEqual(type(result), type(str()))
|
||||
|
||||
|
||||
class TestHello(utils.CliTestCase):
|
||||
|
||||
# Show long diffs in error output...
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue