Files @ 17cf34f73ca6
Branch filter:

Location: majic-ansible-roles/testsite/playbooks/roles/wsgihello2/tasks/main.yml

branko
MAR-28: Implemented additional tests for mail_server role:

- Deploy a number of tools on clients in order to test SMTP, IMAP, and Sieve
services.
- Added one more user to LDAP directory for testing group restrictions.
- Deploy CA certificate on all testing machines for TLS validation purposes.
- Use different custom-configured cipher for mail server ciphers.
- Fixed invalid postmaster address for parameters-optional host.
- Deploy configuration files for use with Imap-CLI on client test machines.
- Updated testing of SMTP server to include checks for users that do not belong
to mail group.
- Extended some SMTP-related tests to cover both test servers.
- Some small fixes in SMTP-related tests for expected output from commands.
- Implemented tests covering Dovecot (IMAP + Sieve) functionality.
- Implemented tests for running/enabled services.
- Implemented tests for ClamAV.
- Implemented tests for firewall and connectivity.
- Implemented tests for Postfix TLS configuration.
- TODO: Tests for Sieve TLS configuration have not been written yet due to
limitation of available tools.
---

- name: Create directory for storing code
  file: dest="/var/www/wsgireq.{{ testsite_domain }}/code/" state=directory
        owner="admin-wsgireq_{{ testsite_domain_underscores }}" group="web-wsgireq_{{ testsite_domain_underscores }}" mode=2750

- name: Deploy requirements and its source for upgrade checks
  copy: src="{{ item }}" dest="/etc/pip_check_requirements_upgrades/wsgireq.{{ testsite_domain }}/{{ item }}"
        owner="root" group="pipreqcheck" mode=640
  with_items:
    - requirements.in
    - requirements.txt

- name: Deploy requirements
  copy: src="requirements.txt" dest="/var/www/wsgireq.{{ testsite_domain }}/code/requirements.txt"
        owner="admin-wsgireq_{{ testsite_domain_underscores }}" group="web-wsgireq_{{ testsite_domain_underscores }}" mode=640

- name: Install latest version of pip
  become_user: "admin-wsgireq_{{ testsite_domain_underscores }}"
  pip: name=pip state=latest virtualenv="/var/www/wsgireq.{{ testsite_domain }}/virtualenv"

- name: Deploy pip-tools
  become_user: "admin-wsgireq_{{ testsite_domain_underscores }}"
  pip: name=pip-tools state=present virtualenv="/var/www/wsgireq.{{ testsite_domain }}/virtualenv"

- name: Synchronise virtual environment with requirements file
  become_user: "admin-wsgireq_{{ testsite_domain_underscores }}"
  command: "'/var/www/wsgireq.{{ testsite_domain }}/virtualenv/bin/exec' pip-sync ~/code/requirements.txt ~/.wsgi_requirements.txt"
  register: pip_sync_result
  changed_when: "pip_sync_result.stdout != 'Everything up-to-date'"
  notify:
    - Restart website wsgireq.{{ testsite_domain }}

- name: Deploy WSGI application
  copy: src="hello.wsgi" dest="/var/www/wsgireq.{{ testsite_domain }}/code/wsgi.py"
        owner="admin-wsgireq_{{ testsite_domain_underscores }}" group="web-wsgireq_{{ testsite_domain_underscores }}" mode=640
  notify:
    - Restart website wsgireq.{{ testsite_domain }}