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

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

# Conflicts:
#	.travis.yml
#	molecule.yml
#	tasks/main.yml
#	tests/playbook.yml
#	tests/requirements.yml
parents 44cdd447 7f5d2c7b
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.12
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.4"] 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
- &openbsd59 platform=openbsd59 driver=vagrant matrix:
- driver: docker - TOXENV=pre-commit
platform: all - TOXENV=openbsd60
- TOXENV=trusty
- TOXENV=precise
- &jessie TOXENV=jessie
- TOXENV=wheezy
matrix: matrix:
fast_finish: True fast_finish: True
allow_failures: allow_failures:
- python: "3.4" - env: *jessie
- env: *openbsd59
cache: cache:
- pip - pip
- directories: - directories:
...@@ -26,14 +28,12 @@ install: ...@@ -26,14 +28,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
------- -------
......
...@@ -7,14 +7,15 @@ galaxy_info: ...@@ -7,14 +7,15 @@ galaxy_info:
platforms: platforms:
- name: OpenBSD - name: OpenBSD
versions: versions:
- 5.9
- 6.0 - 6.0
- name: Ubuntu - name: Ubuntu
versions: versions:
- precise
- trusty - trusty
- name: Debian - name: Debian
versions: versions:
- jessie - jessie
- wheezy
galaxy_tags: [ php, fpm, fastcgi, http, web ] galaxy_tags: [ php, fpm, fastcgi, http, web ]
dependencies: dependencies:
- src: adarnimrod.php5 - src: adarnimrod.php5
......
...@@ -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,21 +22,20 @@ vagrant: ...@@ -18,21 +22,20 @@ 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
box: ubuntu/xenial32
- name: trusty - name: trusty
box: ubuntu/trusty32 box: ubuntu/trusty32
- name: precise
box: hashicorp/precise32
- 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: php-fpm - name: php-fpm
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")'
...@@ -40,45 +43,5 @@ vagrant: ...@@ -40,45 +43,5 @@ vagrant:
- | - |
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", "off"]
v.memory = ENV['VBOX_MEMORY'].to_i if ENV.has_key?('VBOX_MEMORY')
end end
docker:
containers:
- name: php-fpm-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
- name: php-fpm-trusty
image: ubuntu-upstart
image_version: trusty
command: /sbin/init
privileged: True
environment:
DEBIAN_FRONTEND: noninteractive
container: docker
- name: php-fpm-jessie
image: debian
image_version: jessie
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: php-fpm-wheezy
image: debian
image_version: wheezy
command: /sbin/init
privileged: True
environment:
DEBIAN_FRONTEND: noninteractive
container: docker
...@@ -11,7 +11,7 @@ ...@@ -11,7 +11,7 @@
- ansible_os_family in php_fpm_validate_config - ansible_os_family in php_fpm_validate_config
- ansible_os_family in php_fpm_pools_dir - ansible_os_family in php_fpm_pools_dir
- ansible_os_family in php_fpm_user - ansible_os_family in php_fpm_user
- ansible_distribution_release in ['6.0', '5.9', 'jessie', 'trusty'] - ansible_distribution_release in ['jessie', 'trusty'] or ansible_distribution_version in ['6.0']
- ansible_os_family != 'OpenBSD' or ansible_distribution_release in php_fpm_pkg_version - ansible_os_family != 'OpenBSD' or ansible_distribution_release in php_fpm_pkg_version
- php_fpm_global_config is iterable - php_fpm_global_config is iterable
- php_fpm_www_pool_config is iterable - php_fpm_www_pool_config is iterable
......
--- ---
- hosts: php-fpm-openbsd* - hosts: php-fpm-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: php-fpm-xenial - hosts: php-fpm-xenial, php-fpm-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.5.5
molecule==1.17.3 molecule==1.23.2
ansible-lint==3.4.9 ansible-lint==3.4.12
pre-commit==0.10.1
piprot==0.9.7
python-vagrant==0.5.14 python-vagrant==0.5.14
docker-py==1.10.6 netaddr==0.7.19
netaddr==0.7.18 passlib==1.7.1
passlib==1.7.0 bcrypt==3.1.3
bcrypt==3.1.2
...@@ -5,3 +5,5 @@ ...@@ -5,3 +5,5 @@
name: debian-bootstrap name: debian-bootstrap
- src: adarnimrod.nginx - src: adarnimrod.nginx
name: nginx name: nginx
- src: adarnimrod.users
name: users
tox.ini 0 → 100644
[tox]
skip_install = True
skipsdist = True
envlist = openbsd60,xenial,trusty,precise,stretch,jessie,wheezy
[testenv]
envdir = {toxinidir}/.tox
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]
envdir = {toxinidir}/.tox
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