From 530a28a9b10b1df1233276ba851b9255745fad9b Mon Sep 17 00:00:00 2001 From: armando-migliaccio Date: Wed, 24 Jul 2013 17:35:28 -0700 Subject: [PATCH] Deal with intermittent OverflowError in gate-neutron-python26 This occurence looks like is related to a failure in utils.execute. This patch attempts to deal with the error by mocking out Popen.communicate altogether. Fixes bug #1202065 Change-Id: I4092efb17939b69dd2d1965aaf619a9b2be03ef4 --- neutron/tests/unit/test_agent_linux_utils.py | 34 ++++++++++++++------ 1 file changed, 25 insertions(+), 9 deletions(-) diff --git a/neutron/tests/unit/test_agent_linux_utils.py b/neutron/tests/unit/test_agent_linux_utils.py index 8f0f76cca7..842c8a25f0 100644 --- a/neutron/tests/unit/test_agent_linux_utils.py +++ b/neutron/tests/unit/test_agent_linux_utils.py @@ -29,38 +29,54 @@ class AgentUtilsExecuteTest(base.BaseTestCase): self.test_file = self.useFixture( fixtures.TempDir()).join("test_execute.tmp") open(self.test_file, 'w').close() + instance = mock.patch("subprocess.Popen.communicate") + self.mock_popen = instance.start() + self.addCleanup(self.mock_popen.stop) def test_without_helper(self): + expected = "%s\n" % self.test_file + self.mock_popen.return_value = [expected, ""] result = utils.execute(["ls", self.test_file]) - self.assertEqual(result, "%s\n" % self.test_file) + self.assertEqual(result, expected) def test_with_helper(self): + expected = "ls %s\n" % self.test_file + self.mock_popen.return_value = [expected, ""] result = utils.execute(["ls", self.test_file], self.root_helper) - self.assertEqual(result, "ls %s\n" % self.test_file) + self.assertEqual(result, expected) - def test_stderr(self): - stdout, stderr = utils.execute(["ls", self.test_file], - return_stderr=True) - self.assertEqual(stdout, "%s\n" % self.test_file) - self.assertEqual(stderr, "") + def test_stderr_true(self): + expected = "%s\n" % self.test_file + self.mock_popen.return_value = [expected, ""] + out = utils.execute(["ls", self.test_file], return_stderr=True) + self.assertIsInstance(out, tuple) + self.assertEqual(out, (expected, "")) def test_check_exit_code(self): + self.mock_popen.return_value = ["", ""] stdout = utils.execute(["ls", self.test_file[:-1]], check_exit_code=False) self.assertEqual(stdout, "") + + def test_execute_raises(self): + self.mock_popen.side_effect = RuntimeError self.assertRaises(RuntimeError, utils.execute, ["ls", self.test_file[:-1]]) def test_process_input(self): + expected = "%s\n" % self.test_file[:-1] + self.mock_popen.return_value = [expected, ""] result = utils.execute(["cat"], process_input="%s\n" % self.test_file[:-1]) - self.assertEqual(result, "%s\n" % self.test_file[:-1]) + self.assertEqual(result, expected) def test_with_addl_env(self): + expected = "%s\n" % self.test_file + self.mock_popen.return_value = [expected, ""] result = utils.execute(["ls", self.test_file], addl_env={'foo': 'bar'}) - self.assertEqual(result, "%s\n" % self.test_file) + self.assertEqual(result, expected) class AgentUtilsGetInterfaceMAC(base.BaseTestCase):