2
from nova import datastore
5
class KeeperTestCase(test.BaseTestCase):
7
Basic persistence tests for Keeper datastore.
8
Generalize, then use these to support
9
migration to redis / cassandra / multiple stores.
12
def __init__(self, *args, **kwargs):
14
Create a new keeper instance for test keys.
16
super(KeeperTestCase, self).__init__(*args, **kwargs)
17
self.keeper = datastore.Keeper('test-')
21
Scrub out test keeper data.
25
def test_store_strings(self):
27
Confirm that simple strings go in and come out safely.
28
Should also test unicode strings.
30
randomstring = ''.join(
31
[random.choice('ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890-')
34
self.keeper['test_string'] = randomstring
35
self.assertEqual(randomstring, self.keeper['test_string'])
37
def test_store_dicts(self):
39
Arbitrary dictionaries should be storable.
41
test_dict = {'key_one': 'value_one'}
42
self.keeper['test_dict'] = test_dict
43
self.assertEqual(test_dict['key_one'],
44
self.keeper['test_dict']['key_one'])
48
A keeper dict should be self-serializing.
50
self.keeper.set_add('test_set', 'foo')
51
test_dict = {'arbitrary': 'dict of stuff'}
52
self.keeper.set_add('test_set', test_dict)
53
self.assertTrue(self.keeper.set_is_member('test_set', 'foo'))
54
self.assertFalse(self.keeper.set_is_member('test_set', 'bar'))
55
self.keeper.set_remove('test_set', 'foo')
56
self.assertFalse(self.keeper.set_is_member('test_set', 'foo'))
57
rv = self.keeper.set_fetch('test_set')
58
self.assertEqual(test_dict, rv.next())
59
self.keeper.set_remove('test_set', test_dict)