Remove workaround for fixed bug. (#15340)
* Remove workaround for fixed bug. The bug where PluginLoader required objects to directly inherit from base_classes has been fixed. Remove workaround from this strategy plugin Also switched to using super so that we don't have to modify all of hte code anytime something like that happens. * These should be to_uniocde because they're being sent to display()
This commit is contained in:
parent
005dc84aa7
commit
54acdd7ead
2 changed files with 10 additions and 14 deletions
|
@ -31,7 +31,7 @@ import warnings
|
||||||
from collections import defaultdict
|
from collections import defaultdict
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.utils.unicode import to_str
|
from ansible.utils.unicode import to_unicode
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from __main__ import display
|
from __main__ import display
|
||||||
|
@ -248,7 +248,7 @@ class PluginLoader:
|
||||||
try:
|
try:
|
||||||
full_paths = (os.path.join(path, f) for f in os.listdir(path))
|
full_paths = (os.path.join(path, f) for f in os.listdir(path))
|
||||||
except OSError as e:
|
except OSError as e:
|
||||||
display.warning("Error accessing plugin paths: %s" % to_str(e))
|
display.warning("Error accessing plugin paths: %s" % to_unicode(e))
|
||||||
|
|
||||||
for full_path in (f for f in full_paths if os.path.isfile(f) and not f.endswith('__init__.py')):
|
for full_path in (f for f in full_paths if os.path.isfile(f) and not f.endswith('__init__.py')):
|
||||||
full_name = os.path.basename(full_path)
|
full_name = os.path.basename(full_path)
|
||||||
|
@ -370,7 +370,7 @@ class PluginLoader:
|
||||||
try:
|
try:
|
||||||
obj = getattr(self._module_cache[path], self.class_name)
|
obj = getattr(self._module_cache[path], self.class_name)
|
||||||
except AttributeError as e:
|
except AttributeError as e:
|
||||||
display.warning("Skipping plugin (%s) as it seems to be invalid: %s" % (path, to_str(e)))
|
display.warning("Skipping plugin (%s) as it seems to be invalid: %s" % (path, to_unicode(e)))
|
||||||
|
|
||||||
if self.base_class:
|
if self.base_class:
|
||||||
# The import path is hardcoded and should be the right place,
|
# The import path is hardcoded and should be the right place,
|
||||||
|
|
|
@ -7,7 +7,6 @@ import pprint
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
from ansible.plugins.strategy import linear
|
from ansible.plugins.strategy import linear
|
||||||
from ansible.plugins.strategy import StrategyBase
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from __main__ import display
|
from __main__ import display
|
||||||
|
@ -26,13 +25,10 @@ class NextAction(object):
|
||||||
self.result = result
|
self.result = result
|
||||||
|
|
||||||
|
|
||||||
class StrategyModule(linear.StrategyModule, StrategyBase):
|
class StrategyModule(linear.StrategyModule):
|
||||||
# Usually inheriting linear.StrategyModule is enough. However, StrategyBase class must be
|
|
||||||
# direct ancestor to be considered as strategy plugin, and so we inherit the class here.
|
|
||||||
|
|
||||||
def __init__(self, tqm):
|
def __init__(self, tqm):
|
||||||
self.curr_tqm = tqm
|
self.curr_tqm = tqm
|
||||||
StrategyBase.__init__(self, tqm)
|
super(StrategyModule, self).__init__(tqm)
|
||||||
|
|
||||||
def _queue_task(self, host, task, task_vars, play_context):
|
def _queue_task(self, host, task, task_vars, play_context):
|
||||||
self.curr_host = host
|
self.curr_host = host
|
||||||
|
@ -40,14 +36,14 @@ class StrategyModule(linear.StrategyModule, StrategyBase):
|
||||||
self.curr_task_vars = task_vars
|
self.curr_task_vars = task_vars
|
||||||
self.curr_play_context = play_context
|
self.curr_play_context = play_context
|
||||||
|
|
||||||
StrategyBase._queue_task(self, host, task, task_vars, play_context)
|
super(StrategyModule, self)._queue_task(host, task, task_vars, play_context)
|
||||||
|
|
||||||
def _process_pending_results(self, iterator, one_pass=False):
|
def _process_pending_results(self, iterator, one_pass=False):
|
||||||
if not hasattr(self, "curr_host"):
|
if not hasattr(self, "curr_host"):
|
||||||
return StrategyBase._process_pending_results(self, iterator, one_pass)
|
return super(StrategyModule, self)._process_pending_results(iterator, one_pass)
|
||||||
|
|
||||||
prev_host_state = iterator.get_host_state(self.curr_host)
|
prev_host_state = iterator.get_host_state(self.curr_host)
|
||||||
results = StrategyBase._process_pending_results(self, iterator, one_pass)
|
results = super(StrategyModule, self)._process_pending_results(iterator, one_pass)
|
||||||
|
|
||||||
while self._need_debug(results):
|
while self._need_debug(results):
|
||||||
next_action = NextAction()
|
next_action = NextAction()
|
||||||
|
@ -64,8 +60,8 @@ class StrategyModule(linear.StrategyModule, StrategyBase):
|
||||||
self._tqm._stats.dark[self.curr_host.name] -= 1
|
self._tqm._stats.dark[self.curr_host.name] -= 1
|
||||||
|
|
||||||
# redo
|
# redo
|
||||||
StrategyBase._queue_task(self, self.curr_host, self.curr_task, self.curr_task_vars, self.curr_play_context)
|
super(StrategyModule, self)._queue_task(self.curr_host, self.curr_task, self.curr_task_vars, self.curr_play_context)
|
||||||
results = StrategyBase._process_pending_results(self, iterator, one_pass)
|
results = super(StrategyModule, self)._process_pending_results(iterator, one_pass)
|
||||||
elif next_action.result == NextAction.CONTINUE:
|
elif next_action.result == NextAction.CONTINUE:
|
||||||
break
|
break
|
||||||
elif next_action.result == NextAction.EXIT:
|
elif next_action.result == NextAction.EXIT:
|
||||||
|
|
Loading…
Reference in a new issue