65 lines
2.4 KiB
YAML
65 lines
2.4 KiB
YAML
---
|
|
- name: Verify vaultwarden role
|
|
hosts: localhost
|
|
gather_facts: false
|
|
vars:
|
|
vaultwarden_data_dir: /tmp/sovereign_test/vaultwarden
|
|
vaultwarden_domain: vault.test.example.com
|
|
vaultwarden_admin_token: test_vaultwarden_admin_token
|
|
vaultwarden_version: latest
|
|
|
|
tasks:
|
|
- name: Check vaultwarden data directory exists
|
|
ansible.builtin.stat:
|
|
path: "/tmp/sovereign_test/vaultwarden"
|
|
register: data_dir_stat
|
|
|
|
- name: Assert vaultwarden data directory is present
|
|
ansible.builtin.assert:
|
|
that: data_dir_stat.stat.isdir
|
|
fail_msg: "Data directory /tmp/sovereign_test/vaultwarden was not created"
|
|
|
|
- name: Check docker-compose.yml exists
|
|
ansible.builtin.stat:
|
|
path: "/tmp/sovereign_test/vaultwarden/docker-compose.yml"
|
|
register: compose_stat
|
|
|
|
- name: Assert docker-compose.yml was rendered
|
|
ansible.builtin.assert:
|
|
that: compose_stat.stat.exists
|
|
fail_msg: "docker-compose.yml was not rendered for vaultwarden"
|
|
|
|
- name: Read docker-compose.yml
|
|
ansible.builtin.slurp:
|
|
src: "/tmp/sovereign_test/vaultwarden/docker-compose.yml"
|
|
register: compose_raw
|
|
|
|
- name: Set compose content fact
|
|
ansible.builtin.set_fact:
|
|
compose: "{{ compose_raw.content | b64decode }}"
|
|
|
|
- name: Assert vaultwarden server image is present
|
|
ansible.builtin.assert:
|
|
that: "'vaultwarden/server' in compose"
|
|
fail_msg: "vaultwarden/server image not found in docker-compose.yml"
|
|
|
|
- name: Assert vaultwarden domain traefik rule is present
|
|
ansible.builtin.assert:
|
|
that: "'Host(`vault.test.example.com`)' in compose"
|
|
fail_msg: "Traefik rule for vault.test.example.com not found in docker-compose.yml"
|
|
|
|
- name: Assert admin token is present in compose
|
|
ansible.builtin.assert:
|
|
that: "'test_vaultwarden_admin_token' in compose"
|
|
fail_msg: "vaultwarden_admin_token not found in docker-compose.yml"
|
|
|
|
- name: Assert GELF logging address is present
|
|
ansible.builtin.assert:
|
|
that: "'udp://127.0.0.1:12201' in compose"
|
|
fail_msg: "GELF logging address udp://127.0.0.1:12201 not found in docker-compose.yml"
|
|
|
|
- name: Assert sovereign network is external
|
|
ansible.builtin.assert:
|
|
that: "'external: true' in compose"
|
|
fail_msg: "external: true not found in docker-compose.yml networks section"
|