summaryrefslogtreecommitdiff
path: root/taskflow/tests/unit/persistence
diff options
context:
space:
mode:
authorJoshua Harlow <harlowja@yahoo-inc.com>2015-03-23 17:00:07 -0700
committerJoshua Harlow <harlowja@yahoo-inc.com>2015-03-25 23:00:34 +0000
commit5accccbb7c8fc7f4ff2577bffa83fea27d495aea (patch)
tree7894d97a61ac6751fc62de66c3193d2b4fa42a77 /taskflow/tests/unit/persistence
parentc85805fca1df9b796e8e4fd0e3b7b9248be7267a (diff)
downloadtaskflow-5accccbb7c8fc7f4ff2577bffa83fea27d495aea.tar.gz
Add a set of tests to the in memory fake filesystem
To ensure this continues to work as expected add some basic functional tests that ensure the existing operations work (and continue to work). Change-Id: I2903bf29a77936d850d667d1fbff179a14a57adb
Diffstat (limited to 'taskflow/tests/unit/persistence')
-rw-r--r--taskflow/tests/unit/persistence/test_memory_persistence.py62
1 files changed, 62 insertions, 0 deletions
diff --git a/taskflow/tests/unit/persistence/test_memory_persistence.py b/taskflow/tests/unit/persistence/test_memory_persistence.py
index 725b745..1c9f451 100644
--- a/taskflow/tests/unit/persistence/test_memory_persistence.py
+++ b/taskflow/tests/unit/persistence/test_memory_persistence.py
@@ -16,6 +16,7 @@
import contextlib
+from taskflow import exceptions as exc
from taskflow.persistence import backends
from taskflow.persistence.backends import impl_memory
from taskflow import test
@@ -45,3 +46,64 @@ class MemoryPersistenceTest(test.TestCase, base.PersistenceTestMixin):
conf = {'connection': 'memory'} # note no colon
with contextlib.closing(backends.fetch(conf)) as be:
self.assertIsInstance(be, impl_memory.MemoryBackend)
+
+
+class MemoryFilesystemTest(test.TestCase):
+
+ @staticmethod
+ def _get_item_path(fs, path):
+ # TODO(harlowja): is there a better way to do this??
+ return fs[path]
+
+ @staticmethod
+ def _del_item_path(fs, path):
+ # TODO(harlowja): is there a better way to do this??
+ del fs[path]
+
+ def test_set_get_ls(self):
+ fs = impl_memory.FakeFilesystem()
+ fs['/d'] = 'd'
+ fs['/c'] = 'c'
+ fs['/d/b'] = 'db'
+ self.assertEqual(2, len(fs.ls('/')))
+ self.assertEqual(1, len(fs.ls('/d')))
+ self.assertEqual('d', fs['/d'])
+ self.assertEqual('c', fs['/c'])
+ self.assertEqual('db', fs['/d/b'])
+
+ def test_ensure_path(self):
+ fs = impl_memory.FakeFilesystem()
+ pieces = ['a', 'b', 'c']
+ path = "/" + "/".join(pieces)
+ fs.ensure_path(path)
+ path = fs.root_path
+ for i, p in enumerate(pieces):
+ if i == 0:
+ path += p
+ else:
+ path += "/" + p
+ self.assertIsNone(fs[path])
+
+ def test_not_found(self):
+ fs = impl_memory.FakeFilesystem()
+ self.assertRaises(exc.NotFound, self._get_item_path, fs, '/c')
+
+ def test_del_root_not_allowed(self):
+ fs = impl_memory.FakeFilesystem()
+ self.assertRaises(ValueError, self._del_item_path, fs, '/')
+
+ def test_link_loop_raises(self):
+ fs = impl_memory.FakeFilesystem()
+ fs['/b'] = 'c'
+ fs.symlink('/b', '/b')
+ self.assertRaises(ValueError, self._get_item_path, fs, '/b')
+
+ def test_ensure_linked_delete(self):
+ fs = impl_memory.FakeFilesystem()
+ fs['/b'] = 'd'
+ fs.symlink('/b', '/c')
+ self.assertEqual('d', fs['/b'])
+ self.assertEqual('d', fs['/c'])
+ del fs['/b']
+ self.assertRaises(exc.NotFound, self._get_item_path, fs, '/c')
+ self.assertRaises(exc.NotFound, self._get_item_path, fs, '/b')