mirror of
https://github.com/thegeeklab/ansible-later.git
synced 2024-11-21 20:30: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`. | |
|
||||
| CheckNestedJinja | ANSIBLE0023 | Don't use nested Jinja2 pattern. | |
|
||||
| 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