make cli and hub to support remove-extra for edit-tag

This commit is contained in:
Yuming Zhu 2017-03-10 00:28:16 +08:00 committed by Mike McLean
parent 120ee07d24
commit 75d07f6d01
4 changed files with 409 additions and 8 deletions

View file

@ -0,0 +1,196 @@
import mock
import unittest
import koji
import kojihub
UP = kojihub.UpdateProcessor
IP = kojihub.InsertProcessor
class TestEditTag(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._dml = mock.patch('kojihub._dml').start()
self._singleValue = mock.patch('kojihub._singleValue').start()
self.get_tag = mock.patch('kojihub.get_tag').start()
self.get_perm_id = mock.patch('kojihub.get_perm_id').start()
self.context = mock.patch('kojihub.context').start()
# It seems MagicMock will not automatically handle attributes that
# start with "assert"
self.context.session.assertLogin = mock.MagicMock()
def tearDown(self):
mock.patch.stopall()
def test_maven_disable(self):
self.context.opts.get.return_value = False
with self.assertRaises(koji.GenericError):
kojihub._edit_tag('tag', maven_support=True)
with self.assertRaises(koji.GenericError):
kojihub._edit_tag('tag', maven_include_all=False)
self.context.opts.get.return_value = True
kojihub._edit_tag('tag', maven_support=True)
self.get_tag.assert_called_once()
def test_edit(self):
self.get_tag.return_value = {'id': 333,
'perm_id': 1,
'name': 'tag',
'arches': 'arch1 arch3',
'locked': False,
'maven_support': False,
'maven_include_all': False,
'extra': {'exA': 1,
'exC': 3,
'exD': 4}}
self._singleValue.return_value = None
self.context.event_id = 42
self.context.session.user_id = 23
# no1 invoke
kwargs = {
'perm': None,
'name': 'newtag',
'arches': 'arch1 arch2',
'locked': True,
'maven_support': True,
'maven_include_all': True,
'extra': {'exB': [None, 1, 'text', {'dict': 'val'}, (1, 2)]},
'remove_extra': ['exC']
}
kojihub._edit_tag('tag', **kwargs)
self.get_perm_id.assert_not_called()
self._dml.assert_called_with("""UPDATE tag
SET name = %(name)s
WHERE id = %(tagID)i""", {'name': 'newtag', 'tagID': 333})
# check the insert/update
self.assertEqual(len(self.updates), 3)
self.assertEqual(len(self.inserts), 2)
values = {
'arches': 'arch1 arch2',
'locked': True,
'maven_include_all': True,
'maven_support': True,
'perm_id': None,
'id': 333,
'name': 'tag',
'extra': {'exA': 1, 'exC': 3, 'exD': 4}
}
revoke_data = {
'revoke_event': 42,
'revoker_id': 23
}
revoke_rawdata = {'active': 'NULL'}
update = self.updates[0]
self.assertEqual(update.table, 'tag_config')
self.assertEqual(update.values, values)
self.assertEqual(update.data, revoke_data)
self.assertEqual(update.rawdata, revoke_rawdata)
self.assertEqual(update.clauses, ['tag_id = %(id)i', 'active = TRUE'])
data = {
'create_event': 42,
'creator_id': 23,
'arches': 'arch1 arch2',
'locked': True,
'maven_include_all': True,
'maven_support': True,
'perm_id': None,
'tag_id': 333,
}
insert = self.inserts[0]
self.assertEqual(insert.table, 'tag_config')
self.assertEqual(insert.data, data)
self.assertEqual(insert.rawdata, {})
values = {
'key': 'exB',
'value': '[null, 1, "text", {"dict": "val"}, [1, 2]]',
'tag_id': 333,
}
update = self.updates[1]
self.assertEqual(update.table, 'tag_extra')
self.assertEqual(update.values, values)
self.assertEqual(update.data, revoke_data)
self.assertEqual(update.rawdata, revoke_rawdata)
self.assertEqual(update.clauses, ['tag_id = %(tag_id)i', 'key=%(key)s', 'active = TRUE'])
data = {
'create_event': 42,
'creator_id': 23,
'key': 'exB',
'value': '[null, 1, "text", {"dict": "val"}, [1, 2]]',
'tag_id': 333,
}
insert = self.inserts[1]
self.assertEqual(insert.table, 'tag_extra')
self.assertEqual(insert.data, data)
self.assertEqual(insert.rawdata, {})
values = {
'key': 'exC',
'tag_id': 333,
}
update = self.updates[2]
self.assertEqual(update.table, 'tag_extra')
self.assertEqual(update.values, values)
self.assertEqual(update.data, revoke_data)
self.assertEqual(update.rawdata, revoke_rawdata)
self.assertEqual(update.clauses, ['tag_id = %(tag_id)i', 'key=%(key)s', 'active = TRUE'])
# no2 invoke
kwargs = {
'extra': {'exC': 'text'},
'remove_extra': ['exC']
}
with self.assertRaises(koji.GenericError) as cm:
kojihub._edit_tag('tag', **kwargs)
self.assertEqual(cm.exception.args[0], 'Can not both add/update and remove tag-extra: \'exC\'')
# no3 invoke
kwargs = {
'remove_extra': ['exE']
}
with self.assertRaises(koji.GenericError) as cm:
kojihub._edit_tag('tag', **kwargs)
self.assertEqual(cm.exception.args[0], "Tag: tag doesn't have extra: exE")
# no4 invoke
self.get_perm_id.reset_mock()
self.get_perm_id.return_value = 99
self._singleValue.reset_mock()
self._singleValue.return_value = 2
kwargs = {
'perm': 'admin',
'name': 'newtag',
}
with self.assertRaises(koji.GenericError) as cm:
kojihub._edit_tag('tag', **kwargs)
self.get_perm_id.assert_called_once()
self._singleValue.assert_called_once()
self.assertEqual(cm.exception.args[0], 'Name newtag already taken by tag 2')