ansible-experiments/package_updates
Bryan Black 58ce5f14f2
fix for 'No updates are available to install' error
resolves common problem of false `No updates are available to install` errors after updating FreeBSD base OS files.

```yml
TASK [freebsd-update : Install FreeBSD updates] ****************************************************
fatal: [freebsd6]: FAILED! => {"changed": true, "cmd": ["freebsd-update", "install", "--not-running-from-cron"], "delta": "0:00:00.274477", "end": "2018-05-14 18:13:56.977638", "msg": "non-zero return code", "rc": 1, "start": "2018-05-14 18:13:56.703161", "stderr": "rm: filelist: No such file or directory", "stderr_lines": ["rm: filelist: No such file or directory"], "stdout": "src component not installed, skipped\nInstalling updates...", "stdout_lines": ["src component not installed, skipped", "Installing updates..."]}
changed: [freebsd5]

TASK [freebsd-update : debug] **********************************************************************
```
2018-05-14 11:29:22 -07:00
..
roles fix for 'No updates are available to install' error 2018-05-14 11:29:22 -07:00
ansible.cfg Update packages on ubuntu and freebsd 2018-05-11 16:37:03 +02:00
base-setup.yml install correct dependency version 2018-05-12 14:34:13 +02:00
hosts Update packages on ubuntu and freebsd 2018-05-11 16:37:03 +02:00
hosts-vagrant Update packages on ubuntu and freebsd 2018-05-11 16:37:03 +02:00
os_upgrade.yml Fix typo - Ubuntu dynamic group name 2018-05-12 13:12:08 +02:00
README.md setup script does all from vagrant up to check upgrade' 2018-05-12 14:33:13 +02:00
setup-requirements setup script does all from vagrant up to check upgrade' 2018-05-12 14:33:13 +02:00
Vagrantfile avoid provisioning timeout for freebsd 2018-05-12 12:50:57 +02:00

Update packages on ubuntu and freebsd

🔬 #1

The Vagrant file being used is a copy from https://github.com/stationgroup/vagrant-labs/tree/master/imperialspeculate.

Two roles are being used: debian-upgrade (an upstream Galaxy role) and freebsd-upgrade (a small role based on what was proposed in the comments of #1 and extended with proper support for check mode.)

The upgrade process is contained in the playbook os_upgrade.yml, which will automatically create proper groups for Ubuntu and FreeBSD hosts. If unneeded, this first play can be left out, and the target hosts: in the second play can be replaced by the relevant groups you have in the inventory (e.g. ec2 tags.)

A local ansible.cfg is defined, and needed for these scripts to run out of the box. This implies that all ansible commands must be run from the ansible-experiments/package_updates folder.

A small script setup-requirements is provided, that initializes everything, including doing a vagrant up. It will generate an ssh-config for said vagrant boxes, download roles from galaxy, and make a base-install for the hosts (installing python dependencies, ansible itself on ubuntu1, a deploying an ssh key to all nodes to be used from the vagrant box ubuntu1, as ansible controller machine.)

When deploying and setting up from the machine where vagrant runs, you need to add some extra arguments: --ssh-extra-args "-F ./vagrant-ssh-config" --inventory hosts-vagrant to ansible execution. These are not necessary once running ansible from ubuntu1.