Merge "Handle unhandled ValueError Exception"
This commit is contained in:
commit
f0775849b4
@ -36,8 +36,11 @@ DOCKER_MINIMUM_MEMORY = 4 * 1024 * 1024
|
|||||||
|
|
||||||
|
|
||||||
def validate_limit(limit):
|
def validate_limit(limit):
|
||||||
|
try:
|
||||||
if limit is not None and int(limit) <= 0:
|
if limit is not None and int(limit) <= 0:
|
||||||
raise wsme.exc.ClientSideError(_("Limit must be positive"))
|
raise wsme.exc.ClientSideError(_("Limit must be positive integer"))
|
||||||
|
except ValueError:
|
||||||
|
raise wsme.exc.ClientSideError(_("Limit must be positive integer"))
|
||||||
|
|
||||||
if limit is not None:
|
if limit is not None:
|
||||||
return min(CONF.api.max_limit, int(limit))
|
return min(CONF.api.max_limit, int(limit))
|
||||||
|
47
zun/tests/unit/api/test_utils.py
Normal file
47
zun/tests/unit/api/test_utils.py
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
# not use this file except in compliance with the License. You may obtain
|
||||||
|
# a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
import wsme
|
||||||
|
|
||||||
|
from zun.api.utils import validate_limit
|
||||||
|
from zun.api.utils import validate_sort_dir
|
||||||
|
from zun.tests import base
|
||||||
|
|
||||||
|
|
||||||
|
class TestUtils(base.BaseTestCase):
|
||||||
|
"""Test cases for zun.api.utils"""
|
||||||
|
|
||||||
|
def test_validate_limit(self):
|
||||||
|
self.assertEqual(1000, validate_limit(None))
|
||||||
|
self.assertEqual(1000, validate_limit(1001))
|
||||||
|
self.assertEqual(50, validate_limit(50))
|
||||||
|
with self.assertRaisesRegexp(wsme.exc.ClientSideError,
|
||||||
|
"Limit must be positive"):
|
||||||
|
validate_limit(-1)
|
||||||
|
with self.assertRaisesRegexp(wsme.exc.ClientSideError,
|
||||||
|
"Limit must be positive"):
|
||||||
|
validate_limit(0)
|
||||||
|
with self.assertRaisesRegexp(wsme.exc.ClientSideError,
|
||||||
|
"Limit must be positive integer"):
|
||||||
|
validate_limit('a')
|
||||||
|
with self.assertRaisesRegexp(wsme.exc.ClientSideError,
|
||||||
|
"Limit must be positive integer"):
|
||||||
|
validate_limit('5.5')
|
||||||
|
|
||||||
|
def test_validate_sort_dir(self):
|
||||||
|
self.assertEqual('asc', validate_sort_dir('asc'))
|
||||||
|
self.assertEqual('desc', validate_sort_dir('desc'))
|
||||||
|
with self.assertRaisesRegexp(wsme.exc.ClientSideError,
|
||||||
|
"Invalid sort direction"):
|
||||||
|
validate_sort_dir(None)
|
||||||
|
with self.assertRaisesRegexp(wsme.exc.ClientSideError,
|
||||||
|
"Invalid sort direction"):
|
||||||
|
validate_sort_dir('abc')
|
Loading…
Reference in New Issue
Block a user