summaryrefslogtreecommitdiffstats
path: root/testsuite/Testsrc/Testlib/TestServer/TestPlugins/TestCfg/TestCfgExternalCommandVerifier.py
diff options
context:
space:
mode:
authorChris St. Pierre <chris.a.st.pierre@gmail.com>2012-10-02 15:00:03 -0400
committerChris St. Pierre <chris.a.st.pierre@gmail.com>2012-10-02 15:00:03 -0400
commitadf037aa31031be164e68b1a4817a7cada936c90 (patch)
treee4913b33fbed2bb480a2090b419a7fb3fddc67a7 /testsuite/Testsrc/Testlib/TestServer/TestPlugins/TestCfg/TestCfgExternalCommandVerifier.py
parent414f1c017f5a1e0f0549bcb27175983b04e3312c (diff)
downloadbcfg2-adf037aa31031be164e68b1a4817a7cada936c90.tar.gz
bcfg2-adf037aa31031be164e68b1a4817a7cada936c90.tar.bz2
bcfg2-adf037aa31031be164e68b1a4817a7cada936c90.zip
testsuite: added unit tests for Cfg handlers
Diffstat (limited to 'testsuite/Testsrc/Testlib/TestServer/TestPlugins/TestCfg/TestCfgExternalCommandVerifier.py')
-rw-r--r--testsuite/Testsrc/Testlib/TestServer/TestPlugins/TestCfg/TestCfgExternalCommandVerifier.py89
1 files changed, 89 insertions, 0 deletions
diff --git a/testsuite/Testsrc/Testlib/TestServer/TestPlugins/TestCfg/TestCfgExternalCommandVerifier.py b/testsuite/Testsrc/Testlib/TestServer/TestPlugins/TestCfg/TestCfgExternalCommandVerifier.py
new file mode 100644
index 000000000..fde7ed722
--- /dev/null
+++ b/testsuite/Testsrc/Testlib/TestServer/TestPlugins/TestCfg/TestCfgExternalCommandVerifier.py
@@ -0,0 +1,89 @@
+import os
+import sys
+import lxml.etree
+from mock import Mock, MagicMock, patch
+from Bcfg2.Server.Plugins.Cfg.CfgExternalCommandVerifier import *
+from Bcfg2.Server.Plugin import PluginExecutionError
+
+# add all parent testsuite directories to sys.path to allow (most)
+# relative imports in python 2.4
+path = os.path.dirname(__file__)
+while path != "/":
+ if os.path.basename(path).lower().startswith("test"):
+ sys.path.append(path)
+ if os.path.basename(path) == "testsuite":
+ break
+ path = os.path.dirname(path)
+from common import XI_NAMESPACE, XI, inPy3k, call, builtins, u, can_skip, \
+ skip, skipIf, skipUnless, Bcfg2TestCase, DBModelTestCase, syncdb, \
+ patchIf, datastore, re_type
+from TestServer.TestPlugins.TestCfg.Test_init import TestCfgVerifier
+
+
+class TestCfgExternalCommandVerifier(TestCfgVerifier):
+ test_obj = CfgExternalCommandVerifier
+
+ @patch("Bcfg2.Server.Plugins.Cfg.CfgExternalCommandVerifier.Popen")
+ def test_verify_entry(self, mock_Popen):
+ proc = Mock()
+ mock_Popen.return_value = proc
+ proc.wait.return_value = 0
+ proc.communicate.return_value = MagicMock()
+ entry = lxml.etree.Element("Path", name="/test.txt")
+ metadata = Mock()
+
+ ecv = self.get_obj()
+ ecv.cmd = ["/bin/bash", "-x", "foo"]
+ ecv.verify_entry(entry, metadata, "data")
+ self.assertEqual(mock_Popen.call_args[0], (ecv.cmd,))
+ proc.communicate.assert_called_with(input="data")
+ proc.wait.assert_called_with()
+
+ mock_Popen.reset_mock()
+ proc.wait.return_value = 13
+ self.assertRaises(CfgVerificationError,
+ ecv.verify_entry, entry, metadata, "data")
+ self.assertEqual(mock_Popen.call_args[0], (ecv.cmd,))
+ proc.communicate.assert_called_with(input="data")
+ proc.wait.assert_called_with()
+
+ mock_Popen.reset_mock()
+ mock_Popen.side_effect = OSError
+ self.assertRaises(CfgVerificationError,
+ ecv.verify_entry, entry, metadata, "data")
+ self.assertEqual(mock_Popen.call_args[0], (ecv.cmd,))
+
+ @patch("os.access")
+ def test_handle_event(self, mock_access):
+ @patch("Bcfg2.Server.Plugins.Cfg.CfgVerifier.handle_event")
+ def inner(mock_handle_event):
+ ecv = self.get_obj()
+ event = Mock()
+ mock_access.return_value = False
+ ecv.data = "data"
+ self.assertRaises(PluginExecutionError,
+ ecv.handle_event, event)
+ mock_handle_event.assert_called_with(ecv, event)
+ mock_access.assert_called_with(ecv.name, os.X_OK)
+ self.assertItemsEqual(ecv.cmd, [])
+
+ mock_access.reset_mock()
+ mock_handle_event.reset_mock()
+ ecv.data = "#! /bin/bash -x\ntrue"
+ ecv.handle_event(event)
+ mock_handle_event.assert_called_with(ecv, event)
+ mock_access.assert_called_with(ecv.name, os.X_OK)
+ self.assertEqual(ecv.cmd, ["/bin/bash", "-x", ecv.name])
+
+ mock_access.reset_mock()
+ mock_handle_event.reset_mock()
+ mock_access.return_value = True
+ ecv.data = "true"
+ ecv.handle_event(event)
+ mock_handle_event.assert_called_with(ecv, event)
+ mock_access.assert_called_with(ecv.name, os.X_OK)
+ self.assertItemsEqual(ecv.cmd, [ecv.name])
+
+ inner()
+ mock_access.return_value = True
+ TestCfgVerifier.test_handle_event(self)