DCD-224: Refactor to simplify directory layout and testing.

This commit is contained in:
Steve Smith
2019-04-16 10:52:18 +10:00
parent f2a9dbd1b6
commit 5b91a531ce
8 changed files with 48 additions and 20 deletions

View File

@@ -19,6 +19,8 @@ provisioner:
group_vars: ../../../../group_vars/
verifier:
name: testinfra
additional_files_or_dirs:
- ../../resources/tests/test_*.py
lint:
name: flake8
enabled: false

View File

@@ -7,11 +7,6 @@ testinfra_hosts = testinfra.utils.ansible_runner.AnsibleRunner(
os.environ['MOLECULE_INVENTORY_FILE']).get_hosts('all')
def test_version_downloaded(host):
verfile = host.file('/media/atl/jira/shared/jira-software.version')
assert verfile.exists
def test_version_file_is_latest(host):
verfile = host.file('/media/atl/jira/shared/jira-software.version')
assert verfile.exists
@@ -28,4 +23,3 @@ def test_latest_is_downloaded(host):
installer = host.file('/opt/atlassian/tmp/jira-software.'+upstream+'.tar.gz')
assert installer.exists
assert installer.user == 'root'
assert installer.mode == 0o0755

View File

@@ -0,0 +1,17 @@
import os
import urllib.request
import testinfra.utils.ansible_runner
testinfra_hosts = testinfra.utils.ansible_runner.AnsibleRunner(
os.environ['MOLECULE_INVENTORY_FILE']).get_hosts('all')
def test_version_downloaded(host):
verfile = host.file('/media/atl/jira/shared/jira-software.version')
assert verfile.exists
def test_symlink_created(host):
target = host.file('/opt/atlassian/jira-software/current')
assert target.exists
assert target.is_symlink

View File

@@ -19,6 +19,8 @@ provisioner:
group_vars: ../../../../group_vars/
verifier:
name: testinfra
additional_files_or_dirs:
- ../../resources/tests/test_*.py
lint:
name: flake8
enabled: false

View File

@@ -7,24 +7,19 @@ testinfra_hosts = testinfra.utils.ansible_runner.AnsibleRunner(
os.environ['MOLECULE_INVENTORY_FILE']).get_hosts('all')
def test_version_downloaded(host):
verfile = host.file('/media/atl/jira/shared/jira-software.version')
assert verfile.exists
def test_version_is_latest(host):
def test_version_is_correct(host):
verfile = host.file('/media/atl/jira/shared/jira-software.version')
assert verfile.exists
assert verfile.content.decode("UTF-8").strip() == "7.13.2"
def test_latest_is_downloaded(host):
def test_is_downloaded(host):
installer = host.file('/opt/atlassian/tmp/jira-software.7.13.2.tar.gz')
assert installer.exists
assert installer.user == 'root'
def test_latest_is_unpacked(host):
installer = host.file('/opt/atlassian/jira-software/atlassian-jira-software-7.13.2-standalone')
def test_is_unpacked(host):
installer = host.file('/opt/atlassian/jira-software/7.13.2')
assert installer.exists
assert installer.is_directory
assert installer.user == 'jira'

View File

@@ -30,11 +30,27 @@
mode: 0644
force: false
- name: Create target version directory
file:
path: "{{ atl_product_installation_base }}/{{ atl_product_version_file.stdout }}"
state: directory
owner: "{{ atl_product_user }}"
- name: Unpack the product packages
unarchive:
remote_src: true
src: "{{ atl_product_download }}"
dest: "{{ atl_product_installation_dir }}"
dest: "{{ atl_product_installation_base }}/{{ atl_product_version_file.stdout }}"
owner: "{{ atl_product_user }}"
group: "{{ atl_product_user }}"
mode: 0755
# Strip off the lead product/version specific directory to normaise naming
extra_opts:
- "--strip-components=1"
- name: Symlink the installed version to current
file:
src: "{{ atl_product_installation_base }}/{{ atl_product_version_file.stdout }}"
dest: "{{ atl_product_installation_target }}"
state: link
force: true