Skip to content
Snippets Groups Projects
Commit 6ecba0d2 authored by nimrod's avatar nimrod
Browse files

Merge branch 'master' of /home/nimrod/Documents/Shore/Ansible/example

# Conflicts:
#	.travis.yml
#	meta/main.yml
#	molecule.yml
#	tasks/main.yml
#	tests/playbook.yml
parents eb7feb63 681cd09f
No related branches found
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
...@@ -2,23 +2,47 @@ ...@@ -2,23 +2,47 @@
language: python language: python
python: "2.7" python: "2.7"
dist: trusty dist: trusty
sudo: false sudo: True
group: beta group: beta
services: [docker] env:
global:
- VBOX_MEMORY=2048
- VBOX_HWVIRTEX=off
matrix:
- TOXENV=xenial
- TOXENV=trusty
- TOXENV=precise
- &stretch TOXENV=stretch
- &jessie TOXENV=jessie
- TOXENV=wheezy
cache: cache:
- pip - pip
- directories: - directories:
- $HOME/.pre-commit - $HOME/.pre-commit
install: install:
- pip install -r tests/requirements.txt | cat - sudo apt-get update
- ansible-galaxy install git+file://$(pwd),$(git rev-parse --abbrev-ref HEAD) -p .molecule/roles - sudo apt-get install -y linux-headers-$(uname -r) virtualbox
- molecule dependency - 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 pip install tox-travis | cat
script: script:
- pre-commit run --all-files - travis_wait 45 tox
- travis_retry molecule test --driver docker
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
matrix:
fast_finish: True
allow_failures:
- env: *stretch
include:
- env:
TOXENV: pre-commit
install:
- *pip_install
sudo: False
/*
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'
}
}
}
...@@ -29,22 +29,9 @@ See :code:`tests/playbook.yml`. ...@@ -29,22 +29,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
------- -------
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
library = library library = library
host_key_checking = False host_key_checking = False
retry_files_enabled = False retry_files_enabled = False
roles_path = .molecule/roles:.molecule/../roles:../:../../ roles_path = ../:.molecule/roles:.molecule/../roles:../../
command_warnings = True command_warnings = True
deprecation_warnings = True deprecation_warnings = True
forks = 50 forks = 50
......
...@@ -3,16 +3,17 @@ galaxy_info: ...@@ -3,16 +3,17 @@ galaxy_info:
description: Configure Debian and Ubuntu backports repo. description: Configure Debian and Ubuntu backports repo.
company: Shore technologies company: Shore technologies
license: MIT license: MIT
min_ansible_version: 2.0 min_ansible_version: 2.3
platforms: platforms:
- name: Debian
versions:
- wheezy
- jessie
- name: Ubuntu - name: Ubuntu
versions: versions:
- precise
- trusty
- xenial - xenial
- trusty
- precise
- name: Debian
versions:
- stretch
- jessie
- wheezy
galaxy_tags: [ debian, ubuntu, backports, apt ] galaxy_tags: [ debian, ubuntu, backports, apt ]
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
...@@ -13,51 +17,35 @@ vagrant: ...@@ -13,51 +17,35 @@ vagrant:
providers: providers:
- name: virtualbox - name: virtualbox
type: virtualbox type: virtualbox
options:
cpus: 1
platforms: platforms:
- name: jessie - name: openbsd60
box: debian/jessie64 box: fnichol/openbsd-6.0-i386
- name: xenial - name: xenial
box: ubuntu/xenial64 box: ubuntu/xenial32
- name: trusty
box: ubuntu/trusty32
- name: precise
box: hashicorp/precise32
- name: stretch
box: koalephant/debian9-i386
- name: jessie
box: deb/jessie-i386
- name: wheezy
box: bmorg/debian-wheezy-i386
instances: instances:
- name: backports - name: backports
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' - 'vbguest.auto_update = false if Vagrant.has_plugin?("vbguest")'
- 'landrush.enabled = false' - 'landrush.enabled = false if Vagrant.has_plugin?("landrush")'
- 'landrush_ip.override = false' - 'landrush_ip.override = false if Vagrant.has_plugin?("landrush")'
- |
docker: vm.provider "virtualbox" do |v|
containers: v.customize "pre-boot", ["modifyvm", :id, "--hwvirtex", ENV['VBOX_HWVIRTEX']] if ENV.has_key?('VBOX_HWVIRTEX')
- name: backports-xenial v.memory = ENV['VBOX_MEMORY'].to_i if ENV.has_key?('VBOX_MEMORY')
image: ubuntu end
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
- name: backports-precise
image: ubuntu
image_version: precise
environment:
DEBIAN_FRONTEND: noninteractive
- name: backports-trusty
image: ubuntu
image_version: trusty
environment:
DEBIAN_FRONTEND: noninteractive
- name: backports-wheezy
image: debian
image_version: wheezy
environment:
DEBIAN_FRONTEND: noninteractive
- name: backports-jessie
image: debian
image_version: jessie
environment:
DEBIAN_FRONTEND: noninteractive
--- ---
- hosts: backports-xenial - hosts: backports-openbsd*
gather_facts: false gather_facts: false
roles: [adarnimrod.debian-bootstrap] roles:
- openbsd-bootstrap
- role: users
users: []
users_use_sudo: True
users_lock_root_ssh: False
- hosts: [backports-xenial, backports-wheezy]
gather_facts: false
roles:
- debian-bootstrap
- role: users
users: []
users_use_sudo: True
users_lock_root_ssh: False
- hosts: all - hosts: all
strategy: free
roles: roles:
- role: backports - role: backports
ansible==2.2.0.0 ansible==2.3.1.0
testinfra==1.4.5 testinfra==1.6.3
molecule==1.16.1 molecule==1.25.0
ansible-lint==3.4.7 ansible-lint==3.4.13
pre-commit==0.9.4 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
--- ---
- src: adarnimrod.openbsd-bootstrap - src: adarnimrod.openbsd-bootstrap
name: openbsd-bootstrap
- src: adarnimrod.debian-bootstrap - src: adarnimrod.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
[testenv:import]
envdir = {toxinidir}/.tox/molecule
deps = -rtests/requirements.txt
commands = ansible-galaxy import -v
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment