Files @ 94cf74211121
Branch filter:

Location: majic-ansible-roles/roles/mail_forwarder/molecule/default/prepare.yml - annotation

branko
MAR-218: Drop linting definitions from Molecule configuratin files:

- Molecule no longer natively supports running linters.
- Disable the Ansible Galaxy dependency installation (none of the
roles utilise this).
36e1c9460cd6
36e1c9460cd6
1733003af19f
1733003af19f
1733003af19f
1733003af19f
1733003af19f
1733003af19f
1733003af19f
1733003af19f
1733003af19f
1b36419c4641
1733003af19f
1733003af19f
1733003af19f
1733003af19f
1733003af19f
1733003af19f
1b36419c4641
1733003af19f
1733003af19f
1733003af19f
1733003af19f
1733003af19f
1733003af19f
1733003af19f
1733003af19f
1733003af19f
1733003af19f
1733003af19f
1733003af19f
1733003af19f
1733003af19f
1733003af19f
fb5e4e372902
fb5e4e372902
13982172ed2e
fb5e4e372902
fb5e4e372902
e75d5d4fba3b
13982172ed2e
13982172ed2e
fb5e4e372902
36e1c9460cd6
13982172ed2e
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
13982172ed2e
13982172ed2e
36e1c9460cd6
36e1c9460cd6
13982172ed2e
36e1c9460cd6
36e1c9460cd6
fb5e4e372902
36e1c9460cd6
fb5e4e372902
fb5e4e372902
36e1c9460cd6
fb5e4e372902
fb5e4e372902
fb5e4e372902
fb5e4e372902
36e1c9460cd6
c6e9add17764
c6e9add17764
d8e012ba7070
d8e012ba7070
d8e012ba7070
fb5e4e372902
ed73868fa196
ed73868fa196
ed73868fa196
ed73868fa196
ed73868fa196
fb5e4e372902
13982172ed2e
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
13982172ed2e
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
13982172ed2e
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
1733003af19f
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
fb5e4e372902
13982172ed2e
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
1733003af19f
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
1733003af19f
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
13982172ed2e
13982172ed2e
13982172ed2e
36e1c9460cd6
36e1c9460cd6
13982172ed2e
13982172ed2e
13982172ed2e
13982172ed2e
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
f774e938a4ed
f774e938a4ed
f774e938a4ed
13982172ed2e
f774e938a4ed
01f4b619cfa6
01f4b619cfa6
01f4b619cfa6
13982172ed2e
01f4b619cfa6
23a9ea4219dc
23a9ea4219dc
13982172ed2e
23a9ea4219dc
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
13982172ed2e
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
36e1c9460cd6
---

- name: Set-up fixtures
  hosts: localhost
  connection: local
  gather_facts: false
  tasks:

    - name: Initialise CA hierarchy
      command: "gimmecert init"
      args:
        creates: ".gimmecert/ca/level1.cert.pem"
        chdir: "tests/data/"

    - name: Generate server private keys and certificates
      command:
      args:
        chdir: "tests/data/"
        creates: ".gimmecert/server/{{ item.name }}.cert.pem"
        argv:
          - "gimmecert"
          - "server"
          - "{{ item.name }}"
          - "{{ item.fqdn }}"
      with_items:
        - name: mail-server_smtp
          fqdn: mail-server

    - name: Set-up link to generated X.509 material
      file:
        src: ".gimmecert"
        dest: "tests/data/x509"
        state: link

- name: Prepare
  hosts: all
  gather_facts: false
  tasks:
    - name: Install python for Ansible
      raw: test -e /usr/bin/python3 || (apt -y update && apt install -y python3-minimal)
      become: true
      changed_when: false

- hosts: all
  become: true
  tasks:

    - name: Update all caches to avoid errors due to missing remote archives
      apt:
        update_cache: true
      changed_when: false

- hosts: all
  become: true
  tasks:

    - name: Set-up the hosts file
      lineinfile:
        path: /etc/hosts
        regexp: "^{{ item.key }}"
        line: "{{ item.key }} {{ item.value }}"
        owner: root
        group: root
        mode: 0644
        state: present
      with_dict:
        192.168.56.11: "mail-server domain1"
        192.168.56.12: "client1"
        192.168.56.21: "parameters-mandatory-bookworm"
        192.168.56.22: "parameters-optional-bookworm"
        192.168.56.23: "parameters-no-incoming-bookworm"

    - name: Install tools for testing
      apt:
        name: gnutls-bin
        state: present

- hosts: clients
  become: true
  tasks:

    - name: Install SWAKS for testing SMTP capability
      apt:
        name: swaks
        state: present

    - name: Install tool for testing TCP connectivity
      apt:
        name: hping3
        state: present

    - name: Deploy CA certificate
      copy:
        src: tests/data/x509/ca/level1.cert.pem
        dest: /usr/local/share/ca-certificates/testca.crt
        owner: root
        group: root
        mode: 0644
      notify:
        - Update CA certificate cache

  handlers:

    - name: Update CA certificate cache
      command: /usr/sbin/update-ca-certificates --fresh

- hosts: mail-servers
  become: true
  tasks:

    - name: Deploy CA certificate
      copy:
        src: tests/data/x509/ca/level1.cert.pem
        dest: /usr/local/share/ca-certificates/testca.crt
        owner: root
        group: root
        mode: 0644
      notify:
        - Update CA certificate cache

    - name: Deploy SMTP private key and certificate
      copy:
        src: "tests/data/x509/server/{{ item }}"
        dest: "/etc/ssl/{{ item }}"
        owner: root
        group: root
        mode: 0600
      with_items:
        - mail-server_smtp.cert.pem
        - mail-server_smtp.key.pem

    - name: Install Postfix
      apt:
        name: "postfix"
        state: present

    - name: Purge Exim configuration
      apt:
        name: "exim4*"
        state: absent
        purge: true

    - name: Deploy Postfix configuration
      copy:
        src: tests/data/main.cf
        dest: /etc/postfix/main.cf
        owner: root
        group: root
        mode: 0644
      notify:
        - Restart Postfix

    - name: Install tool for testing TCP connectivity
      apt:
        name: hping3
        state: present

    - name: Install SWAKS for testing SMTP capability
      apt:
        name: swaks
        state: present

    - name: Set-up port forwarding
      command: "iptables -t nat -A PREROUTING -p tcp -m tcp --dport 27 -j REDIRECT --to-ports 25"
      changed_when: false

  handlers:

    - name: Update CA certificate cache
      command: /usr/sbin/update-ca-certificates --fresh

    - name: Restart Postfix
      service:
        name: postfix
        state: restarted

- hosts: parameters-optional
  become: true
  tasks:

    - name: Create additional group for testing local aliases
      group:
        name: testuser

    - name: Create additional user for testing local aliases
      user:
        name: testuser
        group: testuser