Adding Ubuntu support in Ansible - package-repository role 78/101478/18
authorJan Benedikt <j.benedikt@partner.samsung.com>
Mon, 10 Feb 2020 15:29:43 +0000 (16:29 +0100)
committerJan Benedikt <j.benedikt@partner.samsung.com>
Mon, 18 May 2020 07:21:52 +0000 (09:21 +0200)
Extending ansible playbooks of ubuntu support.
Creating new test with Ubuntu image for Molecule in package-repository role.

Issue-ID: OOM-1671
Signed-off-by: Jan Benedikt <j.benedikt@partner.samsung.com>
Change-Id: I85d4e6857536fa06c7eb4f4042c1ed64fcbf903e

ansible/roles/package-repository/defaults/main.yml
ansible/roles/package-repository/molecule/default/Dockerfile.j2
ansible/roles/package-repository/molecule/default/molecule.yml
ansible/roles/package-repository/molecule/default/tests/test_infrastructure-server.py
ansible/roles/package-repository/molecule/default/tests/test_kubernetes-node-1.py
ansible/roles/package-repository/molecule/ubuntu/molecule.yml [new file with mode: 0644]
ansible/roles/package-repository/tasks/Debian.yml [new file with mode: 0644]
ansible/roles/package-repository/tasks/RedHat.yml [new file with mode: 0644]
ansible/roles/package-repository/tasks/main.yml

index 0557eda..97b89ba 100644 (file)
@@ -1,8 +1,17 @@
 ---
+package_type:
+  RedHat: rpm
+  Debian: deb
+repo_patern:
+  RedHat: "*.repo"
+  Debian: "*.list"
+repo_path:
+  RedHat: /etc/yum.repos.d/
+  Debian: /etc/apt/
 package_repositories:
   - name: "{{ app_name }}"
     file: "{{ app_name | lower }}"
     description: "{{ app_name | upper }} offline repository"
-    baseurl: "{{ 'http://repo.infra-server/rpm' if 'infrastructure' not in group_names else 'file://' + app_data_path + '/pkg/rpm' }}"
+    baseurl: "{{ 'http://repo.infra-server/' + package_type[ansible_os_family] if 'infrastructure' not in group_names else 'file://' + app_data_path + '/pkg/' + package_type[ansible_os_family] }}"
     gpgcheck: false
     enabled: true
index 0a60553..b76a6dd 100644 (file)
@@ -6,9 +6,12 @@ FROM {{ item.registry.url }}/{{ item.image }}
 FROM {{ item.image }}
 {% endif %}
 
-RUN if [ $(command -v apt-get) ]; then apt-get update && apt-get install -y python sudo bash ca-certificates && apt-get clean; \
+RUN if [ $(command -v apt-get) ]; then apt-get update && apt-get install -y sudo bash ca-certificates python3-apt && apt-get clean; \
     elif [ $(command -v dnf) ]; then dnf makecache && dnf --assumeyes install python sudo python-devel python2-dnf bash && dnf clean all; \
     elif [ $(command -v yum) ]; then yum makecache fast && yum install -y python sudo yum-plugin-ovl bash && sed -i 's/plugins=0/plugins=1/g' /etc/yum.conf && yum clean all; \
     elif [ $(command -v zypper) ]; then zypper refresh && zypper install -y python sudo bash python-xml && zypper clean -a; \
     elif [ $(command -v apk) ]; then apk update && apk add --no-cache python sudo bash ca-certificates; \
     elif [ $(command -v xbps-install) ]; then xbps-install -Syu && xbps-install -y python sudo bash ca-certificates && xbps-remove -O; fi
+
+# Create symlink python3 -> python
+RUN if [ $(command -v apt-get) ]; then ln -s /usr/bin/python3 /usr/bin/python; fi
index df2024d..7abb08d 100644 (file)
@@ -36,8 +36,6 @@ provisioner:
       all:
         app_name: moleculetestapp
         app_data_path: "/opt/{{ app_name }}"
-scenario:
-  name: default
 verifier:
   name: testinfra
   options:
