From a high level, the builds:
-* Boot a specified base image in the cloud
-* Run a set of shell scripts, listed in the template's shell provisioner
- section, to do any configuration required by the builder.
-* Execute a shutdown of the running instance
-* Execute a 'nova image-create' operation against the shutdown instance.
-* Perform a 'nova delete' operation against the shutdown instance.
+- Boot a specified base image in the cloud
+- Run a set of shell scripts, listed in the template's shell provisioner
+ section, to do any configuration required by the builder.
+- Execute a shutdown of the running instance
+- Execute a 'nova image-create' operation against the shutdown instance.
+- Perform a 'nova delete' operation against the shutdown instance.
[1]: https://www.packer.io/
[2]: https://www.packer.io/intro/getting-started/setup.html
chartmuseum_version: 0.15.0
tasks:
- - name: 'Install kubectl {{kubectl_version}}'
+ - name: "Install kubectl {{kubectl_version}}"
get_url:
url: "https://storage.googleapis.com/kubernetes-release/release/v{{kubectl_version}}/bin/linux/amd64/kubectl"
dest: /usr/local/bin/kubectl
mode: 0775
- become: yes
+ become: true
- - name: 'Install Helm3.8 {{helm3_8_version}}'
+ - name: "Install Helm3.8 {{helm3_8_version}}"
block:
- - name: 'Create directory /tmp/helm3.8'
+ - name: "Create directory /tmp/helm3.8"
file:
path: /tmp/helm3.8
state: directory
- - name: 'Fetch tar.gz for Helm 3.8'
+ - name: "Fetch tar.gz for Helm 3.8"
get_url:
url: "https://get.helm.sh/helm-v{{helm3_8_version}}-linux-amd64.tar.gz"
dest: /tmp/helm3.8
- - name: 'Unarchive Helm 3.8'
+ - name: "Unarchive Helm 3.8"
unarchive:
src: "/tmp/helm3.8/helm-v{{helm3_8_version}}-linux-amd64.tar.gz"
dest: /tmp/helm3.8
remote_src: true
- become: yes
- - name: 'Move Helm 3.8 bin to /usr/local/bin and set as executable'
- command: 'mv /tmp/helm3.8/linux-amd64/helm /usr/local/bin/helm3.8'
- become: yes
- - name: 'Check Helm 3.8'
- command: 'which helm3.8'
- - name: 'Check kubectl {{kubectl_version}}'
- command: 'which kubectl'
+ become: true
+ - name: "Move Helm 3.8 bin to /usr/local/bin and set as executable"
+ command: "mv /tmp/helm3.8/linux-amd64/helm /usr/local/bin/helm3.8"
+ become: true
+ - name: "Check Helm 3.8"
+ command: "which helm3.8"
+ - name: "Check kubectl {{kubectl_version}}"
+ command: "which kubectl"
- - name: 'Install Helm 3.8'
+ - name: "Install Helm 3.8"
shell: |
- echo "----> Installing helm3.8"
- wget 'https://get.helm.sh/helm-v{{helm3_8_version}}-linux-amd64.tar.gz'
- tar -xvf 'https://get.helm.sh/helm-v{{helm3_8_version}}-linux-amd64.tar.gz'
- mv linux-amd64/helm /usr/local/bin/helm3.8
- which helm3.8
+ echo "----> Installing helm3.8"
+ wget 'https://get.helm.sh/helm-v{{helm3_8_version}}-linux-amd64.tar.gz'
+ tar -xvf 'https://get.helm.sh/helm-v{{helm3_8_version}}-linux-amd64.tar.gz'
+ mv linux-amd64/helm /usr/local/bin/helm3.8
+ which helm3.8
become: true
-
- - name: 'Install ChartMuseum {{chartmuseum_version}}'
+ - name: "Install ChartMuseum {{chartmuseum_version}}"
block:
- - name: 'Create directory /tmp/chartmuseum'
+ - name: "Create directory /tmp/chartmuseum"
file:
path: /tmp/chartmuseum
state: directory
- - name: 'Fetch tar.gz for chartmuseum'
+ - name: "Fetch tar.gz for chartmuseum"
get_url:
url: "https://get.helm.sh/chartmuseum-v{{chartmuseum_version}}-linux-amd64.tar.gz"
dest: /tmp/chartmuseum
- - name: 'Unarchive chartmuseum'
+ - name: "Unarchive chartmuseum"
unarchive:
src: "/tmp/chartmuseum/chartmuseum-v{{chartmuseum_version}}-linux-amd64.tar.gz"
dest: /tmp/chartmuseum
remote_src: true
- become: yes
- - name: 'Move chartmuseum bin to /usr/local/bin and set as executable'
- command: 'mv /tmp/chartmuseum/linux-amd64/chartmuseum /usr/local/bin/chartmuseum'
- become: yes
- - name: 'Check ChartMuseum {{chartmuseum_version}}'
- command: 'which chartmuseum'
+ become: true
+ - name: "Move chartmuseum bin to /usr/local/bin and set as executable"
+ command: "mv /tmp/chartmuseum/linux-amd64/chartmuseum /usr/local/bin/chartmuseum"
+ become: true
+ - name: "Check ChartMuseum {{chartmuseum_version}}"
+ command: "which chartmuseum"
- name: Update and upgrade apt packages
apt:
- upgrade: 'yes'
- update_cache: yes
+ upgrade: "yes"
+ update_cache: true
become: true
when: ansible_distribution == 'Ubuntu'
- name: Install libssl1.0-dev dep
apt:
name: libssl1.0-dev
- update_cache: yes
+ update_cache: true
state: fixed
become: true
when: ansible_distribution == 'Ubuntu' and ansible_distribution_version == '18.04'
- crudini
- maven
- python-ncclient
- update_cache: yes
+ update_cache: true
state: fixed
become: true
when: ansible_distribution == 'Ubuntu' and ansible_distribution_version == '18.04'
- crudini
- maven
- python3-ncclient
- update_cache: yes
+ update_cache: true
state: fixed
become: true
when: ansible_distribution == 'Ubuntu' and ansible_distribution_version == '20.04'
- name: Install nodejs and npm
block:
- - name: 'Pull latest nodejs version'
+ - name: "Pull latest nodejs version"
shell: |
curl -sL https://deb.nodesource.com/setup_10.x | sudo -E bash - && sudo apt-get install -y nodejs
- become: yes
- - name: 'Check nodejs version'
+ become: true
+ - name: "Check nodejs version"
command: node --version
- - name: 'Check npm version'
+ - name: "Check npm version"
command: npm --version
when: ansible_distribution == 'Ubuntu'
- name: Install npm build tools
apt:
name: build-essential
- update_cache: yes
+ update_cache: true
state: fixed
become: true
when: ansible_distribution == 'Ubuntu'
apt:
name:
- enchant-2
- update_cache: yes
+ update_cache: true
state: present
become: true
when: ansible_distribution == 'Ubuntu' and ansible_distribution_version == '20.04'
apt:
name:
- enchant
- update_cache: yes
+ update_cache: true
state: present
become: true
when: ansible_distribution == 'Ubuntu' and ansible_distribution_version == '18.04'
dnf:
name:
- enchant2
- update_cache: yes
+ update_cache: true
state: present
become: true
when: ansible_distribution == 'CentOS'
golang_checksum: sha256:d31ecae36efea5197af271ccce86ccc2baf10d2e04f20d0fb75556ecf0614dad
when: "'aarch64' in ansible_architecture"
- - name: 'Install Docker Compose {{docker_compose_version}}'
+ - name: "Install Docker Compose {{docker_compose_version}}"
+ # yamllint disable-line rule:line-length
command: curl -o /usr/local/bin/docker-compose -L "https://github.com/docker/compose/releases/download/{{docker_compose_version}}/docker-compose-Linux-x86_64"
become: true
mode: "+x"
become: true
- - name: 'Install GoLang {{golang_version}}'
+ - name: "Install GoLang {{golang_version}}"
block:
- - name: 'Fetch golang {{golang_version}} to /tmp/go{{golang_version}}.linux-{{host_arch}}.tar.gz'
+ - name: "Fetch golang {{golang_version}} to /tmp/go{{golang_version}}.linux-{{host_arch}}.tar.gz"
get_url:
- url: 'https://storage.googleapis.com/golang/go{{golang_version}}.linux-{{host_arch}}.tar.gz'
- dest: '/tmp/go{{golang_version}}.linux-{{host_arch}}.tar.gz'
- checksum: '{{golang_checksum}}'
- - name: 'Install golang {{golang_version}} to /usr/local'
+ url: "https://storage.googleapis.com/golang/go{{golang_version}}.linux-{{host_arch}}.tar.gz"
+ dest: "/tmp/go{{golang_version}}.linux-{{host_arch}}.tar.gz"
+ checksum: "{{golang_checksum}}"
+ - name: "Install golang {{golang_version}} to /usr/local"
unarchive:
- src: '/tmp/go{{golang_version}}.linux-{{host_arch}}.tar.gz'
+ src: "/tmp/go{{golang_version}}.linux-{{host_arch}}.tar.gz"
dest: /usr/local
remote_src: true
become: true
- name: Update and upgrade apt packages
apt:
- upgrade: 'yes'
- update_cache: yes
+ upgrade: "yes"
+ update_cache: true
become: true
when: ansible_distribution == 'Ubuntu'
- crudini
- maven
- python-ncclient
- update_cache: yes
+ update_cache: true
state: fixed
become: true
when: ansible_distribution == 'Ubuntu' and ansible_distribution_version == '18.04'
- crudini
- maven
- python3-ncclient
- update_cache: yes
+ update_cache: true
state: fixed
become: true
when: ansible_distribution == 'Ubuntu' and ansible_distribution_version == '20.04'
name:
- apt-transport-https
- g++
- update_cache: yes
+ update_cache: true
state: present
become: true
- name: add nodejs apt key
apt_repository:
repo: deb https://deb.nodesource.com/node_19.x {{ ansible_distribution_release }} main
state: present
- update_cache: yes
+ update_cache: true
become: true
- name: install nodejs
apt:
- name: Check nodejs and npm versions
block:
- - name: 'Check nodejs version'
+ - name: "Check nodejs version"
command: node --version
- - name: 'Check npm version'
+ - name: "Check npm version"
command: npm --version
when: ansible_distribution == 'Ubuntu'
- name: Install npm build tools
apt:
name: build-essential
- update_cache: yes
+ update_cache: true
state: fixed
become: true
when: ansible_distribution == 'Ubuntu'
when: ansible_architecture == 'x86_64' and ansible_distribution == 'Ubuntu'
- name: Add Google Chrome repo
+ # yamllint disable-line rule:line-length
copy: content="deb http://dl.google.com/linux/chrome/deb/ stable main" dest={{apt_file}} owner=root group=root mode=644
become: true
when: ansible_architecture == 'x86_64' and ansible_distribution == 'Ubuntu'
name:
- libwxgtk3.0-0v5
become: true
+ # yamllint disable-line rule:line-length
when: ansible_architecture == 'x86_64' and ansible_distribution == 'Ubuntu' and ansible_distribution_version == '18.04'
- name: Install Erlang dependency package libwxgtk3 for 20.04
name:
- libwxgtk3.0-gtk3-0v5
become: true
+ # yamllint disable-line rule:line-length
when: ansible_architecture == 'x86_64' and ansible_distribution == 'Ubuntu' and ansible_distribution_version == '20.04'
- name: Download and install libssl Ubuntu 20.04
apt:
deb: http://security.ubuntu.com/ubuntu/pool/main/o/openssl1.0/libssl1.0.0_1.0.2n-1ubuntu5.11_amd64.deb
become: true
+ # yamllint disable-line rule:line-length
when: ansible_architecture == 'x86_64' and ansible_distribution == 'Ubuntu' and ansible_distribution_version == '20.04'
- name: Install Erlang
become: true
when: ansible_architecture == 'x86_64' and ansible_distribution == 'Ubuntu'
- - name: 'Download latest rebar3 bin'
+ - name: "Download latest rebar3 bin"
command: curl -o /usr/bin/rebar3 -L "https://s3.amazonaws.com/rebar3/rebar3"
become: true
when: ansible_architecture == 'x86_64' and ansible_distribution == 'Ubuntu'
src: https://github.com/mozilla/geckodriver/releases/download/v0.18.0/geckodriver-v0.18.0-linux64.tar.gz
dest: /usr/bin
mode: 0755
- remote_src: yes
+ remote_src: true
become: true
when: ansible_architecture == 'x86_64' and ansible_distribution == 'Ubuntu'
- name: Download Firefox version 55.0.3
unarchive:
+ # yamllint disable-line rule:line-length
src: https://download-installer.cdn.mozilla.net/pub/firefox/releases/55.0.3/linux-x86_64/en-US/firefox-55.0.3.tar.bz2
dest: /opt
mode: 0755
- remote_src: yes
+ remote_src: true
become: true
when: ansible_architecture == 'x86_64' and ansible_distribution == 'Ubuntu'
become_method: sudo
tasks:
- - name: 'Install Memcached'
+ - name: "Install Memcached"
package:
name: memcached
state: present
become_method: sudo
tasks:
- - name: 'Install Redis'
+ - name: "Install Redis"
package:
name: redis
state: present
become: true
- - name: 'Enable service redis'
+ - name: "Enable service redis"
service:
name: redis
- enabled: yes
+ enabled: true
become: true
- - name: 'Start service redis'
+ - name: "Start service redis"
service:
name: redis
state: started
name:
- epel-release
- python36
- update_cache: yes
+ update_cache: true
state: latest
become: true
"tenant_name": "{{user `cloud_tenant`}}",
"domain_name": "Default",
"region": "ca-ymq-1",
- "networks": [
- "{{user `cloud_network`}}"
- ],
+ "networks": ["{{user `cloud_network`}}"],
"user_data_file": "{{user `cloud_user_data`}}",
"ssh_username": "{{user `ssh_user`}}",
"ssh_proxy_host": "{{user `ssh_proxy_host`}}",
"tenant_name": "{{user `cloud_tenant`}}",
"domain_name": "Default",
"region": "ca-ymq-1",
- "networks": [
- "{{user `cloud_network`}}"
- ],
+ "networks": ["{{user `cloud_network`}}"],
"user_data_file": "{{user `cloud_user_data`}}",
"ssh_username": "{{user `ssh_user`}}",
"ssh_proxy_host": "{{user `ssh_proxy_host`}}",
"tenant_name": "{{user `cloud_tenant`}}",
"domain_name": "Default",
"region": "ca-ymq-1",
- "networks": [
- "{{user `cloud_network`}}"
- ],
+ "networks": ["{{user `cloud_network`}}"],
"user_data_file": "{{user `cloud_user_data`}}",
"ssh_username": "{{user `ssh_user`}}",
"ssh_proxy_host": "{{user `ssh_proxy_host`}}",