issue #340: split up Connection._connect()

The logic was getting too busy.
pull/350/head
David Wilson 6 years ago
parent a1e653978b
commit 6dcd5f8998

@ -551,20 +551,11 @@ class Connection(ansible.plugins.connection.ConnectionBase):
return stack, seen_names return stack, seen_names
def _connect(self): def _connect_broker(self):
""" """
Establish a connection to the master process's UNIX listener socket, Establish a reference to the Broker, Router and parent context used for
constructing a mitogen.master.Router to communicate with the master, connections.
and a mitogen.parent.Context to represent it.
Depending on the original transport we should emulate, trigger one of
the _connect_*() service calls defined above to cause the master
process to establish the real connection on our behalf, or return a
reference to the existing one.
""" """
if self.connected:
return
if not self.broker: if not self.broker:
self.broker = mitogen.master.Broker() self.broker = mitogen.master.Broker()
self.router, self.parent = mitogen.unix.connect( self.router, self.parent = mitogen.unix.connect(
@ -572,6 +563,11 @@ class Connection(ansible.plugins.connection.ConnectionBase):
broker=self.broker, broker=self.broker,
) )
def _build_stack(self):
"""
Construct a list of dictionaries representing the connection
configuration between the controller and the target.
"""
if hasattr(self._play_context, 'delegate_to'): if hasattr(self._play_context, 'delegate_to'):
target_config = config_from_hostvars( target_config = config_from_hostvars(
transport=self._play_context.connection, transport=self._play_context.connection,
@ -589,7 +585,14 @@ class Connection(ansible.plugins.connection.ConnectionBase):
connection=self connection=self
) )
stack, _ = self._stack_from_config(target_config) stack, _ = self._stack_from_config(target_config)
return stack
def _connect_stack(self, stack):
"""
Pass `stack` to ContextService, requesting a copy of the context object
representing the target. If no connection exists yet, ContextService
will establish it before returning it or throwing an error.
"""
dct = self.parent.call_service( dct = self.parent.call_service(
service_name='ansible_mitogen.services.ContextService', service_name='ansible_mitogen.services.ContextService',
method_name='get', method_name='get',
@ -610,6 +613,24 @@ class Connection(ansible.plugins.connection.ConnectionBase):
self.fork_context = dct['init_child_result']['fork_context'] self.fork_context = dct['init_child_result']['fork_context']
self.home_dir = dct['init_child_result']['home_dir'] self.home_dir = dct['init_child_result']['home_dir']
def _connect(self):
"""
Establish a connection to the master process's UNIX listener socket,
constructing a mitogen.master.Router to communicate with the master,
and a mitogen.parent.Context to represent it.
Depending on the original transport we should emulate, trigger one of
the _connect_*() service calls defined above to cause the master
process to establish the real connection on our behalf, or return a
reference to the existing one.
"""
if self.connected:
return
self._connect_broker()
stack = self._build_stack()
self._connect_stack(stack)
def close(self, new_task=False): def close(self, new_task=False):
""" """
Arrange for the mitogen.master.Router running in the worker to Arrange for the mitogen.master.Router running in the worker to

Loading…
Cancel
Save