2016-08-17 09:32:50 +00:00
|
|
|
|
|
|
|
import mock
|
|
|
|
import subprocess
|
|
|
|
import unittest
|
|
|
|
import sys
|
|
|
|
|
2017-09-16 07:15:25 +00:00
|
|
|
import mitogen.master
|
2016-08-17 09:32:50 +00:00
|
|
|
import testlib
|
|
|
|
|
|
|
|
import plain_old_module
|
|
|
|
import simple_pkg.a
|
|
|
|
|
|
|
|
|
2017-09-17 15:03:43 +00:00
|
|
|
class GoodModulesTest(testlib.RouterMixin, unittest.TestCase):
|
2016-08-17 09:32:50 +00:00
|
|
|
def test_plain_old_module(self):
|
|
|
|
# The simplest case: a top-level module with no interesting imports or
|
|
|
|
# package machinery damage.
|
2017-09-17 15:03:43 +00:00
|
|
|
context = self.router.local()
|
2016-08-17 09:32:50 +00:00
|
|
|
self.assertEquals(256, context.call(plain_old_module.pow, 2, 8))
|
|
|
|
|
|
|
|
def test_simple_pkg(self):
|
|
|
|
# Ensure success of a simple package containing two submodules, one of
|
|
|
|
# which imports the other.
|
2017-09-17 15:03:43 +00:00
|
|
|
context = self.router.local()
|
2016-08-17 09:32:50 +00:00
|
|
|
self.assertEquals(3,
|
|
|
|
context.call(simple_pkg.a.subtract_one_add_two, 2))
|
|
|
|
|
|
|
|
def test_self_contained_program(self):
|
|
|
|
# Ensure a program composed of a single script can be imported
|
|
|
|
# successfully.
|
|
|
|
args = [sys.executable, testlib.data_path('self_contained_program.py')]
|
|
|
|
output = subprocess.check_output(args)
|
|
|
|
self.assertEquals(output, "['__main__', 50]\n")
|
|
|
|
|
|
|
|
|
2016-08-17 11:05:52 +00:00
|
|
|
class BrokenModulesTest(unittest.TestCase):
|
2016-08-17 11:11:26 +00:00
|
|
|
def test_obviously_missing(self):
|
|
|
|
# Ensure we don't crash in the case of a module legitimately being
|
|
|
|
# unavailable. Should never happen in the real world.
|
|
|
|
|
2017-09-17 15:03:43 +00:00
|
|
|
router = mock.Mock()
|
|
|
|
responder = mitogen.master.ModuleResponder(router)
|
|
|
|
responder._on_get_module(
|
|
|
|
mitogen.core.Message(
|
|
|
|
data='non_existent_module',
|
|
|
|
reply_to=50,
|
|
|
|
)
|
|
|
|
)
|
|
|
|
self.assertEquals(1, len(router.route.mock_calls))
|
2016-08-17 11:11:26 +00:00
|
|
|
|
2017-09-17 15:03:43 +00:00
|
|
|
call = router.route.mock_calls[0]
|
|
|
|
msg, = call[1]
|
|
|
|
self.assertEquals(50, msg.handle)
|
|
|
|
self.assertTrue(msg.unpickle() is None)
|
2016-08-17 11:11:26 +00:00
|
|
|
|
2016-08-17 09:32:50 +00:00
|
|
|
def test_ansible_six_messed_up_path(self):
|
|
|
|
# The copy of six.py shipped with Ansible appears in a package whose
|
|
|
|
# __path__ subsequently ends up empty, which prevents pkgutil from
|
|
|
|
# finding its submodules. After ansible.compat.six is initialized in
|
|
|
|
# the parent, attempts to execute six/__init__.py on the slave will
|
|
|
|
# cause an attempt to request ansible.compat.six._six from the master.
|
|
|
|
import six_brokenpkg
|
|
|
|
|
2017-09-17 15:03:43 +00:00
|
|
|
router = mock.Mock()
|
|
|
|
responder = mitogen.master.ModuleResponder(router)
|
|
|
|
responder._on_get_module(
|
|
|
|
mitogen.core.Message(
|
|
|
|
data='six_brokenpkg._six',
|
|
|
|
reply_to=50,
|
|
|
|
)
|
|
|
|
)
|
|
|
|
self.assertEquals(1, len(router.route.mock_calls))
|
2016-08-17 09:32:50 +00:00
|
|
|
|
2017-09-17 15:03:43 +00:00
|
|
|
call = router.route.mock_calls[0]
|
|
|
|
msg, = call[1]
|
|
|
|
self.assertEquals(50, msg.handle)
|
|
|
|
self.assertTrue(isinstance(msg.unpickle(), tuple))
|
2017-09-28 09:07:27 +00:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
import logging
|
|
|
|
logging.basicConfig(level=logging.DEBUG)
|
|
|
|
unittest.main()
|