deb-manila/manila/tests/db/test_api.py
Akshai Parthasarathy 0ac5604159 Fix db shim layer mismatches with implementation
The module manila/db/api.py is a pass-through shim
layer intended to provide an interface between the
implementation and the actual database queries implemented
elsewhere. However, many interface methods in this
module were not in sync with the actual implementation.

Remove unused interfaces and create a unit test to avoid
mismatches in the future.

Co-Authored-By: Goutham Pacha Ravi <gouthamr@netapp.com>

Change-Id: I275f028bf6f6afe10eb71fa005d3caefbc5673d2
Closes-Bug: #1516160
2016-01-22 15:05:09 -05:00

55 lines
2.1 KiB
Python

# Copyright (c) Goutham Pacha Ravi.
# 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.
"""Unit Tests for the interface methods in the manila/db/api.py."""
import re
from manila.db import api as db_interface
from manila.db.sqlalchemy import api as db_api
from manila import test
class DBInterfaceTestCase(test.TestCase):
"""Test cases for the DB Interface methods."""
def setUp(self):
super(self.__class__, self).setUp()
def test_interface_methods(self):
"""Ensure that implementation methods match interfaces.
manila/db/api module is merely shim layer between the database
implementation and the other methods using these implementations.
Bugs are introduced when the shims go out of sync with the actual
implementation. So this test ensures that method names and
signatures match between the interface and the implementation.
"""
members = dir(db_interface)
# Ignore private methods for the file and any other members that
# need not match.
ignore_members = re.compile(r'^_|CONF|IMPL')
interfaces = [i for i in members if not ignore_members.match(i)]
for interface in interfaces:
method = getattr(db_interface, interface)
if callable(method):
mock_method_call = self.mock_object(db_api, interface)
# kwargs always specify defaults, ignore them in the signature.
args = filter(
lambda x: x != 'kwargs', method.__code__.co_varnames)
method(*args)
self.assertTrue(mock_method_call.called)