index 9fb1a4f..5b3fce4 100644 (file)
@@ -7,10 +7,17 @@ testinfra_hosts = testinfra.utils.ansible_runner.AnsibleRunner(
 
 
 def test_onap_repo(host):
-    fc = host.file('/etc/yum.repos.d/moleculetestapp.repo').content_string
-    expected_content = """[moleculetestapp]
+    os = host.system_info.distribution
+    if os == "centos":
+        fc = host.file('/etc/yum.repos.d/moleculetestapp.repo').content_string
+        expected_content = """[moleculetestapp]
 baseurl = file:///opt/moleculetestapp/pkg/rpm
 enabled = 1
 gpgcheck = 0
 name = MOLECULETESTAPP offline repository"""
-    assert fc == expected_content
+        assert fc == expected_content
+    elif os == "ubuntu":
+        fc = host.file('/etc/apt/sources.list.d/moleculetestapp.list')
+        fc = fc.content_string
+        ec = "deb [trusted=yes] file:///opt/moleculetestapp/pkg/deb ./"
+        assert fc == ec
index fda85e8..c1831f7 100644 (file)
@@ -7,10 +7,17 @@ testinfra_hosts = testinfra.utils.ansible_runner.AnsibleRunner(
 
 
 def test_onap_repo(host):
-    fc = host.file('/etc/yum.repos.d/moleculetestapp.repo').content_string
-    expected_content = """[moleculetestapp]
+    os = host.system_info.distribution
+    if os == "centos":
+        fc = host.file('/etc/yum.repos.d/moleculetestapp.repo').content_string
+        expected_content = """[moleculetestapp]
 baseurl = http://repo.infra-server/rpm
 enabled = 1
 gpgcheck = 0
 name = MOLECULETESTAPP offline repository"""
-    assert fc == expected_content
+        assert fc == expected_content
+    elif os == "ubuntu":
+        fc = host.file('/etc/apt/sources.list.d/moleculetestapp.list')
+        fc = fc.content_string
+        ec = "deb [trusted=yes] http://repo.infra-server/deb ./"
+        assert fc == ec
diff --git a/ansible/roles/package-repository/molecule/ubuntu/molecule.yml b/ansible/roles/package-repository/molecule/ubuntu/molecule.yml
new file mode 100644 (file)
index 0000000..07c2d88
--- /dev/null
@@ -0,0 +1,51 @@
+---
+dependency:
+  name: galaxy
+driver:
+  name: docker
+lint:
+  name: yamllint
+platforms:
+  - name: infrastructure-server
+    image: ${PLATFORM_DISTRO:-ubuntu}:${ISTRO_VERSION:-18.04}
+    dockerfile: ../default/Dockerfile.j2
+    groups:
+      - infrastructure
+    # By design certain file like /etc/resolv.conf cannot be edited in docker
+    # container. To enable role to "edit" /etc/resolv.conf define value already to same.
+    dns_servers:
+      - 6.5.4.3
+
+  - name: kubernetes-node-1
+    image: ${PLATFORM_DISTRO:-ubuntu}:${ISTRO_VERSION:-18.04}
+    dockerfile: ../default/Dockerfile.j2
+    groups:
+      - kubernetes
+    # By design certain file like /etc/resolv.conf cannot be edited in docker
+    # container. To enable role to "edit" /etc/resolv.conf define value already to same.
+    dns_servers:
+      - 6.5.4.3
+
+provisioner:
+  name: ansible
+  lint:
+    name: ansible-lint
+  playbooks:
+    converge: ../default/playbook.yml
+  inventory:
+    host_vars:
+      infrastructure-server:
+        cluster_ip: 6.5.4.3
+    group_vars:
+      all:
+        app_name: moleculetestapp
+        app_data_path: "/opt/{{ app_name }}"
+scenario:
+  name: ubuntu
+verifier:
+  name: testinfra
+  options:
+    verbose: true
+  lint:
+    name: flake8
+  directory: ../default/tests
diff --git a/ansible/roles/package-repository/tasks/Debian.yml b/ansible/roles/package-repository/tasks/Debian.yml
new file mode 100644 (file)
index 0000000..76323eb
--- /dev/null
@@ -0,0 +1,8 @@
+---
+- name: Add application offline package repository
+  apt_repository:
+    repo: "deb [trusted=yes] {{ item.baseurl | default('') }} ./"
+    state: "{{ item.state | default('present') }}"
+    filename: "{{ item.file }}"
+    update_cache: false
+  loop: "{{ package_repositories }}"
diff --git a/ansible/roles/package-repository/tasks/RedHat.yml b/ansible/roles/package-repository/tasks/RedHat.yml
new file mode 100644 (file)
index 0000000..49b2971
--- /dev/null
@@ -0,0 +1,11 @@
+---
+- name: Add application offline package repository
+  yum_repository:
+    name: "{{ item.name }}"
+    file: "{{ item.file }}"
+    description: "{{ item.description | default('') }}"
+    baseurl: "{{ item.baseurl | default('') }}"
+    gpgcheck: "{{ item.gpgcheck | default(true) }}"
+    enabled: "{{ item.enabled | default(false) }}"
+    state: "{{ item.state | default('present') }}"
+  loop: "{{ package_repositories }}"
index e2a5fd4..763ee65 100644 (file)
     insertbefore: BOF
     unsafe_writes: true
 
-- name: Disable all OS default repositories
+- name: Disable all default repositories
   block:
     - name: Find repo files names
       find:
-        paths: /etc/yum.repos.d
-        pattern: '*.repo'
+        paths: "{{ repo_path[ansible_os_family] }}"
+        pattern: "{{ repo_patern[ansible_os_family] }}"
       register: repo_files
 
     - name: Get all defined offline repo names
       loop: "{{ repo_files.files }}"
       when: "(item.path | basename | splitext)[0] not in package_repositories_names"
 
-- name: Add application offline package repository
-  yum_repository:
-    name: "{{ item.name }}"
-    file: "{{ item.file }}"
-    description: "{{ item.description | default('') }}"
-    baseurl: "{{ item.baseurl | default('') }}"
-    gpgcheck: "{{ item.gpgcheck | default(true) }}"
-    enabled: "{{ item.enabled | default(false) }}"
-    state: "{{ item.state | default('present') }}"
-  loop: "{{ package_repositories }}"
+- include_tasks: "{{ ansible_os_family }}.yml"