Skip to content

Commit

Permalink
Merge pull request #6 from f500/ansible-lint
Browse files Browse the repository at this point in the history
Add ansible lint pr workflow
  • Loading branch information
mjmeijerman authored Dec 30, 2024
2 parents c965d6e + dfaad12 commit eafa78d
Show file tree
Hide file tree
Showing 6 changed files with 184 additions and 24 deletions.
129 changes: 129 additions & 0 deletions .ansible-lint
Original file line number Diff line number Diff line change
@@ -0,0 +1,129 @@
---
# .ansible-lint

profile: production # min, basic, moderate,safety, shared, production

# Allows dumping of results in SARIF format
# sarif_file: result.sarif

# exclude_paths included in this file are parsed relative to this file's location
# and not relative to the CWD of execution. CLI arguments passed to the --exclude
# option are parsed relative to the CWD of execution.
exclude_paths:
- .github/
- .ansible-lint
# parseable: true
# quiet: true
# strict: true
# verbosity: 1

# Mock modules or roles in order to pass ansible-playbook --syntax-check
#mock_modules:
# - zuul_return
# note the foo.bar is invalid as being neither a module or a collection
# - fake_namespace.fake_collection.fake_module
# - fake_namespace.fake_collection.fake_module.fake_submodule
#mock_roles:
# - mocked_role
# - author.role_name # old standalone galaxy role
# - fake_namespace.fake_collection.fake_role # role within a collection

# Enable checking of loop variable prefixes in roles
loop_var_prefix: "^(__|{role}_)"

# Enforce variable names to follow pattern below, in addition to Ansible own
# requirements, like avoiding python identifiers. To disable add `var-naming`
# to skip_list.
var_naming_pattern: "^[a-z_][a-z0-9_]*$"

use_default_rules: true
# Load custom rules from this specific folder
# rulesdir:
# - ./rule/directory/

# Ansible-lint is able to recognize and load skip rules stored inside
# `.ansible-lint-ignore` (or `.config/ansible-lint-ignore.txt`) files.
# To skip a rule just enter filename and tag, like "playbook.yml package-latest"
# on a new line.
# Optionally you can add comments after the tag, prefixed by "#". We discourage
# the use of skip_list below because that will hide violations from the output.
# When putting ignores inside the ignore file, they are marked as ignored, but
# still visible, making it easier to address later.
skip_list:
- risky-shell-pipe
# - skip_this_tag

# Ansible-lint does not automatically load rules that have the 'opt-in' tag.
# You must enable opt-in rules by listing each rule 'id' below.
enable_list:
- args
- empty-string-compare # opt-in
- no-log-password # opt-in
- no-same-owner # opt-in
- name[prefix] # opt-in
- galaxy-version-incorrect # opt-in
# add yaml here if you want to avoid ignoring yaml checks when yamllint
# library is missing. Normally its absence just skips using that rule.
- yaml
# Report only a subset of tags and fully ignore any others
# tags:
# - jinja[spacing]

# Ansible-lint does not fail on warnings from the rules or tags listed below
#warn_list:
# - skip_this_tag
# - experimental # experimental is included in the implicit list
# - role-name
# - yaml[document-start] # you can also use sub-rule matches

# Some rules can transform files to fix (or make it easier to fix) identified
# errors. `ansible-lint --fix` will reformat YAML files and run these transforms.
# By default it will run all transforms (effectively `write_list: ["all"]`).
# You can disable running transforms by setting `write_list: ["none"]`.
# Or only enable a subset of rule transforms by listing rules/tags here.
# write_list:
# - all

# Offline mode disables installation of requirements.yml and schema refreshing
offline: true

# Define required Ansible's variables to satisfy syntax check
#extra_vars:
# foo: bar
# multiline_string_variable: |
# line1
# line2
# complex_variable: ":{;\t$()"

# Uncomment to enforce action validation with tasks, usually is not
# needed as Ansible syntax check also covers it.
# skip_action_validation: false

