Merge pull request #10729 from mchlumsky/plugins_cache_abc
Use abc for BaseCacheModule
This commit is contained in:
commit
055d14449b
3 changed files with 105 additions and 9 deletions
30
v2/ansible/plugins/cache/base.py
vendored
30
v2/ansible/plugins/cache/base.py
vendored
|
@ -14,30 +14,42 @@
|
|||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
from __future__ import (absolute_import, division, print_function)
|
||||
__metaclass__ = type
|
||||
|
||||
import exceptions
|
||||
from abc import ABCMeta, abstractmethod
|
||||
|
||||
class BaseCacheModule(object):
|
||||
from six import add_metaclass
|
||||
|
||||
|
||||
@add_metaclass(ABCMeta)
|
||||
class BaseCacheModule:
|
||||
|
||||
@abstractmethod
|
||||
def get(self, key):
|
||||
raise exceptions.NotImplementedError
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
def set(self, key, value):
|
||||
raise exceptions.NotImplementedError
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
def keys(self):
|
||||
raise exceptions.NotImplementedError
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
def contains(self, key):
|
||||
raise exceptions.NotImplementedError
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
def delete(self, key):
|
||||
raise exceptions.NotImplementedError
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
def flush(self):
|
||||
raise exceptions.NotImplementedError
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
def copy(self):
|
||||
raise exceptions.NotImplementedError
|
||||
pass
|
||||
|
|
|
@ -5,6 +5,8 @@ jinja2
|
|||
httplib2
|
||||
passlib
|
||||
six
|
||||
python-memcached
|
||||
redis
|
||||
|
||||
# Test requirements
|
||||
unittest2
|
||||
|
|
82
v2/test/plugins/test_cache.py
Normal file
82
v2/test/plugins/test_cache.py
Normal file
|
@ -0,0 +1,82 @@
|
|||
# (c) 2012-2015, Michael DeHaan <michael.dehaan@gmail.com>
|
||||
#
|
||||
# This file is part of Ansible
|
||||
#
|
||||
# Ansible is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation, either version 3 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# Ansible is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
# Make coding more python3-ish
|
||||
from __future__ import (absolute_import, division, print_function)
|
||||
__metaclass__ = type
|
||||
|
||||
from ansible.compat.tests import unittest
|
||||
from ansible.plugins.cache.base import BaseCacheModule
|
||||
from ansible.plugins.cache.memcached import CacheModule as MemcachedCache
|
||||
from ansible.plugins.cache.memory import CacheModule as MemoryCache
|
||||
from ansible.plugins.cache.redis import CacheModule as RedisCache
|
||||
|
||||
|
||||
class TestAbstractClass(unittest.TestCase):
|
||||
|
||||
def setUp(self):
|
||||
pass
|
||||
|
||||
def tearDown(self):
|
||||
pass
|
||||
|
||||
def test_subclass_error(self):
|
||||
class CacheModule1(BaseCacheModule):
|
||||
pass
|
||||
with self.assertRaises(TypeError):
|
||||
CacheModule1()
|
||||
|
||||
class CacheModule2(BaseCacheModule):
|
||||
def get(self, key):
|
||||
super(CacheModule2, self).get(key)
|
||||
|
||||
with self.assertRaises(TypeError):
|
||||
CacheModule2()
|
||||
|
||||
def test_subclass_success(self):
|
||||
class CacheModule3(BaseCacheModule):
|
||||
def get(self, key):
|
||||
super(CacheModule3, self).get(key)
|
||||
|
||||
def set(self, key, value):
|
||||
super(CacheModule3, self).set(key, value)
|
||||
|
||||
def keys(self):
|
||||
super(CacheModule3, self).keys()
|
||||
|
||||
def contains(self, key):
|
||||
super(CacheModule3, self).contains(key)
|
||||
|
||||
def delete(self, key):
|
||||
super(CacheModule3, self).delete(key)
|
||||
|
||||
def flush(self):
|
||||
super(CacheModule3, self).flush()
|
||||
|
||||
def copy(self):
|
||||
super(CacheModule3, self).copy()
|
||||
|
||||
self.assertIsInstance(CacheModule3(), CacheModule3)
|
||||
|
||||
def test_memcached_cachemodule(self):
|
||||
self.assertIsInstance(MemcachedCache(), MemcachedCache)
|
||||
|
||||
def test_memory_cachemodule(self):
|
||||
self.assertIsInstance(MemoryCache(), MemoryCache)
|
||||
|
||||
def test_redis_cachemodule(self):
|
||||
self.assertIsInstance(RedisCache(), RedisCache)
|
Loading…
Reference in a new issue