summaryrefslogtreecommitdiff
path: root/tests/21_test_command_wrappers.py
diff options
context:
space:
mode:
Diffstat (limited to 'tests/21_test_command_wrappers.py')
-rw-r--r--tests/21_test_command_wrappers.py70
1 files changed, 70 insertions, 0 deletions
diff --git a/tests/21_test_command_wrappers.py b/tests/21_test_command_wrappers.py
new file mode 100644
index 0000000..4dfbb48
--- /dev/null
+++ b/tests/21_test_command_wrappers.py
@@ -0,0 +1,70 @@
+# vim: set fileencoding=utf-8 :
+"""Test L{gbp.command_wrappers.Command}'s tarball unpack"""
+
+import unittest
+import mock
+import functools
+
+from gbp.command_wrappers import Command, CommandExecFailed
+from . testutils import GbpLogTester
+
+
+def patch_popen(stdout='', stderr='', returncode=1):
+ """Decorator to easily set the return value of popen.communicate()"""
+ def patch_popen_decorator(func):
+ @functools.wraps(func)
+ def wrap(self):
+ with mock.patch('subprocess.Popen') as create_mock:
+ popen_mock = mock.Mock(**{'returncode': returncode,
+ 'communicate.return_value': (stdout, stderr)})
+ create_mock.return_value = popen_mock
+ return func(self, create_mock)
+ return wrap
+ return patch_popen_decorator
+
+
+class TestCommandWrapperFailures(unittest.TestCase, GbpLogTester):
+ def setUp(self):
+ self.false = Command('/does/not/matter')
+ self.log_tester = GbpLogTester()
+ self.log_tester._capture_log(True)
+
+ def tearDown(self):
+ self.log_tester._capture_log(False)
+
+ @patch_popen(stdout='', stderr='', returncode=1)
+ def test_log_default_error_msg(self, create_mock):
+ with self.assertRaises(CommandExecFailed):
+ self.false.__call__()
+ self.log_tester._check_log(0, "gbp:error: '/does/not/matter' failed: it exited with 1")
+ self.assertEqual(self.false.retcode, 1)
+ self.assertEqual(self.false.stderr, '')
+ self.assertEqual(self.false.stdout, '')
+
+ @patch_popen(stdout='', stderr='we have a problem', returncode=1)
+ def test_log_use_stderr_for_err_message(self, create_mock):
+ self.false.capture_stderr = True
+ self.false.run_error = "Erpel {stderr}"
+ with self.assertRaises(CommandExecFailed):
+ self.false.__call__()
+ self.log_tester._check_log(0, "gbp:error: Erpel we have a problem")
+ self.assertEqual(self.false.retcode, 1)
+ self.assertEqual(self.false.stderr, 'we have a problem')
+ self.assertEqual(self.false.stdout, '')
+
+ @patch_popen(stdout='we have a problem', stderr='', returncode=1)
+ def test_log_use_stdout_for_err_message(self, create_mock):
+ self.false.capture_stdout = True
+ self.false.run_error = "Erpel {stdout}"
+ with self.assertRaises(CommandExecFailed):
+ self.false.__call__()
+ self.log_tester._check_log(0, "gbp:error: Erpel we have a problem")
+ self.assertEqual(self.false.retcode, 1)
+ self.assertEqual(self.false.stderr, '')
+ self.assertEqual(self.false.stdout, 'we have a problem')
+
+ @patch_popen(returncode=0)
+ def test_no_log_on_success(self, create_mock):
+ self.false.__call__()
+ self.log_tester._check_log_empty()
+ self.assertEqual(self.false.retcode, 0)