# List of additional kind:pattern to be added at the top of the default
# match list, first match determines the file kind.
#kinds:
# - playbook: "**/examples/*.{yml,yaml}"
# - galaxy: "**/folder/galaxy.yml"
# - tasks: "**/tasks/*.yml"
# - vars: "**/vars/*.yml"
# - meta: "**/meta/main.yml"
# - yaml: "**/*.yaml-too"

# List of additional collections to allow in only-builtins rule.
# only_builtins_allow_collections:
# - example_ns.example_collection

# List of additions modules to allow in only-builtins rule.
# only_builtins_allow_modules:
# - example_module

# Allow setting custom prefix for name[prefix] rule
#task_name_prefix: "{stem} | "
# Complexity related settings

# Limit the depth of the nested blocks:
# max_block_depth: 20

# Also recognize these versions of Ansible as supported:
# supported_ansible_also:
# - "2.14"
12 changes: 12 additions & 0 deletions .github/workflows/pull-request.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
---
name: Pull request

on: pull_request

jobs:
ansible-lint:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Run ansible-lint
uses: ansible/ansible-lint@main
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
.idea
16 changes: 16 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,22 @@ Example Playbook
roles:
- { role: f500.nodejs }

Linting
-------
Github actions will check this role with ansible-lint. To run this locally, you will need to follow the following steps:

```bash
brew install ansible-lint
brew install yamllint
ansible-lint
```

to fix the linting errors, run:

```bash
ansible-lint --fix
```

License
-------

Expand Down
19 changes: 10 additions & 9 deletions meta/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,20 +2,21 @@
galaxy_info:
author: Jasper N. Brouwer, Ramon de la Fuente
role_name: nodejs
namespace: f500
description: Install Node.js and NPM
company: Future500
license: LGPL-3.0
min_ansible_version: "1.4"
platforms:
- name: Debian
versions:
- bullseye
- bookworm
- name: Ubuntu
versions:
- precise
- trusty
- xenial
- name: Debian
versions:
- bullseye
- bookworm
- name: Ubuntu
versions:
- precise
- trusty
- xenial
galaxy_tags:
- web
- system
Expand Down
31 changes: 16 additions & 15 deletions tasks/main.yml
Original file line number Diff line number Diff line change
@@ -1,41 +1,42 @@
---

- name: Add the nodesource.com trusted key
ansible.builtin.get_url:
url: https://keyserver.ubuntu.com/pks/lookup?op=get&fingerprint=on&search=0x1655A0AB68576280
dest: /etc/apt/trusted.gpg.d/nodesource
mode: 0644
force: yes
mode: "0644"
force: true

- name: dearmor gpg key
ansible.builtin.shell: gpg --batch --yes --dearmor /etc/apt/trusted.gpg.d/nodesource
become: yes
- name: Dearmor gpg key
ansible.builtin.command: gpg --batch --yes --dearmor /etc/apt/trusted.gpg.d/nodesource
become: true
changed_when: false

- name: Add the nodesource.com repository
apt_repository:
ansible.builtin.apt_repository:
repo: "deb https://deb.nodesource.com/node_{{ nodejs_version }} {{ ansible_distribution_release }} main"
update_cache: no
update_cache: false

- name: Add the nodesource.com source repository
apt_repository:
ansible.builtin.apt_repository:
repo: "deb-src https://deb.nodesource.com/node_{{ nodejs_version }} {{ ansible_distribution_release }} main"
update_cache: yes
update_cache: true

- name: Install Node.js & NPM
apt:
ansible.builtin.apt:
name: nodejs

- name: Check temp directory
command: npm -g config get tmp
ansible.builtin.command: npm -g config get tmp
register: npm_tmp_dir
changed_when: False
changed_when: false

- name: Set temp directory
command: npm -g config set tmp /tmp
ansible.builtin.command: npm -g config set tmp /tmp
when: npm_tmp_dir.stdout != '/tmp'
changed_when: false

- name: Remove old temp directory
file:
ansible.builtin.file:
path: "{{ npm_tmp_dir.stdout }}"
state: absent
when: npm_tmp_dir.stdout != '/tmp'

0 comments on commit eafa78d

Please sign in to comment.