VMware: vmware_inventory contrib testing (#42879)
* VMware: vmware_inventory contrib testing * Use python.py to run inventory script during test. Signed-off-by: Abhijeet Kasurde <akasurde@redhat.com>
This commit is contained in:
parent
54937ba784
commit
905acd7c9e
4 changed files with 90 additions and 0 deletions
4
test/integration/targets/vmware_inventory/aliases
Normal file
4
test/integration/targets/vmware_inventory/aliases
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
shippable/vcenter/group1
|
||||||
|
cloud/vcenter
|
||||||
|
skip/python3
|
||||||
|
destructive
|
62
test/integration/targets/vmware_inventory/runme.sh
Executable file
62
test/integration/targets/vmware_inventory/runme.sh
Executable file
|
@ -0,0 +1,62 @@
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
[[ -n "$DEBUG" || -n "$ANSIBLE_DEBUG" ]] && set -x
|
||||||
|
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
# Get Current test directory
|
||||||
|
DIR=$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )
|
||||||
|
|
||||||
|
contrib_dir=$(pwd)/../../../../contrib/inventory
|
||||||
|
|
||||||
|
echo "DEBUG: using ${contrib_dir}"
|
||||||
|
|
||||||
|
export ANSIBLE_CONFIG=ansible.cfg
|
||||||
|
export vcenter_host="${vcenter_host:-0.0.0.0}"
|
||||||
|
export VMWARE_SERVER="${vcenter_host}"
|
||||||
|
export VMWARE_USERNAME="${VMWARE_USERNAME:-user}"
|
||||||
|
export VMWARE_PASSWORD="${VMWARE_PASSWORD:-pass}"
|
||||||
|
|
||||||
|
VMWARE_CONFIG=${contrib_dir}/vmware_inventory.ini
|
||||||
|
|
||||||
|
|
||||||
|
trap cleanup INT TERM EXIT
|
||||||
|
|
||||||
|
# Remove default inventory config file
|
||||||
|
if [ -f "${VMWARE_CONFIG}" ];
|
||||||
|
then
|
||||||
|
echo "DEBUG: Creating backup of ${VMWARE_CONFIG}"
|
||||||
|
cp "${VMWARE_CONFIG}" "${VMWARE_CONFIG}.bk"
|
||||||
|
fi
|
||||||
|
|
||||||
|
cat > "${VMWARE_CONFIG}" <<VMWARE_INI
|
||||||
|
[vmware]
|
||||||
|
server=${VMWARE_SERVER}
|
||||||
|
username=${VMWARE_USERNAME}
|
||||||
|
password=${VMWARE_PASSWORD}
|
||||||
|
validate_certs=False
|
||||||
|
VMWARE_INI
|
||||||
|
|
||||||
|
function cleanup {
|
||||||
|
# Revert back to previous one
|
||||||
|
if [ -f "${VMWARE_CONFIG}.bk" ]; then
|
||||||
|
echo "DEBUG: Cleanup ${VMWARE_CONFIG}"
|
||||||
|
mv "${VMWARE_CONFIG}.bk" "${VMWARE_CONFIG}"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
echo "DEBUG: Using ${vcenter_host} with username ${VMWARE_USERNAME} and password ${VMWARE_PASSWORD}"
|
||||||
|
|
||||||
|
echo "Kill all previous instances"
|
||||||
|
curl "http://${vcenter_host}:5000/killall" > /dev/null 2>&1
|
||||||
|
|
||||||
|
echo "Start new VCSIM server"
|
||||||
|
curl "http://${vcenter_host}:5000/spawn?datacenter=1&cluster=1&folder=0" > /dev/null 2>&1
|
||||||
|
|
||||||
|
echo "Debugging new instances"
|
||||||
|
curl "http://${vcenter_host}:5000/govc_find"
|
||||||
|
|
||||||
|
# Get inventory
|
||||||
|
ansible-playbook -i ./vmware_inventory.sh "${DIR}/test_vmware_inventory.yml" --connection=local "$@"
|
||||||
|
|
||||||
|
echo "DEBUG: Done"
|
|
@ -0,0 +1,21 @@
|
||||||
|
# Test code for the vmware guest contrib inventory
|
||||||
|
# Copyright: (c) 2018, Abhijeet Kasurde <akasurde@redhat.com>
|
||||||
|
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
|
||||||
|
|
||||||
|
---
|
||||||
|
- name: Test VMware guest contrib inventroy script
|
||||||
|
hosts: localhost
|
||||||
|
tasks:
|
||||||
|
- name: store the vcenter container ip
|
||||||
|
set_fact:
|
||||||
|
vcsim: "{{ lookup('env', 'vcenter_host') }}"
|
||||||
|
|
||||||
|
- debug:
|
||||||
|
var: vcsim
|
||||||
|
|
||||||
|
- name: Check that groups present in inventory
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- "'{{item}}' in groups"
|
||||||
|
with_items:
|
||||||
|
- all
|
3
test/integration/targets/vmware_inventory/vmware_inventory.sh
Executable file
3
test/integration/targets/vmware_inventory/vmware_inventory.sh
Executable file
|
@ -0,0 +1,3 @@
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
python.py "../../../../contrib/inventory/vmware_inventory.py" "$@"
|
Loading…
Reference in a new issue