PR#3754: Unify behavior when result is empty in get_maven/image/win/build
Merges #3754 https://pagure.io/koji/pull-request/3754 Fixes: #3753 https://pagure.io/koji/issue/3753 Unify behavior for empty result in get_maven_build as get_image_build and get_win_build
This commit is contained in:
commit
00a5f3be20
2 changed files with 68 additions and 1 deletions
|
|
@ -4823,7 +4823,10 @@ def get_maven_build(buildInfo, strict=False):
|
||||||
columns=['build_id', 'group_id', 'artifact_id', 'version'],
|
columns=['build_id', 'group_id', 'artifact_id', 'version'],
|
||||||
clauses=['build_id = %(build_id)i'],
|
clauses=['build_id = %(build_id)i'],
|
||||||
values={'build_id': build_id})
|
values={'build_id': build_id})
|
||||||
return query.executeOne(strict=strict)
|
result = query.executeOne()
|
||||||
|
if strict and not result:
|
||||||
|
raise koji.GenericError('no such maven build: %s' % buildInfo)
|
||||||
|
return result
|
||||||
|
|
||||||
|
|
||||||
def get_win_build(buildInfo, strict=False):
|
def get_win_build(buildInfo, strict=False):
|
||||||
|
|
|
||||||
64
tests/test_hub/test_get_maven_build.py
Normal file
64
tests/test_hub/test_get_maven_build.py
Normal file
|
|
@ -0,0 +1,64 @@
|
||||||
|
import mock
|
||||||
|
import koji
|
||||||
|
import kojihub
|
||||||
|
from .utils import DBQueryTestCase
|
||||||
|
|
||||||
|
|
||||||
|
class TestGetMavenBuild(DBQueryTestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
super(TestGetMavenBuild, self).setUp()
|
||||||
|
self.maxDiff = None
|
||||||
|
self.find_build_id = mock.patch('kojihub.kojihub.find_build_id').start()
|
||||||
|
|
||||||
|
def test_build_id_not_found(self):
|
||||||
|
self.find_build_id.return_value = None
|
||||||
|
result = kojihub.get_maven_build('test-build.1-23.1')
|
||||||
|
self.assertEqual(result, None)
|
||||||
|
self.assertEqual(len(self.queries), 0)
|
||||||
|
self.find_build_id.assert_called_once_with('test-build.1-23.1', strict=False)
|
||||||
|
|
||||||
|
def test_valid(self):
|
||||||
|
self.find_build_id.return_value = 123
|
||||||
|
self.qp_execute_one_return_value = {'build_id': 123}
|
||||||
|
kojihub.get_maven_build('test-build.1-23.1')
|
||||||
|
self.assertEqual(len(self.queries), 1)
|
||||||
|
query = self.queries[0]
|
||||||
|
self.assertEqual(query.tables, ['maven_builds'])
|
||||||
|
self.assertEqual(query.joins, None)
|
||||||
|
self.assertEqual(query.clauses, ['build_id = %(build_id)i'])
|
||||||
|
self.assertEqual(query.values, {'build_id': 123})
|
||||||
|
self.assertEqual(query.columns, ['artifact_id', 'build_id', 'group_id', 'version'])
|
||||||
|
|
||||||
|
self.find_build_id.assert_called_once_with('test-build.1-23.1', strict=False)
|
||||||
|
|
||||||
|
def test_without_result_without_strict(self):
|
||||||
|
self.find_build_id.return_value = 123
|
||||||
|
self.qp_execute_one_return_value = {}
|
||||||
|
result = kojihub.get_maven_build('test-build.1-23.1')
|
||||||
|
self.assertEqual(result, {})
|
||||||
|
self.assertEqual(len(self.queries), 1)
|
||||||
|
query = self.queries[0]
|
||||||
|
self.assertEqual(query.tables, ['maven_builds'])
|
||||||
|
self.assertEqual(query.joins, None)
|
||||||
|
self.assertEqual(query.clauses, ['build_id = %(build_id)i'])
|
||||||
|
self.assertEqual(query.values, {'build_id': 123})
|
||||||
|
self.assertEqual(query.columns, ['artifact_id', 'build_id', 'group_id', 'version'])
|
||||||
|
|
||||||
|
self.find_build_id.assert_called_once_with('test-build.1-23.1', strict=False)
|
||||||
|
|
||||||
|
def test_without_result_with_strict(self):
|
||||||
|
self.find_build_id.return_value = 123
|
||||||
|
self.qp_execute_one_return_value = {}
|
||||||
|
with self.assertRaises(koji.GenericError) as ex:
|
||||||
|
kojihub.get_maven_build('test-build.1-23.1', strict=True)
|
||||||
|
self.assertEqual('no such maven build: test-build.1-23.1', str(ex.exception))
|
||||||
|
self.assertEqual(len(self.queries), 1)
|
||||||
|
query = self.queries[0]
|
||||||
|
self.assertEqual(query.tables, ['maven_builds'])
|
||||||
|
self.assertEqual(query.joins, None)
|
||||||
|
self.assertEqual(query.clauses, ['build_id = %(build_id)i'])
|
||||||
|
self.assertEqual(query.values, {'build_id': 123})
|
||||||
|
self.assertEqual(query.columns, ['artifact_id', 'build_id', 'group_id', 'version'])
|
||||||
|
|
||||||
|
self.find_build_id.assert_called_once_with('test-build.1-23.1', strict=True)
|
||||||
Loading…
Add table
Add a link
Reference in a new issue