mirror of
https://github.com/thegeeklab/ansible-later.git
synced 2024-11-22 04:40:42 +00:00
feat: add rule CheckRelativeRolePaths
This commit is contained in:
parent
b050e8c152
commit
a21f599cad
34
ansiblelater/rules/CheckRelativeRolePaths.py
Normal file
34
ansiblelater/rules/CheckRelativeRolePaths.py
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
# Copyright (c) 2016, Tsukinowa Inc. <info@tsukinowa.jp>
|
||||||
|
# Copyright (c) 2018, Ansible Project
|
||||||
|
from ansiblelater.standard import StandardBase
|
||||||
|
|
||||||
|
|
||||||
|
class CheckRelativeRolePaths(StandardBase):
|
||||||
|
|
||||||
|
sid = "ANSIBLE0025"
|
||||||
|
description = "Don't use a relative path in a role"
|
||||||
|
helptext = "`copy` and `template` modules don't need relative path for `src`"
|
||||||
|
version = "0.2"
|
||||||
|
types = ["playbook", "task", "handler"]
|
||||||
|
|
||||||
|
def check(self, candidate, settings):
|
||||||
|
tasks, errors = self.get_normalized_tasks(candidate, settings)
|
||||||
|
module_to_path_folder = {
|
||||||
|
"copy": "files",
|
||||||
|
"win_copy": "files",
|
||||||
|
"template": "templates",
|
||||||
|
"win_template": "win_templates",
|
||||||
|
}
|
||||||
|
|
||||||
|
if not errors:
|
||||||
|
for task in tasks:
|
||||||
|
module = task["action"]["__ansible_module__"]
|
||||||
|
path_to_check = None
|
||||||
|
|
||||||
|
if module in module_to_path_folder and "src" in task["action"]:
|
||||||
|
path_to_check = "../{}".format(module_to_path_folder[module])
|
||||||
|
|
||||||
|
if path_to_check and path_to_check in task["action"]["src"]:
|
||||||
|
errors.append(self.Error(task["__line__"], self.helptext))
|
||||||
|
|
||||||
|
return self.Result(candidate.path, errors)
|
@ -39,3 +39,4 @@ Reviews are nothing without some rules or standards against which to review. ans
|
|||||||
| CheckWhenFormat | ANSIBLE0022 | Don't use Jinja2 in `when`. | |
|
| CheckWhenFormat | ANSIBLE0022 | Don't use Jinja2 in `when`. | |
|
||||||
| CheckNestedJinja | ANSIBLE0023 | Don't use nested Jinja2 pattern. | |
|
| CheckNestedJinja | ANSIBLE0023 | Don't use nested Jinja2 pattern. | |
|
||||||
| CheckLocalAction | ANSIBLE0024 | Don't use local_action. | |
|
| CheckLocalAction | ANSIBLE0024 | Don't use local_action. | |
|
||||||
|
| CheckRelativeRolePaths | ANSIBLE0025 | Don't use a relative path in a role. | |
|
||||||
|
Loading…
Reference in New Issue
Block a user