Skip to content
Snippets Groups Projects
Commit 0dacdea4 authored by nimrod's avatar nimrod
Browse files

Merge branch 'master' into feature/jenkinsfile

parents 7a3506a3 4d67f881
Branches
No related tags found
No related merge requests found
...@@ -9,3 +9,4 @@ __pycache__ ...@@ -9,3 +9,4 @@ __pycache__
.vagrant/ .vagrant/
*.log *.log
*.retry *.retry
.tox
- repo: https://github.com/pre-commit/pre-commit-hooks - repo: https://github.com/pre-commit/pre-commit-hooks
sha: 7539d8bd1a00a3c1bfd34cdb606d3a6372e83469 sha: v0.7.1
hooks: hooks:
- id: check-added-large-files - id: check-added-large-files
- id: check-json - id: check-json
...@@ -9,27 +9,15 @@ ...@@ -9,27 +9,15 @@
- id: flake8 - id: flake8
- id: check-symlinks - id: check-symlinks
- repo: https://github.com/adarnimrod/ansible-pre-commit.git - repo: https://github.com/adarnimrod/ansible-pre-commit.git
sha: 0fadd691465b97db8992cfc66650f630e433324b sha: v0.6.0
hooks: hooks:
- id: ansible-syntax-check - id: ansible-syntax-check
always_run: true
files: tests/playbook.yml
args:
- tests/playbook.yml
- repo: https://github.com/willthames/ansible-lint - repo: https://github.com/willthames/ansible-lint
sha: 959ab0f525e9abb19cf75f34381015cf33695f61 sha: v3.4.13
hooks: hooks:
- id: ansible-lint - id: ansible-lint
always_run: true
files: tests/playbook.yml files: tests/playbook.yml
args: - repo: https://github.com/adarnimrod/python-pre-commit.git
- tests/playbook.yml sha: v0.2.0
- repo: local
hooks: hooks:
- id: piprot - id: piprot
name: piprot
description: Check up-to-date Python requirements
language: system
entry: piprot --quiet --outdated tests/requirements.txt
files: requirements.txt
always_run: true
--- ---
language: python language: python
python: ["2.7", "3.5"] python: "2.7"
dist: trusty dist: trusty
sudo: True sudo: True
group: beta group: beta
services: [docker]
env: env:
- platform: openbsd60 global:
driver: vagrant - VBOX_MEMORY=2048
- platform: openbsd59 - VBOX_HWVIRTEX=off
driver: vagrant matrix:
- platform: xenial - TOXENV=pre-commit
driver: vagrant - TOXENV=openbsd60
- platform: trusty - TOXENV=xenial
driver: vagrant - TOXENV=trusty
- platform: jessie - TOXENV=precise
driver: vagrant - &stretch TOXENV=stretch
- platform: wheezy - &jessie TOXENV=jessie
driver: vagrant - TOXENV=wheezy
- driver: docker
platform: all
matrix: matrix:
fast_finish: True fast_finish: True
allow_failures: allow_failures:
- python: "3.5" - env: *stretch
- env: platform=openbsd59 driver=vagrant
- env: platform=jessie driver=vagrant
- env: platform=wheezy driver=vagrant
cache: cache:
- pip - pip
- directories: - directories:
...@@ -37,14 +31,12 @@ install: ...@@ -37,14 +31,12 @@ install:
- sudo apt-get install -y linux-headers-$(uname -r) virtualbox - sudo apt-get install -y linux-headers-$(uname -r) virtualbox
- wget https://releases.hashicorp.com/vagrant/1.9.1/vagrant_1.9.1_x86_64.deb - wget https://releases.hashicorp.com/vagrant/1.9.1/vagrant_1.9.1_x86_64.deb
- sudo dpkg -i vagrant_1.9.1_x86_64.deb - sudo dpkg -i vagrant_1.9.1_x86_64.deb
- pip install -r tests/requirements.txt | cat - pip install tox-travis | cat
- ansible-galaxy install git+file://$(pwd),$(git rev-parse --abbrev-ref HEAD) -p .molecule/roles
- molecule dependency
script: script:
- pre-commit run --all-files - travis_wait 45 tox
- molecule test --driver $driver --platform $platform
notifications: notifications:
webhooks: https://galaxy.ansible.com/api/v1/notifications/ webhooks: https://galaxy.ansible.com/api/v1/notifications/
email: false email: false
on_failure: never
...@@ -31,22 +31,9 @@ See :code:`tests/playbook.yml`. ...@@ -31,22 +31,9 @@ See :code:`tests/playbook.yml`.
Testing Testing
------- -------
Testing requires Python 2.7 and either Docker or Vagrant and Virtualbox. Testing requires Python 2.7, Tox, Vagrant and Virtualbox. To test simply run
Install the Python dependencies, dependent roles and roles required for :code:`tox`. `Pre-commit <http://pre-commit.com/>`_ is also setup for this
testing: project.
.. code:: shell
pip install -r tests/requirements.txt
ansible-galaxy install git+file://$(pwd),$(git rev-parse --abbrev-ref HEAD) -p .molecule/roles
molecule dependency
To run the full test suite:
.. code:: shell
pre-commit run --all-files
molecule test --platform all
License License
------- -------
......
...@@ -3,7 +3,7 @@ galaxy_info: ...@@ -3,7 +3,7 @@ galaxy_info:
description: An example Ansible role description: An example Ansible role
company: Shore technologies company: Shore technologies
license: MIT license: MIT
min_ansible_version: 2.0 min_ansible_version: 2.3
platforms: platforms:
- name: OpenBSD - name: OpenBSD
versions: versions:
...@@ -11,5 +11,12 @@ galaxy_info: ...@@ -11,5 +11,12 @@ galaxy_info:
- name: Ubuntu - name: Ubuntu
versions: versions:
- xenial - xenial
- trusty
- precise
- name: Debian
versions:
- stretch
- jessie
- wheezy
galaxy_tags: [ ansible ] galaxy_tags: [ ansible ]
dependencies: [] dependencies: []
...@@ -5,6 +5,10 @@ ansible: ...@@ -5,6 +5,10 @@ ansible:
diff: True diff: True
config_file: ../ansible.cfg config_file: ../ansible.cfg
molecule:
ignore_paths:
- .tox
dependency: dependency:
name: galaxy name: galaxy
requirements_file: tests/requirements.yml requirements_file: tests/requirements.yml
...@@ -18,40 +22,30 @@ vagrant: ...@@ -18,40 +22,30 @@ vagrant:
platforms: platforms:
- name: openbsd60 - name: openbsd60
box: fnichol/openbsd-6.0-i386 box: fnichol/openbsd-6.0-i386
- name: openbsd59
box: fnichol/openbsd-5.9-i386
- name: xenial - name: xenial
box: ubuntu/xenial32 box: ubuntu/xenial32
- name: trusty - name: trusty
box: ubuntu/trusty32 box: ubuntu/trusty32
- name: precise
box: hashicorp/precise32
- name: stretch
box: remram/debian-9-i386
- name: jessie - name: jessie
box: debian/jessie32 box: deb/jessie-i386
- name: wheezy - name: wheezy
box: debian/wheezy32 box: bmorg/debian-wheezy-i386
instances: instances:
- name: example - name: example
options: options:
append_platform_to_hostname: yes append_platform_to_hostname: yes
raw_config_args: raw_config_args:
- 'vm.boot_timeout = 600'
- 'vm.synced_folder ".", "/vagrant", disabled: true' - 'vm.synced_folder ".", "/vagrant", disabled: true'
- 'vbguest.auto_update = false if Vagrant.has_plugin?("vbguest")' - 'vbguest.auto_update = false if Vagrant.has_plugin?("vbguest")'
- 'landrush.enabled = false if Vagrant.has_plugin?("landrush")' - 'landrush.enabled = false if Vagrant.has_plugin?("landrush")'
- 'landrush_ip.override = false if Vagrant.has_plugin?("landrush")' - 'landrush_ip.override = false if Vagrant.has_plugin?("landrush")'
- | - |
vm.provider "virtualbox" do |v| vm.provider "virtualbox" do |v|
v.customize "pre-boot", ["modifyvm", :id, "--hwvirtex", "off"] v.customize "pre-boot", ["modifyvm", :id, "--hwvirtex", ENV['VBOX_HWVIRTEX']] if ENV.has_key?('VBOX_HWVIRTEX')
v.memory = ENV['VBOX_MEMORY'].to_i if ENV.has_key?('VBOX_MEMORY')
end end
docker:
containers:
- name: example-xenial
image: ubuntu
image_version: xenial
command: /sbin/init
privileged: True
volume_mounts:
- /sys/fs/cgroup:/sys/fs/cgroup
- /var/run/dbus/system_bus_socket:/var/run/dbus/system_bus_socket
environment:
DEBIAN_FRONTEND: noninteractive
container: docker
...@@ -5,4 +5,4 @@ ...@@ -5,4 +5,4 @@
assert: assert:
that: that:
- ansible_os_family in ['OpenBSD', 'Debian'] - ansible_os_family in ['OpenBSD', 'Debian']
- ansible_distribution_release in ['6.0', '5.9', 'xenial', 'trusty', 'jessie', 'wheezy'] - ansible_distribution_release in ['xenial', 'trusty', 'precise', 'stretch', 'jessie', 'wheezy'] or ansible_distribution_version in ['6.0']
--- ---
- hosts: example-openbsd* - hosts: example-openbsd*
gather_facts: false gather_facts: false
roles: [openbsd-bootstrap] roles:
- openbsd-bootstrap
- role: users
users: []
users_use_sudo: True
users_lock_root_ssh: False
- hosts: example-xenial - hosts: [example-xenial, example-wheezy]
gather_facts: false gather_facts: false
roles: [debian-bootstrap] roles:
- debian-bootstrap
- role: users
users: []
users_use_sudo: True
users_lock_root_ssh: False
- hosts: all - hosts: all
roles: roles:
......
ansible==2.2.0.0 ansible==2.3.0.0
testinfra==1.5.1 testinfra==1.6.0
molecule==1.17.3 molecule==1.24.0
ansible-lint==3.4.9 ansible-lint==3.4.13
pre-commit==0.10.1 python-vagrant==0.5.15
piprot==0.9.7 netaddr==0.7.19
python-vagrant==0.5.14 passlib==1.7.1
docker-py==1.10.6 bcrypt==3.1.3
netaddr==0.7.18
passlib==1.7.0
bcrypt==3.1.2
...@@ -3,3 +3,5 @@ ...@@ -3,3 +3,5 @@
name: openbsd-bootstrap name: openbsd-bootstrap
- src: adarnimrod.debian-bootstrap - src: adarnimrod.debian-bootstrap
name: debian-bootstrap name: debian-bootstrap
- src: adarnimrod.users
name: users
...@@ -3,10 +3,10 @@ from testinfra.utils.ansible_runner import AnsibleRunner ...@@ -3,10 +3,10 @@ from testinfra.utils.ansible_runner import AnsibleRunner
testinfra_hosts = AnsibleRunner('.molecule/ansible_inventory').get_hosts('all') testinfra_hosts = AnsibleRunner('.molecule/ansible_inventory').get_hosts('all')
def test_example(Command): def test_example(host):
assert Command('uname').rc == 0 assert host.run('uname').rc == 0
def test_root(Command, Sudo): def test_root(host):
with Sudo(): with host.sudo():
assert Command('whoami').stdout.strip() == 'root' assert host.run('whoami').stdout.strip() == 'root'
tox.ini 0 → 100644
[tox]
skip_install = True
skipsdist = True
envlist = openbsd60,xenial,trusty,precise,stretch,jessie,wheezy
[testenv]
envdir = {toxinidir}/.tox/molecule
deps = -rtests/requirements.txt
passenv = HOME VBOX* ANSIBLE_*
whitelist_externals =
sh
commands =
sh -c "ansible-galaxy install git+file://$(pwd),$(git rev-parse --abbrev-ref HEAD) -p .molecule/roles"
molecule test --platform {envname}
[testenv:pre-commit]
deps =
-rtests/requirements.txt
pre-commit
passenv = HOME VBOX* ANSIBLE_*
whitelist_externals =
sh
commands =
sh -c "ansible-galaxy install git+file://$(pwd),$(git rev-parse --abbrev-ref HEAD) -p .molecule/roles"
molecule dependency
pre-commit run --all-files
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment