Add CLI related to channels + add comments to channels
Fixes: https://pagure.io/koji/issue/1711 Fixes: https://pagure.io/koji/issue/1849
This commit is contained in:
parent
ed2b0ad19b
commit
aec9fba121
18 changed files with 599 additions and 169 deletions
65
tests/test_hub/test_add_channel.py
Normal file
65
tests/test_hub/test_add_channel.py
Normal file
|
|
@ -0,0 +1,65 @@
|
|||
import unittest
|
||||
|
||||
import mock
|
||||
|
||||
import koji
|
||||
import kojihub
|
||||
|
||||
UP = kojihub.UpdateProcessor
|
||||
IP = kojihub.InsertProcessor
|
||||
|
||||
|
||||
class TestAddChannel(unittest.TestCase):
|
||||
|
||||
def setUp(self):
|
||||
|
||||
self.context = mock.patch('kojihub.context').start()
|
||||
self.context.session.assertPerm = mock.MagicMock()
|
||||
self.exports = kojihub.RootExports()
|
||||
self.channel_name = 'test-channel'
|
||||
self.description = 'test-description'
|
||||
self.InsertProcessor = mock.patch('kojihub.InsertProcessor',
|
||||
side_effect=self.getInsert).start()
|
||||
self.inserts = []
|
||||
self.insert_execute = mock.MagicMock()
|
||||
|
||||
def tearDown(self):
|
||||
mock.patch.stopall()
|
||||
|
||||
def getInsert(self, *args, **kwargs):
|
||||
insert = IP(*args, **kwargs)
|
||||
insert.execute = self.insert_execute
|
||||
self.inserts.append(insert)
|
||||
return insert
|
||||
|
||||
@mock.patch('kojihub.get_channel')
|
||||
@mock.patch('kojihub._singleValue')
|
||||
def test_add_channel_exists(self, _singleValue, get_channel):
|
||||
get_channel.return_value = {'id': 123, 'name': self.channel_name}
|
||||
with self.assertRaises(koji.GenericError):
|
||||
self.exports.addChannel(self.channel_name)
|
||||
get_channel.assert_called_once_with(self.channel_name, strict=False)
|
||||
_singleValue.assert_not_called()
|
||||
self.assertEqual(len(self.inserts), 0)
|
||||
|
||||
@mock.patch('kojihub.get_channel')
|
||||
@mock.patch('kojihub._singleValue')
|
||||
def test_add_channel_valid(self, _singleValue, get_channel):
|
||||
get_channel.return_value = {}
|
||||
_singleValue.side_effect = [12]
|
||||
|
||||
r = self.exports.addChannel(self.channel_name, description=self.description)
|
||||
self.assertEqual(r, 12)
|
||||
self.assertEqual(len(self.inserts), 1)
|
||||
insert = self.inserts[0]
|
||||
self.assertEqual(insert.data['name'], self.channel_name)
|
||||
self.assertEqual(insert.data['id'], 12)
|
||||
self.assertEqual(insert.data['description'], self.description)
|
||||
self.assertEqual(insert.table, 'channels')
|
||||
|
||||
self.context.session.assertPerm.assert_called_once_with('admin')
|
||||
get_channel.assert_called_once_with(self.channel_name, strict=False)
|
||||
self.assertEqual(_singleValue.call_count, 1)
|
||||
_singleValue.assert_has_calls([
|
||||
mock.call("SELECT nextval('channels_id_seq')", strict=True)
|
||||
])
|
||||
99
tests/test_hub/test_edit_channel.py
Normal file
99
tests/test_hub/test_edit_channel.py
Normal file
|
|
@ -0,0 +1,99 @@
|
|||
import unittest
|
||||
|
||||
import mock
|
||||
|
||||
import koji
|
||||
import kojihub
|
||||
|
||||
UP = kojihub.UpdateProcessor
|
||||
IP = kojihub.InsertProcessor
|
||||
|
||||
|
||||
class TestEditChannel(unittest.TestCase):
|
||||
def getInsert(self, *args, **kwargs):
|
||||
insert = IP(*args, **kwargs)
|
||||
insert.execute = mock.MagicMock()
|
||||
self.inserts.append(insert)
|
||||
return insert
|
||||
|
||||
def getUpdate(self, *args, **kwargs):
|
||||
update = UP(*args, **kwargs)
|
||||
update.execute = mock.MagicMock()
|
||||
self.updates.append(update)
|
||||
return update
|
||||
|
||||
def setUp(self):
|
||||
self.InsertProcessor = mock.patch('kojihub.InsertProcessor',
|
||||
side_effect=self.getInsert).start()
|
||||
self.inserts = []
|
||||
self.UpdateProcessor = mock.patch('kojihub.UpdateProcessor',
|
||||
side_effect=self.getUpdate).start()
|
||||
self.updates = []
|
||||
self.context = mock.patch('kojihub.context').start()
|
||||
self.context.session.assertPerm = mock.MagicMock()
|
||||
self.exports = kojihub.RootExports()
|
||||
self.channel_name = 'test-channel'
|
||||
self.channel_name_new = 'test-channel-2'
|
||||
|
||||
def tearDown(self):
|
||||
mock.patch.stopall()
|
||||
|
||||
@mock.patch('kojihub.get_channel')
|
||||
def test_edit_channel_missing(self, get_channel):
|
||||
expected = 'Invalid type for channelInfo: %s' % self.channel_name
|
||||
get_channel.side_effect = koji.GenericError(expected)
|
||||
with self.assertRaises(koji.GenericError) as ex:
|
||||
self.exports.editChannel(self.channel_name, name=self.channel_name_new)
|
||||
get_channel.assert_called_once_with(self.channel_name, strict=True)
|
||||
self.assertEqual(self.inserts, [])
|
||||
self.assertEqual(self.updates, [])
|
||||
self.assertEqual(expected, str(ex.exception))
|
||||
|
||||
@mock.patch('kojihub.get_channel')
|
||||
def test_edit_channel_already_exists(self, get_channel):
|
||||
get_channel.side_effect = [
|
||||
{
|
||||
'id': 123,
|
||||
'name': self.channel_name,
|
||||
'description': 'description',
|
||||
},
|
||||
{
|
||||
'id': 124,
|
||||
'name': self.channel_name_new,
|
||||
'description': 'description',
|
||||
}
|
||||
]
|
||||
with self.assertRaises(koji.GenericError) as ex:
|
||||
self.exports.editChannel(self.channel_name, name=self.channel_name_new)
|
||||
expected_calls = [mock.call(self.channel_name, strict=True),
|
||||
mock.call(self.channel_name_new, strict=False)]
|
||||
get_channel.assert_has_calls(expected_calls)
|
||||
self.assertEqual(self.inserts, [])
|
||||
self.assertEqual(self.updates, [])
|
||||
self.assertEqual('channel %s already exists (id=124)' % self.channel_name_new,
|
||||
str(ex.exception))
|
||||
|
||||
@mock.patch('kojihub.get_channel')
|
||||
def test_edit_channel_valid(self, get_channel):
|
||||
kojihub.get_channel.side_effect = [{
|
||||
'id': 123,
|
||||
'name': self.channel_name,
|
||||
'description': 'description',
|
||||
},
|
||||
{}]
|
||||
|
||||
r = self.exports.editChannel(self.channel_name, name=self.channel_name_new,
|
||||
description='description_new')
|
||||
self.assertIsNone(r)
|
||||
expected_calls = [mock.call(self.channel_name, strict=True),
|
||||
mock.call(self.channel_name_new, strict=False)]
|
||||
get_channel.assert_has_calls(expected_calls)
|
||||
|
||||
self.assertEqual(len(self.updates), 1)
|
||||
values = {'channelID': 123}
|
||||
clauses = ['id = %(channelID)i']
|
||||
|
||||
update = self.updates[0]
|
||||
self.assertEqual(update.table, 'channels')
|
||||
self.assertEqual(update.values, values)
|
||||
self.assertEqual(update.clauses, clauses)
|
||||
|
|
@ -1,22 +1,31 @@
|
|||
import unittest
|
||||
|
||||
import mock
|
||||
|
||||
import koji
|
||||
import kojihub
|
||||
|
||||
|
||||
class TestGetChannel(unittest.TestCase):
|
||||
|
||||
def setUp(self):
|
||||
self.context = mock.patch('kojihub.context').start()
|
||||
self.exports = kojihub.RootExports()
|
||||
|
||||
def tearDown(self):
|
||||
mock.patch.stopall()
|
||||
|
||||
def test_wrong_type_channelInfo(self):
|
||||
# dict
|
||||
channel_info = {'channel': 'val'}
|
||||
with self.assertRaises(koji.GenericError) as cm:
|
||||
kojihub.get_channel(channel_info)
|
||||
self.exports.getChannel(channel_info)
|
||||
self.assertEqual('Invalid type for channelInfo: %s' % type(channel_info),
|
||||
str(cm.exception))
|
||||
|
||||
#list
|
||||
# list
|
||||
channel_info = ['channel']
|
||||
with self.assertRaises(koji.GenericError) as cm:
|
||||
kojihub.get_channel(channel_info)
|
||||
self.exports.getChannel(channel_info)
|
||||
self.assertEqual('Invalid type for channelInfo: %s' % type(channel_info),
|
||||
str(cm.exception))
|
||||
|
|
|
|||
|
|
@ -1,6 +1,7 @@
|
|||
import mock
|
||||
import unittest
|
||||
|
||||
import mock
|
||||
|
||||
import koji
|
||||
import kojihub
|
||||
|
||||
|
|
@ -17,7 +18,7 @@ class TestListChannels(unittest.TestCase):
|
|||
|
||||
def setUp(self):
|
||||
self.QueryProcessor = mock.patch('kojihub.QueryProcessor',
|
||||
side_effect=self.getQuery).start()
|
||||
side_effect=self.getQuery).start()
|
||||
self.queries = []
|
||||
self.context = mock.patch('kojihub.context').start()
|
||||
# It seems MagicMock will not automatically handle attributes that
|
||||
|
|
@ -27,16 +28,15 @@ class TestListChannels(unittest.TestCase):
|
|||
def tearDown(self):
|
||||
mock.patch.stopall()
|
||||
|
||||
|
||||
def test_all(self):
|
||||
kojihub.list_channels()
|
||||
self.assertEqual(len(self.queries), 1)
|
||||
query = self.queries[0]
|
||||
self.assertEqual(query.tables, ['channels'])
|
||||
self.assertEqual(query.aliases, ['id', 'name'])
|
||||
self.assertEqual(query.aliases, ['description', 'id', 'name'])
|
||||
self.assertEqual(query.joins, None)
|
||||
self.assertEqual(query.values, {})
|
||||
self.assertEqual(query.columns, ['channels.id', 'channels.name'])
|
||||
self.assertEqual(query.columns, ['channels.description', 'channels.id', 'channels.name'])
|
||||
self.assertEqual(query.clauses, None)
|
||||
|
||||
def test_host(self):
|
||||
|
|
@ -50,10 +50,10 @@ class TestListChannels(unittest.TestCase):
|
|||
'host_channels.host_id = %(host_id)s'
|
||||
]
|
||||
self.assertEqual(query.tables, ['host_channels'])
|
||||
self.assertEqual(query.aliases, ['id', 'name'])
|
||||
self.assertEqual(query.aliases, ['description', 'id', 'name'])
|
||||
self.assertEqual(query.joins, joins)
|
||||
self.assertEqual(query.values, {'host_id': 1234})
|
||||
self.assertEqual(query.columns, ['channels.id', 'channels.name'])
|
||||
self.assertEqual(query.columns, ['channels.description', 'channels.id', 'channels.name'])
|
||||
self.assertEqual(query.clauses, clauses)
|
||||
|
||||
def test_host_and_event(self):
|
||||
|
|
@ -63,14 +63,15 @@ class TestListChannels(unittest.TestCase):
|
|||
query = self.queries[0]
|
||||
joins = ['channels ON channels.id = host_channels.channel_id']
|
||||
clauses = [
|
||||
'(host_channels.create_event <= 2345 AND ( host_channels.revoke_event IS NULL OR 2345 < host_channels.revoke_event ))',
|
||||
'(host_channels.create_event <= 2345 AND ( host_channels.revoke_event '
|
||||
'IS NULL OR 2345 < host_channels.revoke_event ))',
|
||||
'host_channels.host_id = %(host_id)s',
|
||||
]
|
||||
self.assertEqual(query.tables, ['host_channels'])
|
||||
self.assertEqual(query.aliases, ['id', 'name'])
|
||||
self.assertEqual(query.aliases, ['description', 'id', 'name'])
|
||||
self.assertEqual(query.joins, joins)
|
||||
self.assertEqual(query.values, {'host_id': 1234})
|
||||
self.assertEqual(query.columns, ['channels.id', 'channels.name'])
|
||||
self.assertEqual(query.columns, ['channels.description', 'channels.id', 'channels.name'])
|
||||
self.assertEqual(query.clauses, clauses)
|
||||
|
||||
def test_event_only(self):
|
||||
|
|
|
|||
38
tests/test_hub/test_remove_channel.py
Normal file
38
tests/test_hub/test_remove_channel.py
Normal file
|
|
@ -0,0 +1,38 @@
|
|||
import unittest
|
||||
|
||||
import mock
|
||||
|
||||
import koji
|
||||
import kojihub
|
||||
|
||||
UP = kojihub.UpdateProcessor
|
||||
|
||||
|
||||
class TestRemoveChannel(unittest.TestCase):
|
||||
def getUpdate(self, *args, **kwargs):
|
||||
update = UP(*args, **kwargs)
|
||||
update.execute = mock.MagicMock()
|
||||
self.updates.append(update)
|
||||
return update
|
||||
|
||||
def setUp(self):
|
||||
self.UpdateProcessor = mock.patch('kojihub.UpdateProcessor',
|
||||
side_effect=self.getUpdate).start()
|
||||
self.updates = []
|
||||
self.context = mock.patch('kojihub.context').start()
|
||||
self.context.session.assertPerm = mock.MagicMock()
|
||||
self.exports = kojihub.RootExports()
|
||||
self.channel_name = 'test-channel'
|
||||
|
||||
def tearDown(self):
|
||||
mock.patch.stopall()
|
||||
|
||||
@mock.patch('kojihub.get_channel_id')
|
||||
def test_non_exist_channel(self, get_channel_id):
|
||||
get_channel_id.side_effect = koji.GenericError('No such channel: %s' % self.channel_name)
|
||||
|
||||
with self.assertRaises(koji.GenericError):
|
||||
kojihub.remove_channel(self.channel_name)
|
||||
|
||||
get_channel_id.assert_called_once_with(self.channel_name, strict=True)
|
||||
self.assertEqual(len(self.updates), 0)
|
||||
|
|
@ -1,6 +1,7 @@
|
|||
import mock
|
||||
import unittest
|
||||
|
||||
import mock
|
||||
|
||||
import koji
|
||||
import kojihub
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue