heat/heat/tests/db/test_sqlalchemy_filters.py

44 lines
1.6 KiB
Python

#
# 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 heat.db.sqlalchemy import filters as db_filters
from heat.tests import common
class ExactFilterTest(common.HeatTestCase):
def setUp(self):
super(ExactFilterTest, self).setUp()
self.query = mock.Mock()
self.model = mock.Mock()
def test_returns_same_query_for_empty_filters(self):
filters = {}
db_filters.exact_filter(self.query, self.model, filters)
self.assertEqual(0, self.query.call_count)
def test_add_exact_match_clause_for_single_values(self):
filters = {'cat': 'foo'}
db_filters.exact_filter(self.query, self.model, filters)
self.query.filter_by.assert_called_once_with(cat='foo')
def test_adds_an_in_clause_for_multiple_values(self):
self.model.cat.in_.return_value = 'fake in clause'
filters = {'cat': ['foo', 'quux']}
db_filters.exact_filter(self.query, self.model, filters)
self.query.filter.assert_called_once_with('fake in clause')
self.model.cat.in_.assert_called_once_with(['foo', 'quux'])