[stable-2.10] Update ansible-test change detection for plugins.
(cherry picked from commit 09f02980a4
)
Co-authored-by: Matt Clay <matt@mystile.com>
This commit is contained in:
parent
957f0c27fc
commit
ddc78622a4
2 changed files with 36 additions and 0 deletions
|
@ -0,0 +1,2 @@
|
||||||
|
bugfixes:
|
||||||
|
- ansible-test - integration and unit test change detection now works for filter, lookup and test plugins
|
|
@ -608,6 +608,12 @@ class PathMapper:
|
||||||
FOCUSED_TARGET: target is not None,
|
FOCUSED_TARGET: target is not None,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if is_subdir(path, data_context().content.plugin_paths['filter']):
|
||||||
|
return self._simple_plugin_tests('filter', name)
|
||||||
|
|
||||||
|
if is_subdir(path, data_context().content.plugin_paths['lookup']):
|
||||||
|
return self._simple_plugin_tests('lookup', name)
|
||||||
|
|
||||||
if (is_subdir(path, data_context().content.plugin_paths['terminal']) or
|
if (is_subdir(path, data_context().content.plugin_paths['terminal']) or
|
||||||
is_subdir(path, data_context().content.plugin_paths['cliconf']) or
|
is_subdir(path, data_context().content.plugin_paths['cliconf']) or
|
||||||
is_subdir(path, data_context().content.plugin_paths['netconf'])):
|
is_subdir(path, data_context().content.plugin_paths['netconf'])):
|
||||||
|
@ -632,6 +638,9 @@ class PathMapper:
|
||||||
'units': 'all',
|
'units': 'all',
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if is_subdir(path, data_context().content.plugin_paths['test']):
|
||||||
|
return self._simple_plugin_tests('test', name)
|
||||||
|
|
||||||
return None
|
return None
|
||||||
|
|
||||||
def _classify_collection(self, path): # type: (str) -> t.Optional[t.Dict[str, str]]
|
def _classify_collection(self, path): # type: (str) -> t.Optional[t.Dict[str, str]]
|
||||||
|
@ -874,6 +883,31 @@ class PathMapper:
|
||||||
|
|
||||||
return None # unknown, will result in fall-back to run all tests
|
return None # unknown, will result in fall-back to run all tests
|
||||||
|
|
||||||
|
def _simple_plugin_tests(self, plugin_type, plugin_name): # type: (str, str) -> t.Dict[str, t.Optional[str]]
|
||||||
|
"""
|
||||||
|
Return tests for the given plugin type and plugin name.
|
||||||
|
This function is useful for plugin types which do not require special processing.
|
||||||
|
"""
|
||||||
|
if plugin_name == '__init__':
|
||||||
|
return all_tests(self.args, True)
|
||||||
|
|
||||||
|
integration_target = self.integration_targets_by_name.get('%s_%s' % (plugin_type, plugin_name))
|
||||||
|
|
||||||
|
if integration_target:
|
||||||
|
integration_name = integration_target.name
|
||||||
|
else:
|
||||||
|
integration_name = None
|
||||||
|
|
||||||
|
units_path = os.path.join(data_context().content.unit_path, 'plugins', plugin_type, 'test_%s.py' % plugin_name)
|
||||||
|
|
||||||
|
if units_path not in self.units_paths:
|
||||||
|
units_path = None
|
||||||
|
|
||||||
|
return dict(
|
||||||
|
integration=integration_name,
|
||||||
|
units=units_path,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
def all_tests(args, force=False):
|
def all_tests(args, force=False):
|
||||||
"""
|
"""
|
||||||
|
|
Loading…
Reference in a new issue