Commit 3ded27fe by Michael DeHaan

Treat module args as strings everywhere to avoid unneccessary shlex and requoting

parent f11de2f5
...@@ -104,7 +104,7 @@ class Cli(object): ...@@ -104,7 +104,7 @@ class Cli(object):
runner = ansible.runner.Runner( runner = ansible.runner.Runner(
module_name=options.module_name, module_path=options.module_path, module_name=options.module_name, module_path=options.module_path,
module_args=shlex.split(options.module_args), module_args=options.module_args,
remote_user=options.remote_user, remote_pass=sshpass, remote_user=options.remote_user, remote_pass=sshpass,
host_list=options.inventory, timeout=options.timeout, host_list=options.inventory, timeout=options.timeout,
remote_port=options.remote_port, forks=options.forks, remote_port=options.remote_port, forks=options.forks,
...@@ -119,7 +119,7 @@ class Cli(object): ...@@ -119,7 +119,7 @@ class Cli(object):
def get_polling_runner(self, old_runner, hosts, jid): def get_polling_runner(self, old_runner, hosts, jid):
return ansible.runner.Runner( return ansible.runner.Runner(
module_name='async_status', module_path=old_runner.module_path, module_name='async_status', module_path=old_runner.module_path,
module_args=[ "jid=%s" % jid ], remote_user=old_runner.remote_user, module_args="jid=%s" % jid, remote_user=old_runner.remote_user,
remote_pass=old_runner.remote_pass, host_list=hosts, remote_pass=old_runner.remote_pass, host_list=hosts,
timeout=old_runner.timeout, forks=old_runner.forks, timeout=old_runner.timeout, forks=old_runner.forks,
remote_port=old_runner.remote_port, pattern='*', remote_port=old_runner.remote_port, pattern='*',
......
...@@ -221,7 +221,7 @@ class PlayBook(object): ...@@ -221,7 +221,7 @@ class PlayBook(object):
while (clock >= 0): while (clock >= 0):
# poll/loop until polling duration complete # poll/loop until polling duration complete
runner.module_args = [ "jid=%s" % jid ] runner.module_args = "jid=%s" % jid
runner.module_name = 'async_status' runner.module_name = 'async_status'
runner.background = 0 runner.background = 0
runner.pattern = '*' runner.pattern = '*'
......
...@@ -111,6 +111,9 @@ class Runner(object): ...@@ -111,6 +111,9 @@ class Runner(object):
self.basedir = basedir self.basedir = basedir
self.sudo = sudo self.sudo = sudo
if type(self.module_args) != str:
raise Exception("module_args must be a string: %s" % self.module_args)
self._tmp_paths = {} self._tmp_paths = {}
random.seed() random.seed()
...@@ -327,24 +330,10 @@ class Runner(object): ...@@ -327,24 +330,10 @@ class Runner(object):
# ***************************************************** # *****************************************************
def _coerce_args_to_string(self, args, remote_module_path):
''' final arguments must always be made a string '''
if type(args) == list:
if remote_module_path.endswith('setup'):
# quote long strings so setup module gets them unscathed
args = " ".join([ "\"%s\"" % str(x) for x in args ])
else:
args = " ".join([ str(x) for x in args ])
return args
# *****************************************************
def _execute_module(self, conn, tmp, remote_module_path, args, def _execute_module(self, conn, tmp, remote_module_path, args,
async_jid=None, async_module=None, async_limit=None): async_jid=None, async_module=None, async_limit=None):
''' runs a module that has already been transferred ''' ''' runs a module that has already been transferred '''
args = self._coerce_args_to_string(args, remote_module_path)
inject = self.setup_cache.get(conn.host,{}) inject = self.setup_cache.get(conn.host,{})
conditional = utils.double_template(self.conditional, inject) conditional = utils.double_template(self.conditional, inject)
if not eval(conditional): if not eval(conditional):
...@@ -393,12 +382,8 @@ class Runner(object): ...@@ -393,12 +382,8 @@ class Runner(object):
''' transfer & execute a module that is not 'copy' or 'template' ''' ''' transfer & execute a module that is not 'copy' or 'template' '''
# shell and command are the same module # shell and command are the same module
# FIXME: keep these args as strings as long as possible...
if module_name == 'shell': if module_name == 'shell':
module_name = 'command' module_name = 'command'
if type(self.module_args) == list:
self.module_args.append("#USE_SHELL")
else:
self.module_args += " #USE_SHELL" self.module_args += " #USE_SHELL"
module = self._transfer_module(conn, tmp, module_name) module = self._transfer_module(conn, tmp, module_name)
...@@ -419,11 +404,6 @@ class Runner(object): ...@@ -419,11 +404,6 @@ class Runner(object):
module_args = self.module_args module_args = self.module_args
if module_name == 'shell': if module_name == 'shell':
module_name = 'command' module_name = 'command'
# FIXME: this will become cleaner once we keep args as a string
# throughout the app
if type(module_args) == list:
module_args.append("#USE_SHELL")
else:
module_args += " #USE_SHELL" module_args += " #USE_SHELL"
async = self._transfer_module(conn, tmp, 'async_wrapper') async = self._transfer_module(conn, tmp, 'async_wrapper')
...@@ -455,7 +435,7 @@ class Runner(object): ...@@ -455,7 +435,7 @@ class Runner(object):
module = self._transfer_module(conn, tmp, 'copy') module = self._transfer_module(conn, tmp, 'copy')
# run the copy module # run the copy module
args = [ "src=%s" % tmp_src, "dest=%s" % dest ] args = "src=%s dest=%s" % (tmp_src, dest)
(result1, executed) = self._execute_module(conn, tmp, module, args) (result1, executed) = self._execute_module(conn, tmp, module, args)
(host, ok, data) = self._return_from_module(conn, host, result1, executed) (host, ok, data) = self._return_from_module(conn, host, result1, executed)
...@@ -471,7 +451,7 @@ class Runner(object): ...@@ -471,7 +451,7 @@ class Runner(object):
old_changed = data.get('changed', False) old_changed = data.get('changed', False)
module = self._transfer_module(conn, tmp, 'file') module = self._transfer_module(conn, tmp, 'file')
args = [ "%s=%s" % (k,v) for (k,v) in options.items() ] args = ' '.join([ "%s=%s" % (k,v) for (k,v) in options.items() ])
(result2, executed2) = self._execute_module(conn, tmp, module, args) (result2, executed2) = self._execute_module(conn, tmp, module, args)
results2 = self._return_from_module(conn, conn.host, result2, executed) results2 = self._return_from_module(conn, conn.host, result2, executed)
(host, ok, data2) = results2 (host, ok, data2) = results2
...@@ -506,7 +486,7 @@ class Runner(object): ...@@ -506,7 +486,7 @@ class Runner(object):
template_module = self._transfer_module(conn, tmp, 'template') template_module = self._transfer_module(conn, tmp, 'template')
# run the template module # run the template module
args = [ "src=%s" % temppath, "dest=%s" % dest, "metadata=%s" % metadata ] args = "src=%s dest=%s metadata=%s" % (temppath, dest, metadata)
(result1, executed) = self._execute_module(conn, tmp, template_module, args) (result1, executed) = self._execute_module(conn, tmp, template_module, args)
(host, ok, data) = self._return_from_module(conn, host, result1, executed) (host, ok, data) = self._return_from_module(conn, host, result1, executed)
...@@ -616,8 +596,7 @@ class Runner(object): ...@@ -616,8 +596,7 @@ class Runner(object):
def _match_hosts(self, pattern): def _match_hosts(self, pattern):
''' return all matched hosts fitting a pattern ''' ''' return all matched hosts fitting a pattern '''
rc = [ h for h in self.host_list if self._matches(h, pattern) ] return [ h for h in self.host_list if self._matches(h, pattern) ]
return rc
# ***************************************************** # *****************************************************
......
...@@ -21,7 +21,7 @@ class TestRunner(unittest.TestCase): ...@@ -21,7 +21,7 @@ class TestRunner(unittest.TestCase):
self.runner = ansible.runner.Runner( self.runner = ansible.runner.Runner(
module_name='ping', module_name='ping',
module_path='library/', module_path='library/',
module_args=[], module_args='',
remote_user=self.user, remote_user=self.user,
remote_pass=None, remote_pass=None,
host_list='test/ansible_hosts', host_list='test/ansible_hosts',
...@@ -58,7 +58,9 @@ class TestRunner(unittest.TestCase): ...@@ -58,7 +58,9 @@ class TestRunner(unittest.TestCase):
def _run(self, module_name, module_args, background=0): def _run(self, module_name, module_args, background=0):
''' run a module and get the localhost results ''' ''' run a module and get the localhost results '''
self.runner.module_name = module_name self.runner.module_name = module_name
self.runner.module_args = module_args args = ' '.join(module_args)
print "DEBUG: using args=%s" % args
self.runner.module_args = args
self.runner.background = background self.runner.background = background
results = self.runner.run() results = self.runner.run()
# when using nosetests this will only show up on failure # when using nosetests this will only show up on failure
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment