Skip to content

Commit

Permalink
Merge pull request #4 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 aa121e6 + 9ff5ad9 commit e55d8e8
Show file tree
Hide file tree
Showing 8 changed files with 205 additions and 28 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 @@ -54,6 +54,22 @@ Example Playbook
roles:
- { role: f500.memcached }

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
7 changes: 3 additions & 4 deletions defaults/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,11 @@ memcached_port: 11211
memcached_maxconn: 1024
memcached_memusage: 128

#memcached_socket: ~
#memcached_permissions: ~
# memcached_socket: ~
# memcached_permissions: ~

# When using multiple instances:
#memcached_servers:
# memcached_servers:
# - name: production
# maxconn: 1024
# memusage: 128
Expand All @@ -21,4 +21,3 @@ memcached_memusage: 128
# memusage: 128
# socket: "/var/run/memcached/memcached_development.sock"
# permissions: "0666"

7 changes: 4 additions & 3 deletions handlers/main.yml
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
---

- name: restart memcached
service: name=memcached state=restarted
- name: Restart memcached
ansible.builtin.service:
name: memcached
state: restarted
when: not started_memcached is changed
14 changes: 7 additions & 7 deletions meta/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,16 +2,16 @@
galaxy_info:
author: "Jasper N. Brouwer, Ramon de la Fuente"
role_name: memcached
namespace: "f500"
description: Install and start memcached
company: Future500
license: LGPL
min_ansible_version: 1.4
min_ansible_version: "1.4"
platforms:
- name: Debian
versions:
- bullseye
- bookworm
- name: Debian
versions:
- bullseye
- bookworm
galaxy_tags:
- database
- database:sql
- system
dependencies: []
47 changes: 33 additions & 14 deletions tasks/main.yml
Original file line number Diff line number Diff line change
@@ -1,26 +1,45 @@
---
- name: Install memcached
ansible.builtin.apt:
pkg: memcached
state: present

- name: install memcached
apt: pkg=memcached state=present

- name: write memcached.conf
template: src=memcached.conf.j2 dest=/etc/memcached.conf owner=root group=root mode=0644
- name: Write memcached.conf
ansible.builtin.template:
src: memcached.conf.j2
dest: /etc/memcached.conf
owner: root
group: root
mode: "0644"
when: memcached_servers is undefined
notify:
- restart memcached
- Restart memcached

- name: write memcached_servers.conf
template: src=memcached_servers.conf.j2 dest=/etc/memcached_{{ item.name }}.conf owner=root group=root mode=0644
- name: Write memcached_servers.conf
ansible.builtin.template:
src: memcached_servers.conf.j2
dest: "/etc/memcached_{{ item.name }}.conf"
owner: root
group: root
mode: "0644"
with_items: "{{ memcached_servers | default([]) }}"
when: memcached_servers is defined
notify:
- restart memcached
- Restart memcached

- name: write init.d/memcached
copy: src=memcached dest=/etc/init.d/memcached owner=root group=root mode=0755
- name: Write init.d/memcached
ansible.builtin.copy:
src: memcached
dest: /etc/init.d/memcached
owner: root
group: root
mode: "0755"
notify:
- restart memcached
- Restart memcached

- name: start memcached
service: name=memcached enabled=yes state=started
- name: Start memcached
ansible.builtin.service:
name: memcached
enabled: "yes"
state: started
register: started_memcached

0 comments on commit e55d8e8

Please sign in to comment.