summaryrefslogtreecommitdiff
path: root/src/mailman/model/tests/test_workflow.py
diff options
context:
space:
mode:
authorBarry Warsaw2015-03-29 17:14:09 -0400
committerBarry Warsaw2015-03-29 17:14:09 -0400
commit9de0ea02dc757e41a5013bb41e68d04f44ed5066 (patch)
tree9ffe836a512f11423eb7e91ce3ee1e01d7ed188d /src/mailman/model/tests/test_workflow.py
parent2c49b7535bf9989b3e0aeb0ae209d9f0a6a9be9e (diff)
downloadmailman-9de0ea02dc757e41a5013bb41e68d04f44ed5066.tar.gz
mailman-9de0ea02dc757e41a5013bb41e68d04f44ed5066.tar.zst
mailman-9de0ea02dc757e41a5013bb41e68d04f44ed5066.zip
Diffstat (limited to 'src/mailman/model/tests/test_workflow.py')
-rw-r--r--src/mailman/model/tests/test_workflow.py110
1 files changed, 110 insertions, 0 deletions
diff --git a/src/mailman/model/tests/test_workflow.py b/src/mailman/model/tests/test_workflow.py
new file mode 100644
index 000000000..b5e915df4
--- /dev/null
+++ b/src/mailman/model/tests/test_workflow.py
@@ -0,0 +1,110 @@
+# Copyright (C) 2015 by the Free Software Foundation, Inc.
+#
+# This file is part of GNU Mailman.
+#
+# GNU Mailman 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.
+#
+# GNU Mailman 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
+# GNU Mailman. If not, see <http://www.gnu.org/licenses/>.
+
+"""Test the workflow model."""
+
+__all__ = [
+ 'TestWorkflow',
+ ]
+
+
+import unittest
+
+from mailman.interfaces.workflow import IWorkflowStateManager
+from mailman.testing.layers import ConfigLayer
+from zope.component import getUtility
+
+
+
+class TestWorkflow(unittest.TestCase):
+ layer = ConfigLayer
+
+ def setUp(self):
+ self._manager = getUtility(IWorkflowStateManager)
+
+ def test_save_restore_workflow(self):
+ # Save and restore a workflow.
+ name = 'ant'
+ key = 'bee'
+ step = 'cat'
+ data = 'dog'
+ self._manager.save(name, key, step, data)
+ workflow = self._manager.restore(name, key)
+ self.assertEqual(workflow.name, name)
+ self.assertEqual(workflow.key, key)
+ self.assertEqual(workflow.step, step)
+ self.assertEqual(workflow.data, data)
+
+ def test_save_restore_workflow_without_step(self):
+ # Save and restore a workflow that contains no step.
+ name = 'ant'
+ key = 'bee'
+ data = 'dog'
+ self._manager.save(name, key, data=data)
+ workflow = self._manager.restore(name, key)
+ self.assertEqual(workflow.name, name)
+ self.assertEqual(workflow.key, key)
+ self.assertIsNone(workflow.step)
+ self.assertEqual(workflow.data, data)
+
+ def test_save_restore_workflow_without_data(self):
+ # Save and restore a workflow that contains no data.
+ name = 'ant'
+ key = 'bee'
+ step = 'cat'
+ self._manager.save(name, key, step)
+ workflow = self._manager.restore(name, key)
+ self.assertEqual(workflow.name, name)
+ self.assertEqual(workflow.key, key)
+ self.assertEqual(workflow.step, step)
+ self.assertIsNone(workflow.data)
+
+ def test_save_restore_workflow_without_step_or_data(self):
+ # Save and restore a workflow that contains no step or data.
+ name = 'ant'
+ key = 'bee'
+ self._manager.save(name, key)
+ workflow = self._manager.restore(name, key)
+ self.assertEqual(workflow.name, name)
+ self.assertEqual(workflow.key, key)
+ self.assertIsNone(workflow.step)
+ self.assertIsNone(workflow.data)
+
+ def test_restore_workflow_with_no_matching_name(self):
+ # Try to restore a workflow that has no matching name in the database.
+ name = 'ant'
+ key = 'bee'
+ self._manager.save(name, key)
+ workflow = self._manager.restore('ewe', key)
+ self.assertIsNone(workflow)
+
+ def test_restore_workflow_with_no_matching_key(self):
+ # Try to restore a workflow that has no matching key in the database.
+ name = 'ant'
+ key = 'bee'
+ self._manager.save(name, key)
+ workflow = self._manager.restore(name, 'fly')
+ self.assertIsNone(workflow)
+
+ def test_restore_workflow_with_no_matching_key_or_name(self):
+ # Try to restore a workflow that has no matching key or name in the
+ # database.
+ name = 'ant'
+ key = 'bee'
+ self._manager.save(name, key)
+ workflow = self._manager.restore('ewe', 'fly')
+ self.assertIsNone(workflow)