mirror of
https://github.com/apache/cloudstack.git
synced 2025-10-26 08:42:29 +01:00
* Introducing granular command timeouts global setting * fix marvin tests * Fixed log messages * some more log message fix * Fix empty value setting * Converted the global setting to non-dynamic * set wait on command only when granular wait is defined. This is to keep the backward compatibility * Improve error logging
233 lines
12 KiB
Python
233 lines
12 KiB
Python
# Licensed to the Apache Software Foundation (ASF) under one
|
|
# or more contributor license agreements. See the NOTICE file
|
|
# distributed with this work for additional information
|
|
# regarding copyright ownership. The ASF licenses this file
|
|
# to you under the Apache License, Version 2.0 (the
|
|
# "License"); you may not use this file except in compliance
|
|
# with the License. You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing,
|
|
# software distributed under the License is distributed on an
|
|
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
# KIND, either express or implied. See the License for the
|
|
# specific language governing permissions and limitations
|
|
# under the License.
|
|
""" P1 tests for updating the granular Configuration parameter with scope and resource id provided.
|
|
"""
|
|
#Import Local Modules
|
|
from marvin.cloudstackTestCase import *
|
|
from marvin.cloudstackAPI import *
|
|
from marvin.lib.utils import *
|
|
from marvin.lib.base import *
|
|
from marvin.lib.common import *
|
|
from nose.plugins.attrib import attr
|
|
#Import System modules
|
|
|
|
class TestUpdateConfigWithScope(cloudstackTestCase):
|
|
"""
|
|
Test to update a configuration (global setting) at various scopes
|
|
"""
|
|
def setUp(self):
|
|
self.apiClient = self.testClient.getApiClient()
|
|
|
|
@attr(tags=["devcloud", "basic", "advanced"], required_hardware="false")
|
|
def test_UpdateConfigParamWithScope(self):
|
|
"""
|
|
test update configuration setting at zone level scope
|
|
@return:
|
|
"""
|
|
updateConfigurationCmd = updateConfiguration.updateConfigurationCmd()
|
|
updateConfigurationCmd.name = "use.external.dns"
|
|
updateConfigurationCmd.value = "true"
|
|
updateConfigurationCmd.scopename = "zone"
|
|
updateConfigurationCmd.scopeid = 1
|
|
|
|
updateConfigurationResponse = self.apiClient.updateConfiguration(updateConfigurationCmd)
|
|
self.debug("updated the parameter %s with value %s"%(updateConfigurationResponse.name, updateConfigurationResponse.value))
|
|
|
|
listConfigurationsCmd = listConfigurations.listConfigurationsCmd()
|
|
listConfigurationsCmd.name = updateConfigurationResponse.name
|
|
listConfigurationsCmd.scopename = "zone"
|
|
listConfigurationsCmd.scopeid = 1
|
|
listConfigurationsResponse = self.apiClient.listConfigurations(listConfigurationsCmd)
|
|
|
|
self.assertNotEqual(len(listConfigurationsResponse), 0, "Check if the list API \
|
|
returns a non-empty response")
|
|
|
|
for item in listConfigurationsResponse:
|
|
if item.name == updateConfigurationResponse.name:
|
|
configParam = item
|
|
|
|
self.assertEqual(configParam.value, updateConfigurationResponse.value, "Check if the update API returned \
|
|
is the same as the one we got in the list API")
|
|
|
|
|
|
def tearDown(self):
|
|
"""
|
|
Reset the configuration back to false
|
|
@return:
|
|
"""
|
|
updateConfigurationCmd = updateConfiguration.updateConfigurationCmd()
|
|
updateConfigurationCmd.name = "use.external.dns"
|
|
updateConfigurationCmd.value = "false"
|
|
updateConfigurationCmd.scopename = "zone"
|
|
updateConfigurationCmd.scopeid = 1
|
|
self.apiClient.updateConfiguration(updateConfigurationCmd)
|
|
|
|
|
|
updateConfigurationCmd = updateConfiguration.updateConfigurationCmd()
|
|
updateConfigurationCmd.name = "commands.timeout"
|
|
updateConfigurationCmd.value = ""
|
|
self.apiClient.updateConfiguration(updateConfigurationCmd)
|
|
|
|
class TestListConfigurations(cloudstackTestCase):
|
|
"""
|
|
Test to list configurations (global settings)
|
|
"""
|
|
@classmethod
|
|
def setUpClass(cls):
|
|
cls.apiclient = cls.testClient.getApiClient()
|
|
cls._cleanup = []
|
|
|
|
@classmethod
|
|
def tearDownClass(cls):
|
|
super(TestListConfigurations, cls).tearDownClass()
|
|
|
|
def setUp(self):
|
|
self.apiClient = self.testClient.getApiClient()
|
|
self.cleanup = []
|
|
|
|
def tearDown(self):
|
|
super(TestListConfigurations, self).tearDown()
|
|
|
|
@attr(tags=["devcloud", "basic", "advanced"], required_hardware="false")
|
|
def test_01_list_configs(self):
|
|
"""
|
|
test list configuration setting at global level
|
|
@return:
|
|
"""
|
|
listConfigurationsCmd = listConfigurations.listConfigurationsCmd()
|
|
|
|
listConfigurationsCmd.name = "agent.lb.enabled"
|
|
listConfigurationsResponse = self.apiClient.listConfigurations(listConfigurationsCmd)
|
|
self.assertNotEqual(len(listConfigurationsResponse), 0, "Check if the list configurations API returns a non-empty response")
|
|
self.debug("The parameter %s listed with value %s" %(listConfigurationsCmd.name, listConfigurationsResponse[0].value))
|
|
self.assertEqual(listConfigurationsResponse[0].type, 'Boolean', "Wrong type for the config")
|
|
self.assertEqual(listConfigurationsResponse[0].defaultvalue, 'false', "Wrong default value for the config")
|
|
self.assertEqual(listConfigurationsResponse[0].group, 'Management Server', "Check the group for the config")
|
|
self.assertEqual(listConfigurationsResponse[0].subgroup, 'Agent', "Check the subgroup for the config")
|
|
|
|
listConfigurationsCmd.name = "storage.cleanup.interval"
|
|
listConfigurationsResponse = self.apiClient.listConfigurations(listConfigurationsCmd)
|
|
self.assertNotEqual(len(listConfigurationsResponse), 0, "Check if the list configurations API returns a non-empty response")
|
|
self.debug("The parameter %s listed with value %s" % (listConfigurationsCmd.name, listConfigurationsResponse[0].value))
|
|
self.assertEqual(listConfigurationsResponse[0].type, 'Number', "Wrong type for the config")
|
|
self.assertEqual(listConfigurationsResponse[0].defaultvalue, '86400', "Wrong default value for the config")
|
|
self.assertEqual(listConfigurationsResponse[0].group, 'Infrastructure', "Check the group for the config")
|
|
self.assertEqual(listConfigurationsResponse[0].subgroup, 'Primary Storage', "Check the subgroup for the config")
|
|
|
|
listConfigurationsCmd.name = "agent.load.threshold"
|
|
listConfigurationsResponse = self.apiClient.listConfigurations(listConfigurationsCmd)
|
|
self.assertNotEqual(len(listConfigurationsResponse), 0, "Check if the list configurations API returns a non-empty response")
|
|
self.debug("The parameter %s listed with value %s" % (listConfigurationsCmd.name, listConfigurationsResponse[0].value))
|
|
self.assertEqual(listConfigurationsResponse[0].type, 'Range', "Wrong type for the config")
|
|
self.assertEqual(listConfigurationsResponse[0].defaultvalue, '0.7', "Wrong default value for the config")
|
|
self.assertEqual(listConfigurationsResponse[0].group, 'Management Server', "Check the group for the config")
|
|
self.assertEqual(listConfigurationsResponse[0].subgroup, 'Agent', "Check the subgroup for the config")
|
|
|
|
listConfigurationsCmd.name = "endpoint.url"
|
|
listConfigurationsResponse = self.apiClient.listConfigurations(listConfigurationsCmd)
|
|
self.assertNotEqual(len(listConfigurationsResponse), 0, "Check if the list configurations API returns a non-empty response")
|
|
self.debug("The parameter %s listed with value %s" % (listConfigurationsCmd.name, listConfigurationsResponse[0].value))
|
|
self.assertEqual(listConfigurationsResponse[0].type, 'String', "Wrong type for the config")
|
|
self.assertEqual(listConfigurationsResponse[0].defaultvalue, 'http://localhost:8080/client/api', "Wrong default value for the config")
|
|
|
|
@attr(tags=["devcloud", "basic", "advanced"], required_hardware="false")
|
|
def test_02_list_config_parent(self):
|
|
"""
|
|
test list configuration setting parent
|
|
@return:
|
|
"""
|
|
listConfigurationsCmd = listConfigurations.listConfigurationsCmd()
|
|
|
|
listConfigurationsCmd.name = "api.throttling.cachesize"
|
|
listConfigurationsResponse = self.apiClient.listConfigurations(listConfigurationsCmd)
|
|
self.assertNotEqual(len(listConfigurationsResponse), 0, "Check if the list configurations API returns a non-empty response")
|
|
self.assertEqual(listConfigurationsResponse[0].parent, 'api.throttling.enabled', "Wrong parent for the config")
|
|
|
|
listConfigurationsCmd.name = "storage.cache.replacement.interval"
|
|
listConfigurationsResponse = self.apiClient.listConfigurations(listConfigurationsCmd)
|
|
self.assertNotEqual(len(listConfigurationsResponse), 0, "Check if the list configurations API returns a non-empty response")
|
|
self.assertEqual(listConfigurationsResponse[0].parent, 'storage.cache.replacement.enabled', "Wrong parent for the config")
|
|
|
|
listConfigurationsCmd.name = "cloud.kubernetes.cluster.max.size"
|
|
listConfigurationsResponse = self.apiClient.listConfigurations(listConfigurationsCmd)
|
|
self.assertNotEqual(len(listConfigurationsResponse), 0, "Check if the list configurations API returns a non-empty response")
|
|
self.assertEqual(listConfigurationsResponse[0].parent, 'cloud.kubernetes.service.enabled', "Wrong parent for the config")
|
|
|
|
@attr(tags=["devcloud", "basic", "advanced"], required_hardware="false")
|
|
def test_03_config_groups(self):
|
|
"""
|
|
test list configuration groups
|
|
@return:
|
|
"""
|
|
listConfigurationGroupsResponse = Configurations.listGroups(self.apiclient)
|
|
self.assertNotEqual(len(listConfigurationGroupsResponse), 0, "Check if the list configurationgroups API returns a non-empty response")
|
|
|
|
self.debug("Total %d configuration groups listed" %(len(listConfigurationGroupsResponse)))
|
|
self.debug("Configuration groups: %s" % (str(listConfigurationGroupsResponse)))
|
|
|
|
group = listConfigurationGroupsResponse[0].name
|
|
subgroup = listConfigurationGroupsResponse[0].subgroup[0].name
|
|
|
|
listConfigurationsResponse = Configurations.list(self.apiclient,
|
|
group=group,
|
|
subgroup=subgroup)
|
|
self.assertNotEqual(len(listConfigurationsResponse), 0, "Check if the list configurations API returns a non-empty response")
|
|
self.debug("Total %d configurations for group %s, subgroup %s" % (len(listConfigurationsResponse), group, subgroup))
|
|
|
|
@attr(tags=["devcloud", "basic", "advanced"], required_hardware="false")
|
|
def test_UpdateCommandsTimeoutConfigParamWithValidValue(self):
|
|
"""
|
|
test update configuration setting for commands.timeout with valid value
|
|
@return:
|
|
"""
|
|
updateConfigurationCmd = updateConfiguration.updateConfigurationCmd()
|
|
updateConfigurationCmd.name = "commands.timeout"
|
|
updateConfigurationCmd.value = "DhcpEntryCommand= 600, SavePasswordCommand= 300, VmDataCommand= 300"
|
|
|
|
updateConfigurationResponse = self.apiClient.updateConfiguration(updateConfigurationCmd)
|
|
self.debug("updated the parameter %s with value %s" % (updateConfigurationResponse.name, updateConfigurationResponse.value))
|
|
|
|
listConfigurationsCmd = listConfigurations.listConfigurationsCmd()
|
|
listConfigurationsCmd.name = updateConfigurationResponse.name
|
|
listConfigurationsResponse = self.apiClient.listConfigurations(listConfigurationsCmd)
|
|
|
|
for item in listConfigurationsResponse:
|
|
if item.name == updateConfigurationResponse.name:
|
|
configParam = item
|
|
|
|
self.assertEqual(configParam.value, updateConfigurationResponse.value, "Check if the update API returned is the same as the one we got in the list API")
|
|
|
|
|
|
@attr(tags=["devcloud", "basic", "advanced"], required_hardware="false")
|
|
def test_UpdateCommandsTimeoutConfigParamWithInvalidValue(self):
|
|
"""
|
|
Test update configuration setting for commands.timeout with invalid valid value
|
|
@return:
|
|
"""
|
|
updateConfigurationCmd = updateConfiguration.updateConfigurationCmd()
|
|
updateConfigurationCmd.name = "commands.timeout"
|
|
updateConfigurationCmd.value = "StartCommand: 1" # Intentionally providing invalid format
|
|
|
|
try:
|
|
self.apiClient.updateConfiguration(updateConfigurationCmd)
|
|
self.fail("API call should have failed due to invalid format, but it succeeded.")
|
|
except Exception as e:
|
|
self.debug("Caught expected exception: %s" % str(e))
|
|
error_message = str(e)
|
|
self.assertIn("errorCode: 431", error_message, "Expected error code 431 for invalid format")
|
|
self.assertIn("Validation failed", error_message, "Expected validation failure message")
|