#!/usr/bin/python
#
# Copyright (c) 2016 The Chromium OS Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
"""Unit tests for frontend/afe/rpc_utils.py."""
import mock
import unittest
import common
from autotest_lib.client.common_lib import control_data
from autotest_lib.frontend import setup_django_environment
from autotest_lib.frontend.afe import frontend_test_utils
from autotest_lib.frontend.afe import models
from autotest_lib.frontend.afe import rpc_utils
class DjangoModelTest(unittest.TestCase):
"""Unit tests for verifying Django behavior."""
def test_model_equal_by_id(self):
"""Test that model instances compare equal by id."""
x = models.Host(id=10, hostname='foo')
y = models.Host(id=10, hostname='bar')
self.assertEqual(x, y)
class RpcUtilsTest(unittest.TestCase,
frontend_test_utils.FrontendTestMixin):
"""Unit tests for functions in rpc_utils.py."""
def setUp(self):
self._frontend_common_setup()
def tearDown(self):
self._frontend_common_teardown()
def testCheckIsServer(self):
"""Ensure that test type check is correct."""
self.assertFalse(rpc_utils._check_is_server_test(None))
self.assertFalse(rpc_utils._check_is_server_test(
control_data.CONTROL_TYPE.CLIENT))
self.assertFalse(rpc_utils._check_is_server_test('Client'))
self.assertTrue(rpc_utils._check_is_server_test(
control_data.CONTROL_TYPE.SERVER))
self.assertTrue(rpc_utils._check_is_server_test('Server'))
self.assertFalse(rpc_utils._check_is_server_test('InvalidType'))
class ConvertToKwargsOnlyTest(unittest.TestCase):
"""Unit tests for _convert_to_kwargs_only()."""
# pylint: disable=unused-argument,missing-docstring
def test_no_kwargs_in_spec(self):
"""Test with function without kwargs."""
def func(a, b):
pass
got = rpc_utils._convert_to_kwargs_only(func, (1, 2), {})
self.assertEquals(got, {'a': 1, 'b': 2})
def test_pass_by_keyword(self):
"""Test passing required args by keyword."""
def func(a, b):
pass
got = rpc_utils._convert_to_kwargs_only(func, (), {'a': 1, 'b': 2})
self.assertEquals(got, {'a': 1, 'b': 2})
def test_with_kwargs(self):
"""Test with custom keyword arg."""
def func(a, b, **kwargs):
pass
got = rpc_utils._convert_to_kwargs_only(func, (1, 2), {'c': 3})
self.assertEquals(got, {'a': 1, 'b': 2, 'c': 3})
def test_with_kwargs_pass_by_keyword(self):
"""Test passing required parameter by keyword."""
def func(a, b, **kwargs):
pass
got = rpc_utils._convert_to_kwargs_only(func, (1,), {'b': 2, 'c': 3})
self.assertEquals(got, {'a': 1, 'b': 2, 'c': 3})
def test_empty_kwargs(self):
"""Test without passing kwargs."""
def func(a, b, **kwargs):
pass
got = rpc_utils._convert_to_kwargs_only(func, (1, 2), {})
self.assertEquals(got, {'a': 1, 'b': 2})
def test_with_varargs(self):
"""Test against vararg function."""
def func(a, b, *args):
pass
got = rpc_utils._convert_to_kwargs_only(func, (1, 2, 3), {})
self.assertEquals(got, {'a': 1, 'b': 2, 'args': (3,)})
class AllowedHostsForMasterJobTest(unittest.TestCase):
"""Unit tests for _allowed_hosts_for_master_job()."""
# pylint: disable=missing-docstring
@mock.patch.object(rpc_utils, 'bucket_hosts_by_shard', autospec=True)
def test_multiple_shards(self, bucket_mock):
bucket_mock.return_value = {
'shard1': [],
'shard2': [],
}
got = rpc_utils._allowed_hosts_for_master_job([])
self.assertFalse(got)
@mock.patch.object(rpc_utils, 'bucket_hosts_by_shard', autospec=True)
def test_one_shard_with_less_hosts(self, bucket_mock):
bucket_mock.return_value = {
'shard1': [1],
}
got = rpc_utils._allowed_hosts_for_master_job([1, 2])
self.assertFalse(got)
@mock.patch.object(rpc_utils, 'bucket_hosts_by_shard', autospec=True)
def test_one_shard_with_equal_hosts(self, bucket_mock):
bucket_mock.return_value = {
'shard1': [1, 2],
}
got = rpc_utils._allowed_hosts_for_master_job([1, 2])
self.assertTrue(got)
@mock.patch.object(rpc_utils, 'bucket_hosts_by_shard', autospec=True)
def test_no_shards(self, bucket_mock):
bucket_mock.return_value = {}
got = rpc_utils._allowed_hosts_for_master_job([1, 2])
self.assertTrue(got)
if __name__ == '__main__':
unittest.main()