diff --git a/.gitignore b/.gitignore index e1cf205905d93c46016f27f9e4df6a1da11cfd86..966ef052e8cb1dfe9ab17eff54ee874231f5dbb0 100644 --- a/.gitignore +++ b/.gitignore @@ -9,3 +9,4 @@ __pycache__ .vagrant/ *.log *.retry +.tox diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index bd9a4d714377ea51d2cd14419ae059cc9307b5d5..13dbdf1997b4d7115d467b019b31712b08540e26 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -13,7 +13,7 @@ hooks: - id: ansible-syntax-check - repo: https://github.com/willthames/ansible-lint - sha: v3.4.12 + sha: v3.4.13 hooks: - id: ansible-lint files: tests/playbook.yml diff --git a/.travis.yml b/.travis.yml index 3d5ac3473f5e72fb4667a7dcb58304b3ae70b605..fba962b950a578374c37104635dd048299887420 100644 --- a/.travis.yml +++ b/.travis.yml @@ -1,28 +1,22 @@ --- language: python -python: ["2.7", "3.5"] +python: "2.7" dist: trusty sudo: True group: beta env: global: - VBOX_MEMORY=2048 + - VBOX_HWVIRTEX=off matrix: - - platform: openbsd60 - - &openbsd59 platform=openbsd59 - - platform: xenial - - platform: trusty - - platform: precise - - &stretch platform=stretch - - &jessie platform=jessie - - platform: wheezy -matrix: - fast_finish: True - allow_failures: - - python: "3.5" - - env: *openbsd59 - - env: *stretch - - env: *jessie + - TOXENV=openbsd60 + - TOXENV=xenial + - TOXENV=trusty + - TOXENV=precise + - &stretch TOXENV=stretch + - &jessie TOXENV=jessie + - TOXENV=wheezy + cache: - pip - directories: @@ -33,15 +27,23 @@ install: - 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 - sudo dpkg -i vagrant_1.9.1_x86_64.deb - - pip install -r tests/requirements.txt | cat - - ansible-galaxy install git+file://$(pwd),$(git rev-parse --abbrev-ref HEAD) -p .molecule/roles - - molecule dependency + - &pip_install pip install tox-travis | cat script: - - pre-commit run --all-files - - travis_wait 45 molecule test --platform $platform + - travis_wait 45 tox notifications: webhooks: https://galaxy.ansible.com/api/v1/notifications/ email: false on_failure: never + +matrix: + fast_finish: True + allow_failures: + - env: *stretch + include: + - env: + TOXENV: pre-commit + install: + - *pip_install + sudo: False diff --git a/Jenkinsfile b/Jenkinsfile new file mode 100644 index 0000000000000000000000000000000000000000..57e457ec22c6c18aac27a138882f83e8c5022012 --- /dev/null +++ b/Jenkinsfile @@ -0,0 +1,38 @@ +/* +Jenkins pipeline for testing an Ansible role. +Required software on the agent: +- Python 2.7. +- Tox. +- Vagrant. +- Virtualbox. +*/ +pipeline { + agent any + environment { + VBOX_HWVIRTEX = off + } + stages { + stage('install') { + steps { + sh 'git submodule update --init --recursive' + } + } + stage('test') { + steps { + parallel ( + 'pre-commit': { + sh 'tox -e pre-commit' + } + 'molecule': { + sh 'tox' + } + ) + } + } + } + post { + success { + sh 'tox -e import' + } + } +} diff --git a/README.rst b/README.rst index 9be411b907d04e4962ea5289563108899cf5d627..52f132636413cf3e91f09660f52c5c2bef6c103b 100644 --- a/README.rst +++ b/README.rst @@ -40,21 +40,9 @@ See :code:`tests/playbook.yml`. Testing ------- -Testing requires Python 2.7, Vagrant and Virtualbox. Install the Python -dependencies, dependent roles and roles required for testing: - -.. 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 +Testing requires Python 2.7, Tox, Vagrant and Virtualbox. To test simply run +:code:`tox`. `Pre-commit <http://pre-commit.com/>`_ is also setup for this +project. License ------- diff --git a/meta/main.yml b/meta/main.yml index 36cb8c523c9351fb6f5a1c25d09f7ae51c0c7b65..3ec86b1effdfda8ed27e9a04d18982499c309ce0 100644 --- a/meta/main.yml +++ b/meta/main.yml @@ -3,15 +3,22 @@ galaxy_info: description: Create users, groups, email aliases, configure sudo and lock down root account. company: Shore technologies license: MIT - min_ansible_version: 2.0 + min_ansible_version: 2.3 platforms: - name: OpenBSD versions: - 6.0 - 5.9 - 5.8 + - name: Ubuntu + versions: + - xenial + - trusty + - precise - name: Debian versions: + - stretch - jessie + - wheezy galaxy_tags: [] dependencies: [] diff --git a/molecule.yml b/molecule.yml index 5d153e56f7c34b8b7f3a56a25a822a9c6d72b2f6..9908a43b24199e8aa6021d58da24792cfd275540 100644 --- a/molecule.yml +++ b/molecule.yml @@ -10,6 +10,10 @@ ansible: users_openbsd59: ansible_become_method: doas +molecule: + ignore_paths: + - .tox + dependency: name: galaxy requirements_file: tests/requirements.yml @@ -23,8 +27,6 @@ vagrant: platforms: - name: openbsd60 box: fnichol/openbsd-6.0-i386 - - name: openbsd59 - box: fnichol/openbsd-5.9-i386 - name: xenial box: ubuntu/xenial32 - name: trusty @@ -32,7 +34,7 @@ vagrant: - name: precise box: hashicorp/precise32 - name: stretch - box: remram/debian-9-i386 + box: koalephant/debian9-i386 - name: jessie box: deb/jessie-i386 - name: wheezy @@ -49,6 +51,6 @@ vagrant: - 'landrush_ip.override = false if Vagrant.has_plugin?("landrush")' - | 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 diff --git a/tests/requirements.txt b/tests/requirements.txt index 57c94d957f72c9d89286e5275edda7bf2932707b..032b0dad72dde2847566f1a537e6939c4be2e2d6 100644 --- a/tests/requirements.txt +++ b/tests/requirements.txt @@ -1,9 +1,8 @@ -ansible==2.3.0.0 -testinfra==1.5.5 -molecule==1.23.2 -ansible-lint==3.4.12 -pre-commit==0.13.6 -python-vagrant==0.5.14 +ansible==2.3.1.0 +testinfra==1.6.4 +molecule==1.25.0 +ansible-lint==3.4.13 +python-vagrant==0.5.15 netaddr==0.7.19 passlib==1.7.1 bcrypt==3.1.3 diff --git a/tests/test_example.py b/tests/test_example.py index aaea50030b9784f0528df9b936cf1903d3af5994..3c308b7bc441b051237f60b2a935f56ce357557d 100644 --- a/tests/test_example.py +++ b/tests/test_example.py @@ -3,10 +3,10 @@ from testinfra.utils.ansible_runner import AnsibleRunner testinfra_hosts = AnsibleRunner('.molecule/ansible_inventory').get_hosts('all') -def test_example(Command): - assert Command('uname').rc == 0 +def test_example(host): + assert host.run('uname').rc == 0 -def test_root(Command, Sudo): - with Sudo(): - assert Command('whoami').stdout.strip() == 'root' +def test_root(host): + with host.sudo(): + assert host.run('whoami').stdout.strip() == 'root' diff --git a/tox.ini b/tox.ini new file mode 100644 index 0000000000000000000000000000000000000000..c80d480b6f557c37a14f6ec977a2900494e95d51 --- /dev/null +++ b/tox.ini @@ -0,0 +1,31 @@ +[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 + +[testenv:import] +envdir = {toxinidir}/.tox/molecule +deps = -rtests/requirements.txt +commands = ansible-galaxy import -v