blob: cd9936c6aedafa1cd8b5cf738ff192830f04b5a7 [file] [log] [blame]
# Copyright 2014 NEC Corporation.
# All Rights Reserved.
#
# 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 mock
from tempest.common import debug
from tempest import config
from tempest.openstack.common.fixture import mockpatch
from tempest import test
from tempest.tests import base
from tempest.tests import fake_config
class TestDebug(base.TestCase):
def setUp(self):
super(TestDebug, self).setUp()
self.useFixture(fake_config.ConfigFixture())
self.stubs.Set(config, 'TempestConfigPrivate', fake_config.FakePrivate)
common_pre = 'tempest.common.commands'
self.ip_addr_raw_mock = self.patch(common_pre + '.ip_addr_raw')
self.ip_route_raw_mock = self.patch(common_pre + '.ip_route_raw')
self.iptables_raw_mock = self.patch(common_pre + '.iptables_raw')
self.ip_ns_list_mock = self.patch(common_pre + '.ip_ns_list')
self.ip_ns_addr_mock = self.patch(common_pre + '.ip_ns_addr')
self.ip_ns_route_mock = self.patch(common_pre + '.ip_ns_route')
self.iptables_ns_mock = self.patch(common_pre + '.iptables_ns')
self.ovs_db_dump_mock = self.patch(common_pre + '.ovs_db_dump')
self.log_mock = self.patch('tempest.common.debug.LOG')
def test_log_ip_ns_debug_disabled(self):
self.useFixture(mockpatch.PatchObject(test.CONF.debug,
'enable', False))
debug.log_ip_ns()
self.assertFalse(self.ip_addr_raw_mock.called)
self.assertFalse(self.log_mock.info.called)
def test_log_ip_ns_debug_enabled(self):
self.useFixture(mockpatch.PatchObject(test.CONF.debug,
'enable', True))
tables = ['filter', 'nat', 'mangle']
self.ip_ns_list_mock.return_value = [1, 2]
debug.log_ip_ns()
self.ip_addr_raw_mock.assert_called_with()
self.assertTrue(self.log_mock.info.called)
self.ip_route_raw_mock.assert_called_with()
self.assertEqual(len(tables), self.iptables_raw_mock.call_count)
for table in tables:
self.assertIn(mock.call(table),
self.iptables_raw_mock.call_args_list)
self.ip_ns_list_mock.assert_called_with()
self.assertEqual(len(self.ip_ns_list_mock.return_value),
self.ip_ns_addr_mock.call_count)
self.assertEqual(len(self.ip_ns_list_mock.return_value),
self.ip_ns_route_mock.call_count)
for ns in self.ip_ns_list_mock.return_value:
self.assertIn(mock.call(ns),
self.ip_ns_addr_mock.call_args_list)
self.assertIn(mock.call(ns),
self.ip_ns_route_mock.call_args_list)
self.assertEqual(len(tables) * len(self.ip_ns_list_mock.return_value),
self.iptables_ns_mock.call_count)
for ns in self.ip_ns_list_mock.return_value:
for table in tables:
self.assertIn(mock.call(ns, table),
self.iptables_ns_mock.call_args_list)
def test_log_ovs_db_debug_disabled(self):
self.useFixture(mockpatch.PatchObject(test.CONF.debug,
'enable', False))
self.useFixture(mockpatch.PatchObject(test.CONF.service_available,
'neutron', False))
debug.log_ovs_db()
self.assertFalse(self.ovs_db_dump_mock.called)
self.useFixture(mockpatch.PatchObject(test.CONF.debug,
'enable', True))
self.useFixture(mockpatch.PatchObject(test.CONF.service_available,
'neutron', False))
debug.log_ovs_db()
self.assertFalse(self.ovs_db_dump_mock.called)
self.useFixture(mockpatch.PatchObject(test.CONF.debug,
'enable', False))
self.useFixture(mockpatch.PatchObject(test.CONF.service_available,
'neutron', True))
debug.log_ovs_db()
self.assertFalse(self.ovs_db_dump_mock.called)
def test_log_ovs_db_debug_enabled(self):
self.useFixture(mockpatch.PatchObject(test.CONF.debug,
'enable', True))
self.useFixture(mockpatch.PatchObject(test.CONF.service_available,
'neutron', True))
debug.log_ovs_db()
self.ovs_db_dump_mock.assert_called_with()
def test_log_net_debug(self):
self.log_ip_ns_mock = self.patch('tempest.common.debug.log_ip_ns')
self.log_ovs_db_mock = self.patch('tempest.common.debug.log_ovs_db')
debug.log_net_debug()
self.log_ip_ns_mock.assert_called_with()
self.log_ovs_db_mock.assert_called_with()