mirror of
https://github.com/valitydev/salt.git
synced 2024-11-07 17:09:03 +00:00
initial commit for vmware cloud test
This commit is contained in:
parent
284d3be943
commit
cbb6eca2cf
107
tests/integration/cloud/providers/test_vmware.py
Normal file
107
tests/integration/cloud/providers/test_vmware.py
Normal file
@ -0,0 +1,107 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
'''
|
||||||
|
:codeauthor: :email:`Megan Wilhite <mwilhite@saltstack.com>`
|
||||||
|
'''
|
||||||
|
|
||||||
|
# Import Python Libs
|
||||||
|
import os
|
||||||
|
import random
|
||||||
|
import string
|
||||||
|
|
||||||
|
# Import Salt Libs
|
||||||
|
from salt.config import cloud_providers_config
|
||||||
|
|
||||||
|
# Import Salt Testing LIbs
|
||||||
|
import tests.integration as integration
|
||||||
|
from tests.support.helpers import expensiveTest
|
||||||
|
|
||||||
|
def __random_name(size=6):
|
||||||
|
'''
|
||||||
|
Generates a radom cloud instance name
|
||||||
|
'''
|
||||||
|
return 'CLOUD-TEST-' + ''.join(
|
||||||
|
random.choice(string.ascii_uppercase + string.digits)
|
||||||
|
for x in range(size)
|
||||||
|
)
|
||||||
|
|
||||||
|
# Create the cloud instance name to be used throughout the tests
|
||||||
|
INSTANCE_NAME = __random_name()
|
||||||
|
PROVIDER_NAME = 'vmware'
|
||||||
|
|
||||||
|
class VMWareTest(integration.ShellCase):
|
||||||
|
'''
|
||||||
|
Integration tests for the vmware cloud provider in Salt-Cloud
|
||||||
|
'''
|
||||||
|
|
||||||
|
@expensiveTest
|
||||||
|
def setUp(self):
|
||||||
|
'''
|
||||||
|
Sets up the test requirements
|
||||||
|
'''
|
||||||
|
# super(EC2Test, self).setUp()
|
||||||
|
|
||||||
|
# check if appropriate cloud provider and profile files are present
|
||||||
|
profile_str = 'vmware-config'
|
||||||
|
providers = self.run_cloud('--list-providers')
|
||||||
|
|
||||||
|
if profile_str + ':' not in providers:
|
||||||
|
self.skipTest(
|
||||||
|
'Configuration file for {0} was not found. Check {0}.conf files '
|
||||||
|
'in tests/integration/files/conf/cloud.*.d/ to run these tests.'
|
||||||
|
.format(PROVIDER_NAME)
|
||||||
|
)
|
||||||
|
|
||||||
|
# check if id, key, keyname, securitygroup, private_key, location,
|
||||||
|
# and provider are present
|
||||||
|
config = cloud_providers_config(
|
||||||
|
os.path.join(
|
||||||
|
integration.FILES,
|
||||||
|
'conf',
|
||||||
|
'cloud.providers.d',
|
||||||
|
PROVIDER_NAME + '.conf'
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
user = config[profile_str][PROVIDER_NAME]['user']
|
||||||
|
password = config[profile_str][PROVIDER_NAME]['password']
|
||||||
|
url = config[profile_str][PROVIDER_NAME]['url']
|
||||||
|
|
||||||
|
conf_items = [user, password, url]
|
||||||
|
missing_conf_item = []
|
||||||
|
|
||||||
|
for item in conf_items:
|
||||||
|
if item == '':
|
||||||
|
missing_conf_item.append(item)
|
||||||
|
|
||||||
|
if missing_conf_item:
|
||||||
|
self.skipTest(
|
||||||
|
'A user, password, and url must be provided to run these tests.'
|
||||||
|
'One or more of these elements is missing. Check'
|
||||||
|
'tests/integration/files/conf/cloud.providers.d/{0}.conf'
|
||||||
|
.format(PROVIDER_NAME)
|
||||||
|
)
|
||||||
|
|
||||||
|
def test_instance(self):
|
||||||
|
'''
|
||||||
|
Tests creating and deleting an instance on vmware
|
||||||
|
'''
|
||||||
|
# create the instance
|
||||||
|
instance = self.run_cloud('-p vmware-test {0}'.format(INSTANCE_NAME), timeout=500)
|
||||||
|
ret_str = '{0}:'.format(INSTANCE_NAME)
|
||||||
|
|
||||||
|
# check if instance returned with salt installed
|
||||||
|
try:
|
||||||
|
self.assertIn(ret_str, instance)
|
||||||
|
except AssertionError:
|
||||||
|
self.run_cloud('-d {0} --assume-yes'.format(INSTANCE_NAME), timeout=500)
|
||||||
|
raise
|
||||||
|
|
||||||
|
# delete the instance
|
||||||
|
delete = self.run_cloud('-d {0} --assume-yes'.format(INSTANCE_NAME), timeout=500)
|
||||||
|
ret_str = ' shutting-down'
|
||||||
|
|
||||||
|
# check if deletion was performed appropriately
|
||||||
|
try:
|
||||||
|
self.assertIn(ret_str, delete)
|
||||||
|
except AssertionError:
|
||||||
|
raise
|
22
tests/integration/files/conf/cloud.profiles.d/vmware.conf
Normal file
22
tests/integration/files/conf/cloud.profiles.d/vmware.conf
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
vmware-test:
|
||||||
|
provider: vmware-config
|
||||||
|
clonefrom: ''
|
||||||
|
num_cpus: 1
|
||||||
|
memory: 2GB
|
||||||
|
devices:
|
||||||
|
disk:
|
||||||
|
Hard disk 1:
|
||||||
|
size: 30
|
||||||
|
network:
|
||||||
|
Network adapter 1:
|
||||||
|
name: ''
|
||||||
|
adapter_type: e1000
|
||||||
|
switch_type: standard
|
||||||
|
ip: 192.168.0.5
|
||||||
|
gateway: [192.168.0.1]
|
||||||
|
subnet_mask: 255.255.255.0
|
||||||
|
domain: ''
|
||||||
|
resourcepool: ''
|
||||||
|
datastore: ''
|
||||||
|
datacenter: ''
|
||||||
|
host: ''
|
@ -0,0 +1,7 @@
|
|||||||
|
vmware-config:
|
||||||
|
driver: vmware
|
||||||
|
user: ''
|
||||||
|
password: ''
|
||||||
|
url: ''
|
||||||
|
protocol: 'https'
|
||||||
|
port: 443
|
Loading…
Reference in New Issue
Block a user