mirror of https://github.com/apache/cloudstack.git
279 lines
9.6 KiB
Python
279 lines
9.6 KiB
Python
# -*- encoding: utf-8 -*-
|
|
#
|
|
# Copyright (c) 2012 Citrix. All rights reserved.
|
|
#
|
|
""" BVT tests for Secondary Storage
|
|
"""
|
|
#Import Local Modules
|
|
from cloudstackTestCase import *
|
|
from cloudstackAPI import *
|
|
from utils import *
|
|
from base import *
|
|
|
|
#Import System modules
|
|
import time
|
|
|
|
class Services:
|
|
"""Test secondary storage Services
|
|
"""
|
|
|
|
def __init__(self):
|
|
self.services = {
|
|
"storage": {
|
|
"url": "nfs://192.168.100.131/SecStorage"
|
|
# Format: File_System_Type/Location/Path
|
|
},
|
|
"hypervisors": {
|
|
0: {
|
|
"hypervisor": "XenServer",
|
|
"templatefilter": "self",
|
|
},
|
|
1: {
|
|
"hypervisor": "KVM",
|
|
"templatefilter": "self",
|
|
},
|
|
2: {
|
|
"hypervisor": "VMWare",
|
|
"templatefilter": "self",
|
|
},
|
|
},
|
|
"sleep": 180,
|
|
"timeout": 5,
|
|
}
|
|
|
|
class TestSecStorageServices(cloudstackTestCase):
|
|
|
|
def setUp(self):
|
|
|
|
self.apiclient = self.testClient.getApiClient()
|
|
self.cleanup = []
|
|
self.services = Services().services
|
|
# Get Zone and pod
|
|
self.zone = get_zone(self.apiclient)
|
|
self.pod = get_pod(self.apiclient, self.zone.id)
|
|
|
|
self.services["storage"]["zoneid"] = self.zone.id
|
|
self.services["storage"]["podid"] = self.pod.id
|
|
|
|
self.services["hypervisors"][0]["zoneid"] = self.zone.id
|
|
self.services["hypervisors"][1]["zoneid"] = self.zone.id
|
|
self.services["hypervisors"][2]["zoneid"] = self.zone.id
|
|
|
|
self.services["hypervisors"][0]["podid"] = self.pod.id
|
|
self.services["hypervisors"][1]["podid"] = self.pod.id
|
|
self.services["hypervisors"][2]["podid"] = self.pod.id
|
|
return
|
|
|
|
def tearDown(self):
|
|
try:
|
|
#Clean up, terminate the created templates
|
|
cleanup_resources(self.apiclient, self.cleanup)
|
|
except Exception as e:
|
|
raise Exception("Warning: Exception during cleanup : %s" % e)
|
|
return
|
|
|
|
def test_01_add_sec_storage(self):
|
|
"""Test secondary storage
|
|
"""
|
|
|
|
# Validate the following:
|
|
# 1. secondary storage should be added to the zone.
|
|
# 2. Verify with listHosts and type secondarystorage
|
|
|
|
cmd = addSecondaryStorage.addSecondaryStorageCmd()
|
|
cmd.zoneid = self.zone.id
|
|
cmd.url = self.services["storage"]["url"]
|
|
sec_storage = self.apiclient.addSecondaryStorage(cmd)
|
|
|
|
self.assertEqual(
|
|
sec_storage.zoneid,
|
|
self.zone.id,
|
|
"Check zoneid where sec storage is added"
|
|
)
|
|
|
|
cmd = listHosts.listHostsCmd()
|
|
cmd.type = 'SecondaryStorage'
|
|
cmd.id = sec_storage.id
|
|
list_hosts_response = self.apiclient.listHosts(cmd)
|
|
|
|
self.assertNotEqual(
|
|
len(list_hosts_response),
|
|
0,
|
|
"Check list Hosts response"
|
|
)
|
|
|
|
host_response = list_hosts_response[0]
|
|
#Check if host is Up and running
|
|
self.assertEqual(
|
|
host_response.id,
|
|
sec_storage.id,
|
|
"Check ID of secondary storage"
|
|
)
|
|
self.assertEqual(
|
|
sec_storage.type,
|
|
host_response.type,
|
|
"Check type of host from list hosts response"
|
|
)
|
|
return
|
|
|
|
def test_02_sys_vm_start(self):
|
|
"""Test system VM start
|
|
"""
|
|
|
|
# 1. verify listHosts has all 'routing' hosts in UP state
|
|
# 2. verify listStoragePools shows all primary storage pools
|
|
# in UP state
|
|
# 3. verify that secondary storage was added successfully
|
|
|
|
cmd = listHosts.listHostsCmd()
|
|
cmd.type = 'Routing'
|
|
cmd.zoneid = self.zone.id
|
|
cmd.podid = self.pod.id
|
|
list_hosts_response = self.apiclient.listHosts(cmd)
|
|
# ListHosts has all 'routing' hosts in UP state
|
|
self.assertNotEqual(
|
|
len(list_hosts_response),
|
|
0,
|
|
"Check list host response"
|
|
)
|
|
for host in list_hosts_response:
|
|
self.assertEqual(
|
|
host.state,
|
|
'Up',
|
|
"Check state of routing hosts is Up or not"
|
|
)
|
|
|
|
# ListStoragePools shows all primary storage pools in UP state
|
|
cmd = listStoragePools.listStoragePoolsCmd()
|
|
cmd.name = 'Primary'
|
|
cmd.zoneid = self.zone.id
|
|
cmd.podid = self.pod.id
|
|
list_storage_response = self.apiclient.listStoragePools(cmd)
|
|
|
|
self.assertNotEqual(
|
|
len(list_storage_response),
|
|
0,
|
|
"Check list storage pools response"
|
|
)
|
|
|
|
for primary_storage in list_hosts_response:
|
|
self.assertEqual(
|
|
primary_storage.state,
|
|
'Up',
|
|
"Check state of primary storage pools is Up or not"
|
|
)
|
|
|
|
# Secondary storage is added successfully
|
|
cmd = listHosts.listHostsCmd()
|
|
cmd.type = 'SecondaryStorage'
|
|
cmd.zoneid = self.zone.id
|
|
|
|
timeout = self.services["timeout"]
|
|
while True:
|
|
list_hosts_response = self.apiclient.listHosts(cmd)
|
|
if not list_hosts_response:
|
|
# Sleep to ensure Secondary storage is Up
|
|
time.sleep(int(self.services["sleep"]))
|
|
timeout = timeout - 1
|
|
elif timeout == 0 or list_hosts_response:
|
|
break
|
|
|
|
self.assertNotEqual(
|
|
len(list_hosts_response),
|
|
0,
|
|
"Check list Hosts response"
|
|
)
|
|
|
|
host_response = list_hosts_response[0]
|
|
#Check if host is Up and running
|
|
self.assertEqual(
|
|
host_response.state,
|
|
'Up',
|
|
"Check state of secondary storage"
|
|
)
|
|
|
|
cmd = listSystemVms.listSystemVmsCmd()
|
|
cmd.systemvmtype = 'secondarystoragevm'
|
|
cmd.zoneid = self.zone.id
|
|
cmd.podid = self.pod.id
|
|
|
|
timeout = self.services["timeout"]
|
|
|
|
while True:
|
|
list_ssvm_response = self.apiclient.listSystemVms(cmd)
|
|
if not list_ssvm_response:
|
|
# Sleep to ensure SSVMs are Up and Running
|
|
time.sleep(int(self.services["sleep"]))
|
|
timeout = timeout - 1
|
|
elif timeout == 0 or list_ssvm_response:
|
|
break
|
|
|
|
#Verify SSVM response
|
|
self.assertNotEqual(
|
|
len(list_ssvm_response),
|
|
0,
|
|
"Check list System VMs response"
|
|
)
|
|
|
|
for ssvm in list_ssvm_response:
|
|
self.assertEqual(
|
|
ssvm.state,
|
|
'Running',
|
|
"Check whether state of SSVM is running"
|
|
)
|
|
return
|
|
|
|
def test_03_sys_template_ready(self):
|
|
"""Test system templates are ready
|
|
"""
|
|
|
|
# Validate the following
|
|
# If SSVM is in UP state and running
|
|
# 1. wait for listTemplates to show all builtin templates
|
|
# downloaded for all added hypervisors and in “Ready” state"
|
|
|
|
for k, v in self.services["hypervisors"].items():
|
|
|
|
cmd = listTemplates.listTemplatesCmd()
|
|
cmd.hypervisor = v["hypervisor"]
|
|
cmd.zoneid = self.zone.id
|
|
cmd.templatefilter = v["templatefilter"]
|
|
list_templates = self.apiclient.listTemplates(cmd)
|
|
|
|
# Ensure all BUILTIN templates are downloaded
|
|
templateid = None
|
|
for template in list_templates:
|
|
if template.templatetype == "BUILTIN":
|
|
templateid = template.id
|
|
|
|
cmd = listTemplates.listTemplatesCmd()
|
|
cmd.id = templateid
|
|
cmd.templatefilter = v["templatefilter"]
|
|
cmd.zoneid = self.zone.id
|
|
|
|
while True and (templateid != None):
|
|
|
|
template = self.apiclient.listTemplates(cmd)[0]
|
|
# If template is ready,
|
|
# template.status = Download Complete
|
|
# Downloading - x% Downloaded
|
|
# Error - Any other string
|
|
|
|
if template.status == 'Download Complete' :
|
|
break
|
|
elif 'Downloaded' not in template.status.split():
|
|
raise Exception
|
|
elif 'Downloaded' in template.status.split():
|
|
time.sleep(120)
|
|
|
|
#Ensuring the template is in ready state
|
|
time.sleep(30)
|
|
template = self.apiclient.listTemplates(cmd)[0]
|
|
|
|
self.assertEqual(
|
|
template.isready,
|
|
True,
|
|
"Check whether state of template is ready or not"
|
|
)
|
|
return
|