aa039bb011
We need to consolidate the unit tests into a separate directory so we can run just the unit tests in our py27 tox target. And we can in subsequent reviews add a parallel directory with functional tests. Related-Bug: #1439621 Change-Id: I8bf5af953fb31080096c371966f7dfda9edb1bf4
100 lines
3.9 KiB
Python
100 lines
3.9 KiB
Python
# Copyright 2011 Justin Santa Barbara
|
|
#
|
|
# 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.
|
|
|
|
from magnum.common import safe_utils
|
|
from magnum.tests import base
|
|
|
|
|
|
class GetCallArgsTestCase(base.BaseTestCase):
|
|
|
|
def _test_func(self, instance, red=None, blue=None):
|
|
pass
|
|
|
|
def test_all_kwargs(self):
|
|
args = ()
|
|
kwargs = {'instance': {'uuid': 1}, 'red': 3, 'blue': 4}
|
|
callargs = safe_utils.getcallargs(self._test_func, *args, **kwargs)
|
|
# implicit self counts as an arg
|
|
self.assertEqual(4, len(callargs))
|
|
self.assertIn('instance', callargs)
|
|
self.assertEqual({'uuid': 1}, callargs['instance'])
|
|
self.assertIn('red', callargs)
|
|
self.assertEqual(3, callargs['red'])
|
|
self.assertIn('blue', callargs)
|
|
self.assertEqual(4, callargs['blue'])
|
|
|
|
def test_all_args(self):
|
|
args = ({'uuid': 1}, 3, 4)
|
|
kwargs = {}
|
|
callargs = safe_utils.getcallargs(self._test_func, *args, **kwargs)
|
|
# implicit self counts as an arg
|
|
self.assertEqual(4, len(callargs))
|
|
self.assertIn('instance', callargs)
|
|
self.assertEqual({'uuid': 1}, callargs['instance'])
|
|
self.assertIn('red', callargs)
|
|
self.assertEqual(3, callargs['red'])
|
|
self.assertIn('blue', callargs)
|
|
self.assertEqual(4, callargs['blue'])
|
|
|
|
def test_mixed_args(self):
|
|
args = ({'uuid': 1}, 3)
|
|
kwargs = {'blue': 4}
|
|
callargs = safe_utils.getcallargs(self._test_func, *args, **kwargs)
|
|
# implicit self counts as an arg
|
|
self.assertEqual(4, len(callargs))
|
|
self.assertIn('instance', callargs)
|
|
self.assertEqual({'uuid': 1}, callargs['instance'])
|
|
self.assertIn('red', callargs)
|
|
self.assertEqual(3, callargs['red'])
|
|
self.assertIn('blue', callargs)
|
|
self.assertEqual(4, callargs['blue'])
|
|
|
|
def test_partial_kwargs(self):
|
|
args = ()
|
|
kwargs = {'instance': {'uuid': 1}, 'red': 3}
|
|
callargs = safe_utils.getcallargs(self._test_func, *args, **kwargs)
|
|
# implicit self counts as an arg
|
|
self.assertEqual(4, len(callargs))
|
|
self.assertIn('instance', callargs)
|
|
self.assertEqual({'uuid': 1}, callargs['instance'])
|
|
self.assertIn('red', callargs)
|
|
self.assertEqual(3, callargs['red'])
|
|
self.assertIn('blue', callargs)
|
|
self.assertIsNone(callargs['blue'])
|
|
|
|
def test_partial_args(self):
|
|
args = ({'uuid': 1}, 3)
|
|
kwargs = {}
|
|
callargs = safe_utils.getcallargs(self._test_func, *args, **kwargs)
|
|
# implicit self counts as an arg
|
|
self.assertEqual(4, len(callargs))
|
|
self.assertIn('instance', callargs)
|
|
self.assertEqual({'uuid': 1}, callargs['instance'])
|
|
self.assertIn('red', callargs)
|
|
self.assertEqual(3, callargs['red'])
|
|
self.assertIn('blue', callargs)
|
|
self.assertIsNone(callargs['blue'])
|
|
|
|
def test_partial_mixed_args(self):
|
|
args = (3,)
|
|
kwargs = {'instance': {'uuid': 1}}
|
|
callargs = safe_utils.getcallargs(self._test_func, *args, **kwargs)
|
|
self.assertEqual(4, len(callargs))
|
|
self.assertIn('instance', callargs)
|
|
self.assertEqual({'uuid': 1}, callargs['instance'])
|
|
self.assertIn('red', callargs)
|
|
self.assertEqual(3, callargs['red'])
|
|
self.assertIn('blue', callargs)
|
|
self.assertIsNone(callargs['blue'])
|