139 lines
5.3 KiB
Python
139 lines
5.3 KiB
Python
# Copyright (c) 2015 OpenStack Foundation.
|
|
# 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 dragonflow.common import exceptions
|
|
from dragonflow.db.drivers import redis_db_driver
|
|
from dragonflow.tests import base as tests_base
|
|
|
|
|
|
class TestRedisDB(tests_base.BaseTestCase):
|
|
|
|
def setUp(self):
|
|
super(TestRedisDB, self).setUp()
|
|
self.RedisDbDriver = redis_db_driver.RedisDbDriver()
|
|
|
|
def test_set_key(self):
|
|
client = mock.Mock()
|
|
self.RedisDbDriver._get_client = mock.Mock(return_value=client)
|
|
client.execute_command.return_value = 1
|
|
redis_mgt = mock.Mock()
|
|
redis_mgt.get_ip_by_key.return_value = '0.0.0.0:1000'
|
|
self.RedisDbDriver.redis_mgt = redis_mgt
|
|
result = self.RedisDbDriver.set_key('table', 'key', 'value', 'topic')
|
|
self.assertEqual(1, result)
|
|
|
|
client.execute_command.return_value = None
|
|
result = self.RedisDbDriver.set_key('table', 'key', 'value', 'topic')
|
|
self.assertEqual(0, result)
|
|
|
|
def test_get_method(self):
|
|
client = mock.Mock()
|
|
self.RedisDbDriver._get_client = mock.Mock(return_value=client)
|
|
self.RedisDbDriver._sync_master_list = mock.Mock()
|
|
self.RedisDbDriver.clients[0] = client
|
|
client.keys.return_value = ['a']
|
|
client.mget.return_value = ['value']
|
|
client.execute_command.return_value = 'value'
|
|
redis_mgt = mock.Mock()
|
|
self.RedisDbDriver.redis_mgt = redis_mgt
|
|
redis_mgt.get_ip_by_key.return_value = '0.0.0.0:1000'
|
|
|
|
# test get_key
|
|
result = self.RedisDbDriver.get_key('table', 'key')
|
|
self.assertEqual('value', result)
|
|
redis_mgt.get_ip_by_key.assert_called_with('a')
|
|
|
|
result = self.RedisDbDriver.get_key('table', 'key', '')
|
|
self.assertEqual('value', result)
|
|
redis_mgt.get_ip_by_key.assert_called_with('a')
|
|
|
|
result = self.RedisDbDriver.get_key('table', 'key', 'topic')
|
|
self.assertEqual('value', result)
|
|
local_key = '{table.topic}.key'
|
|
redis_mgt.get_ip_by_key.assert_called_with(local_key)
|
|
|
|
with mock.patch(
|
|
'dragonflow.db.drivers.redis_db_driver.RedisDbDriver._execute_cmd',
|
|
return_value=None,
|
|
):
|
|
self.assertRaises(
|
|
exceptions.DBKeyNotFound,
|
|
self.RedisDbDriver.get_key,
|
|
'table', 'key', 'topic',
|
|
)
|
|
|
|
with mock.patch(
|
|
'dragonflow.db.drivers.redis_db_driver.RedisDbDriver._execute_cmd',
|
|
side_effect=RuntimeError,
|
|
):
|
|
self.assertRaises(
|
|
exceptions.DBKeyNotFound,
|
|
self.RedisDbDriver.get_key,
|
|
'table', 'key', 'topic',
|
|
)
|
|
|
|
# test get_all_entries
|
|
result = self.RedisDbDriver.get_all_entries('table')
|
|
self.assertEqual(['value'], result)
|
|
redis_mgt.get_ip_by_key.assert_called_with('a')
|
|
|
|
result = self.RedisDbDriver.get_all_entries('table', '')
|
|
self.assertEqual(['value'], result)
|
|
redis_mgt.get_ip_by_key.assert_called_with('a')
|
|
|
|
result = self.RedisDbDriver.get_all_entries('table', 'topic')
|
|
self.assertEqual(['value'], result)
|
|
local_key = '{table.topic}.*'
|
|
redis_mgt.get_ip_by_key.assert_called_with(local_key)
|
|
|
|
# test get_all_key
|
|
client.keys.return_value = ['{table.*}.key']
|
|
result = self.RedisDbDriver.get_all_keys('table')
|
|
self.assertEqual(['key'], result)
|
|
local_key = '{table.*}.*'
|
|
client.keys.assert_called_with(local_key)
|
|
|
|
result = self.RedisDbDriver.get_all_keys('table', '')
|
|
self.assertEqual(['key'], result)
|
|
client.keys.assert_called_with(local_key)
|
|
|
|
result = self.RedisDbDriver.get_all_keys('table', 'topic')
|
|
self.assertEqual(['key'], result)
|
|
local_key = '{table.topic}.*'
|
|
redis_mgt.get_ip_by_key.assert_called_with(local_key)
|
|
|
|
def test_delete_key(self):
|
|
client = mock.Mock()
|
|
self.RedisDbDriver._get_client = mock.Mock(return_value=client)
|
|
client.execute_command.return_value = 1
|
|
redis_mgt = mock.Mock()
|
|
self.RedisDbDriver.redis_mgt = redis_mgt
|
|
redis_mgt.get_ip_by_key.return_value = '0.0.0.0:1000'
|
|
result = self.RedisDbDriver.delete_key('table', 'key', 'topic')
|
|
self.assertEqual(1, result)
|
|
|
|
client.execute_command.return_value = None
|
|
result = self.RedisDbDriver.delete_key('table', 'key', 'topic')
|
|
self.assertEqual(0, result)
|
|
|
|
def test_allocate_unique_key(self):
|
|
client = mock.Mock()
|
|
self.RedisDbDriver._update_client = mock.Mock(return_value=client)
|
|
client.incr.return_value = 1
|
|
result = self.RedisDbDriver.allocate_unique_key('fake_table')
|
|
self.assertEqual(1, result)
|