Extending ansible playbooks of ubuntu support.
Issue-ID: OOM-1671
Signed-off-by: Jan Benedikt <j.benedikt@partner.samsung.com>
Change-Id: I6028736b54ce825d3eae257ca61cb6efab19a913
 # Systemd requires this env for ConditionVirtualization setting in unit files
 ENV container docker
 
-# Python2.7 required by ansible
-RUN apt-get update && apt-get -y install dbus systemd python openssh-server
+# Install necessary packages
+RUN apt-get update && apt-get -y install dbus systemd openssh-server
+
+# Create symlink python3 -> python
+RUN ln -s /usr/bin/python3 /usr/bin/python
 
 EXPOSE 22
 
 
 ---
-# Needed because host system has all mounts by default to shared, and
-# some things may depend on mounts being shared if we run docker inside
-# test env.
-- name: "Make all mounts shared"
-  command: "mount --make-rshared /"
-  args:
-    warn: false
+- include: rhel.yml
+  when: ansible_distribution in ["CentOS","Red Hat Enterprise Linux"]
 
-- name: "Enable docker repository"
-  yum_repository:
-    name: "Docker"
-    description: Docker-ce repository
-    enabled: yes
-    baseurl: "https://download.docker.com/linux/centos/7/$basearch/stable"
-    gpgcheck: yes
-    gpgkey: https://download.docker.com/linux/centos/gpg
-
-- name: "Install docker"
-  package:
-    name: "docker-ce-{{ docker_version }}"
-    state: present
-    allow_downgrade: true
-  notify: Restart docker
+- include: ubuntu.yml
+  when: ansible_distribution in ["Ubuntu","Debian"]
\ No newline at end of file
 
--- /dev/null
+---
+# Needed because host system has all mounts by default to shared, and
+# some things may depend on mounts being shared if we run docker inside
+# test env.
+- name: "Make all mounts shared"
+  command: "mount --make-rshared /"
+  args:
+    warn: false
+
+- name: "Enable docker repository - yum"
+  yum_repository:
+    name: "Docker"
+    description: Docker-ce repository
+    enabled: yes
+    baseurl: "https://download.docker.com/linux/centos/7/$basearch/stable"
+    gpgcheck: yes
+    gpgkey: https://download.docker.com/linux/centos/gpg
+
+- name: "Install docker"
+  package:
+    name: "docker-ce-{{ docker_version }}"
+    state: present
+    allow_downgrade: true
+  notify: Restart docker
 
--- /dev/null
+---
+# Needed because host system has all mounts by default to shared, and
+# some things may depend on mounts being shared if we run docker inside
+# test env.
+- name: "Make all mounts shared"
+  command: "mount --make-rshared /"
+  args:
+    warn: false
+
+- name: "Install GNUPG for apt-key"
+  package:
+    name: "gnupg"
+    state: present
+
+- name: "Add an apt key"
+  apt_key:
+      url: https://download.docker.com/linux/ubuntu/gpg
+      id: 9DC858229FC7DD38854AE2D88D81803C0EBFCD88
+      state: present
+
+- name: "Enable docker repository - apt"
+  apt_repository:
+    repo: "deb [arch=amd64] https://download.docker.com/linux/ubuntu bionic stable"
+    state: present
+    validate_certs: true
+    filename: "Docker"
+
+- name: "Install docker - apt"
+  apt:
+    name: "docker-ce"
+    state: present
+    update_cache: true
+  notify: Restart docker