Add Ansible config and playbook for Vagrant

This commit is contained in:
Damien 2016-05-17 23:41:19 -07:00
Родитель ac75254d13
Коммит c4b05eefcd
4 изменённых файлов: 102 добавлений и 57 удалений

67
tests/Vagrantfile поставляемый
Просмотреть файл

@ -10,62 +10,15 @@ Vagrant.configure(2) do |config|
# For a complete reference, please see the online documentation at
# https://docs.vagrantup.com.
# Every Vagrant development environment requires a box. You can search for
# boxes at https://atlas.hashicorp.com/search.
config.vm.box = "juniper/ffp-12.1X47-D15.4-packetmode"
config.vm.define "vsrx" do |vsrx|
vsrx.vm.hostname = "vsrx"
vsrx.vm.box = "juniper/ffp-12.1X47-D15.4-packetmode"
end
# Disable automatic box update checking. If you disable this, then
# boxes will only be checked for updates when the user runs
# `vagrant box outdated`. This is not recommended.
# config.vm.box_check_update = false
# Create a forwarded port mapping which allows access to a specific port
# within the machine from a port on the host machine. In the example below,
# accessing "localhost:8080" will access port 80 on the guest machine.
# config.vm.network "forwarded_port", guest: 80, host: 8080
# Create a private network, which allows host-only access to the machine
# using a specific IP.
# config.vm.network "private_network", ip: "192.168.33.10"
# Create a public network, which generally matched to bridged network.
# Bridged networks make the machine appear as another physical device on
# your network.
# config.vm.network "public_network"
# Share an additional folder to the guest VM. The first argument is
# the path on the host to the actual folder. The second argument is
# the path on the guest to mount the folder. And the optional third
# argument is a set of non-required options.
# config.vm.synced_folder "../data", "/vagrant_data"
# Provider-specific configuration so you can fine-tune various
# backing providers for Vagrant. These expose provider-specific options.
# Example for VirtualBox:
#
# config.vm.provider "virtualbox" do |vb|
# # Display the VirtualBox GUI when booting the machine
# vb.gui = true
#
# # Customize the amount of memory on the VM:
# vb.memory = "1024"
# end
#
# View the documentation for the provider you are using for more
# information on available options.
# Define a Vagrant Push strategy for pushing to Atlas. Other push strategies
# such as FTP and Heroku are also available. See the documentation at
# https://docs.vagrantup.com/v2/push/atlas.html for more information.
# config.push.define "atlas" do |push|
# push.app = "YOUR_ATLAS_USERNAME/YOUR_APPLICATION_NAME"
# end
# Enable provisioning with a shell script. Additional provisioners such as
# Puppet, Chef, Ansible, Salt, and Docker are also available. Please see the
# documentation for more information about their specific syntax and use.
# config.vm.provision "shell", inline: <<-SHELL
# sudo apt-get update
# sudo apt-get install -y apache2
# SHELL
config.vm.provision "ansible" do |ansible|
ansible.groups = {
"all" => ["vsrx"]
}
ansible.playbook = "junos_get_facts/pb.junos_get_facts.yaml"
end
end

5
tests/ansible.cfg Normal file
Просмотреть файл

@ -0,0 +1,5 @@
[defaults]
hash_behaviour=merge
inventory = .vagrant/provisioners/ansible/inventory/vagrant_ansible_inventory
roles_path = ../../

Просмотреть файл

@ -0,0 +1,26 @@
---
- name: Test junos_get_facts module
hosts: all
connection: local
gather_facts: no
vars:
ansible_python_interpreter: /usr/local/bin/python
roles:
- Juniper.junos
tasks:
- name: "TEST 1 - Gather Facts"
junos_get_facts:
host: "{{ ansible_ssh_host }}"
port: "{{ ansible_ssh_port }}"
user: root
passwd: Juniper
ignore_errors: True
register: test1
# - debug: var=test1
- name: Check TEST 1
assert:
that:
- test1.facts.hostname == 'vsrx'
- test1.facts.virtual == true

Просмотреть файл

@ -0,0 +1,61 @@
---
- name: Test junos_ping module
hosts: all
connection: local
gather_facts: no
vars:
ansible_python_interpreter: /usr/local/bin/python
roles:
- Juniper.junos
tasks:
- name: "TEST 1 - Ping Google DNS"
junos_ping:
host: "{{ ansible_ssh_host }}"
port: "{{ ansible_ssh_port }}"
user: root
passwd: Juniper
dest_ip: 8.8.8.8
register: test1
ignore_errors: True
# - debug: var=test1
- name: Check TEST 1
assert:
that:
- test1.packet_loss == '0'
############
- name: "TEST 2 - Ping Wrong IP"
junos_ping:
host: "{{ ansible_ssh_host }}"
port: "{{ ansible_ssh_port }}"
user: root
passwd: Juniper
dest_ip: 8.8.1.1
register: test2
ignore_errors: True
# - debug: var=test2
- name: Check TEST 2
assert:
that:
- test2.packet_loss == '100'
#################
- name: "TEST 3 - Change nbr packets"
junos_ping:
host: "{{ ansible_ssh_host }}"
port: "{{ ansible_ssh_port }}"
user: root
passwd: Juniper
dest_ip: 8.8.8.8
count: 3
register: test3
ignore_errors: True
# - debug: var=test3
- name: Check TEST 3
assert:
that:
- test3.packets_sent == '3'