1 # Copyright (c) 2017-2019 Intel Corporation
3 # Licensed under the Apache License, Version 2.0 (the "License");
4 # you may not use this file except in compliance with the License.
5 # You may obtain a copy of the License at
7 # http://www.apache.org/licenses/LICENSE-2.0
9 # Unless required by applicable law or agreed to in writing, software
10 # distributed under the License is distributed on an "AS IS" BASIS,
11 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 # See the License for the specific language governing permissions and
13 # limitations under the License.
15 from oslo_utils import excutils
17 from yardstick.common import constants
20 class ProcessExecutionError(RuntimeError):
21 def __init__(self, message, returncode):
22 super(ProcessExecutionError, self).__init__(message)
23 self.returncode = returncode
26 class ErrorClass(object):
28 def __init__(self, *args, **kwargs):
29 if 'test' not in kwargs:
32 def __getattr__(self, item):
36 class YardstickException(Exception):
37 """Base Yardstick Exception.
39 To correctly use this class, inherit from it and define
40 a 'message' property. That message will get printf'd
41 with the keyword arguments provided to the constructor.
43 Based on NeutronException class.
45 message = "An unknown exception occurred."
47 def __init__(self, **kwargs):
49 super(YardstickException, self).__init__(self.message % kwargs)
50 self.msg = self.message % kwargs
51 except Exception: # pylint: disable=broad-except
52 with excutils.save_and_reraise_exception() as ctxt:
53 if not self.use_fatal_exceptions():
55 # at least get the core message out if something happened
56 super(YardstickException, self).__init__(self.message)
61 def use_fatal_exceptions(self):
62 """Is the instance using fatal exceptions.
64 :returns: Always returns False.
69 class ResourceCommandError(YardstickException):
70 message = 'Command: "%(command)s" Failed, stderr: "%(stderr)s"'
73 class ContextUpdateCollectdForNodeError(YardstickException):
74 message = 'Cannot find node %(attr_name)s'
77 class FunctionNotImplemented(YardstickException):
78 message = ('The function "%(function_name)s" is not implemented in '
79 '"%(class_name)" class.')
82 class InvalidType(YardstickException):
83 message = 'Type "%(type_to_convert)s" is not valid'
86 class InfluxDBConfigurationMissing(YardstickException):
87 message = ('InfluxDB configuration is not available. Add "influxdb" as '
88 'a dispatcher and the configuration section')
91 class YardstickBannedModuleImported(YardstickException):
92 message = 'Module "%(module)s" cannnot be imported. Reason: "%(reason)s"'
95 class IXIAUnsupportedProtocol(YardstickException):
96 message = 'Protocol "%(protocol)" is not supported in IXIA'
99 class PayloadMissingAttributes(YardstickException):
100 message = ('Error instantiating a Payload class, missing attributes: '
101 '%(missing_attributes)s')
104 class HeatTemplateError(YardstickException):
105 message = ('Error in Heat during the creation of the OpenStack stack '
109 class IPv6RangeError(YardstickException):
110 message = 'Start IP "%(start_ip)s" is greater than end IP "%(end_ip)s"'
113 class TrafficProfileNotImplemented(YardstickException):
114 message = 'No implementation for traffic profile %(profile_class)s.'
117 class TrafficProfileRate(YardstickException):
118 message = 'Traffic profile rate must be "<number>[fps|%]"'
121 class DPDKSetupDriverError(YardstickException):
122 message = '"igb_uio" driver is not loaded'
125 class OVSUnsupportedVersion(YardstickException):
126 message = ('Unsupported OVS version "%(ovs_version)s". Please check the '
127 'config. OVS to DPDK version map: %(ovs_to_dpdk_map)s.')
130 class OVSHugepagesInfoError(YardstickException):
131 message = 'MemInfo cannnot be retrieved.'
134 class OVSHugepagesNotConfigured(YardstickException):
135 message = 'HugePages are not configured in this system.'
138 class OVSHugepagesZeroFree(YardstickException):
139 message = ('There are no HugePages free in this system. Total HugePages '
140 'configured: %(total_hugepages)s')
143 class OVSDeployError(YardstickException):
144 message = 'OVS deploy tool failed with error: %(stderr)s.'
147 class OVSSetupError(YardstickException):
148 message = 'OVS setup error. Command: %(command)s. Error: %(error)s.'
151 class LibvirtCreateError(YardstickException):
152 message = 'Error creating the virtual machine. Error: %(error)s.'
155 class LibvirtQemuImageBaseImageNotPresent(YardstickException):
156 message = ('Error creating the qemu image for %(vm_image)s. Base image: '
157 '%(base_image)s. Base image not present in execution host or '
161 class LibvirtQemuImageCreateError(YardstickException):
162 message = ('Error creating the qemu image for %(vm_image)s. Base image: '
163 '%(base_image)s. Error: %(error)s.')
166 class SSHError(YardstickException):
167 message = '%(error_msg)s'
170 class SSHTimeout(SSHError):
174 class IncorrectConfig(YardstickException):
175 message = '%(error_msg)s'
178 class IncorrectSetup(YardstickException):
179 message = '%(error_msg)s'
182 class IncorrectNodeSetup(IncorrectSetup):
186 class ScenarioConfigContextNameNotFound(YardstickException):
187 message = 'Context for host name "%(host_name)s" not found'
190 class StackCreationInterrupt(YardstickException):
191 message = 'Stack create interrupted.'
194 class TaskRenderArgumentError(YardstickException):
195 message = 'Error reading the task input arguments'
198 class TaskReadError(YardstickException):
199 message = 'Failed to read task %(task_file)s'
202 class TaskRenderError(YardstickException):
203 message = 'Failed to render template:\n%(input_task)s'
206 class TimerTimeout(YardstickException):
207 message = 'Timer timeout expired, %(timeout)s seconds'
210 class WaitTimeout(YardstickException):
211 message = 'Wait timeout while waiting for condition'
214 class PktgenActionError(YardstickException):
215 message = 'Error in "%(action)s" action'
218 class KubernetesApiException(YardstickException):
219 message = ('Kubernetes API errors. Action: %(action)s, '
220 'resource: %(resource)s')
223 class KubernetesConfigFileNotFound(YardstickException):
224 message = 'Config file (%s) not found' % constants.K8S_CONF_FILE
227 class KubernetesTemplateInvalidVolumeType(YardstickException):
228 message = 'No valid "volume" types present in %(volume)s'
231 class KubernetesSSHPortNotDefined(YardstickException):
232 message = 'Port 22 needs to be defined'
235 class KubernetesServiceObjectNotDefined(YardstickException):
236 message = 'ServiceObject is not defined'
239 class KubernetesServiceObjectDefinitionError(YardstickException):
240 message = ('Kubernetes Service object definition error, missing '
241 'parameters: %(missing_parameters)s')
244 class KubernetesServiceObjectNameError(YardstickException):
245 message = ('Kubernetes Service object name "%(name)s" does not comply'
249 class KubernetesCRDObjectDefinitionError(YardstickException):
250 message = ('Kubernetes Custom Resource Definition Object error, missing '
251 'parameters: %(missing_parameters)s')
254 class KubernetesNetworkObjectDefinitionError(YardstickException):
255 message = ('Kubernetes Network object definition error, missing '
256 'parameters: %(missing_parameters)s')
259 class KubernetesNetworkObjectKindMissing(YardstickException):
260 message = 'Kubernetes kind "Network" is not defined'
263 class KubernetesWrongRestartPolicy(YardstickException):
264 message = 'Restart policy "%(rpolicy)s" is not valid'
267 class KubernetesContainerPortNotDefined(YardstickException):
268 message = 'Container port not defined in "%(port)s"'
271 class KubernetesContainerWrongImagePullPolicy(YardstickException):
272 message = 'Image pull policy must be "Always", "IfNotPresent" or "Never"'
275 class KubernetesContainerCommandType(YardstickException):
276 message = '"args" and "command" must be string or list of strings'
279 class ScenarioCreateNetworkError(YardstickException):
280 message = 'Create Neutron Network Scenario failed'
283 class ScenarioCreateSubnetError(YardstickException):
284 message = 'Create Neutron Subnet Scenario failed'
287 class ScenarioDeleteRouterError(YardstickException):
288 message = 'Delete Neutron Router Scenario failed'
291 class MissingPodInfoError(YardstickException):
292 message = 'Missing pod args, please check'
295 class UnsupportedPodFormatError(YardstickException):
296 message = 'Failed to load pod info, unsupported format'
299 class ScenarioCreateRouterError(YardstickException):
300 message = 'Create Neutron Router Scenario failed'
303 class ScenarioRemoveRouterIntError(YardstickException):
304 message = 'Remove Neutron Router Interface Scenario failed'
307 class ScenarioCreateFloatingIPError(YardstickException):
308 message = 'Create Neutron Floating IP Scenario failed'
311 class ScenarioDeleteFloatingIPError(YardstickException):
312 message = 'Delete Neutron Floating IP Scenario failed'
315 class ScenarioCreateSecurityGroupError(YardstickException):
316 message = 'Create Neutron Security Group Scenario failed'
319 class ScenarioDeleteNetworkError(YardstickException):
320 message = 'Delete Neutron Network Scenario failed'
323 class ScenarioCreateServerError(YardstickException):
324 message = 'Nova Create Server Scenario failed'
327 class ScenarioDeleteServerError(YardstickException):
328 message = 'Delete Server Scenario failed'
331 class ScenarioCreateKeypairError(YardstickException):
332 message = 'Nova Create Keypair Scenario failed'
335 class ScenarioDeleteKeypairError(YardstickException):
336 message = 'Nova Delete Keypair Scenario failed'
339 class ScenarioAttachVolumeError(YardstickException):
340 message = 'Nova Attach Volume Scenario failed'
343 class ScenarioGetServerError(YardstickException):
344 message = 'Nova Get Server Scenario failed'
347 class ScenarioGetFlavorError(YardstickException):
348 message = 'Nova Get Falvor Scenario failed'
351 class ScenarioCreateVolumeError(YardstickException):
352 message = 'Cinder Create Volume Scenario failed'
355 class ScenarioDeleteVolumeError(YardstickException):
356 message = 'Cinder Delete Volume Scenario failed'
359 class ScenarioDetachVolumeError(YardstickException):
360 message = 'Cinder Detach Volume Scenario failed'
363 class ApiServerError(YardstickException):
364 message = 'An unkown exception happened to Api Server!'
367 class UploadOpenrcError(ApiServerError):
368 message = 'Upload openrc ERROR!'
371 class UpdateOpenrcError(ApiServerError):
372 message = 'Update openrc ERROR!'
375 class ScenarioCreateImageError(YardstickException):
376 message = 'Glance Create Image Scenario failed'
379 class ScenarioDeleteImageError(YardstickException):
380 message = 'Glance Delete Image Scenario failed'
383 class IxNetworkClientNotConnected(YardstickException):
384 message = 'IxNetwork client not connected to a TCL server'
387 class IxNetworkFlowNotPresent(YardstickException):
388 message = 'Flow Group "%(flow_group)s" is not present'
391 class IxNetworkFieldNotPresentInStackItem(YardstickException):
392 message = 'Field "%(field_name)s" not present in stack item %(stack_item)s'
395 class IncorrectFlowOption(YardstickException):
396 message = 'Flow option {option} for {link} is incorrect'
399 class SLAValidationError(YardstickException):
400 message = '%(case_name)s SLA validation failed. Error: %(error_msg)s'
403 class AclMissingActionArguments(YardstickException):
404 message = ('Missing ACL action parameter '
405 '[action=%(action_name)s parameter=%(action_param)s]')
408 class AclUnknownActionTemplate(YardstickException):
409 message = 'No ACL CLI template found for "%(action_name)s" action'
412 class InvalidMacAddress(YardstickException):
413 message = 'Mac address "%(mac_address)s" is invalid'
416 class ValueCheckError(YardstickException):
417 message = 'Constraint "%(value1)s %(operator)s %(value2)s" does not hold'
420 class RestApiError(RuntimeError):
421 def __init__(self, message):
422 self._message = message
423 super(RestApiError, self).__init__(message)
426 class LandslideTclException(RuntimeError):
427 def __init__(self, message):
428 self._message = message
429 super(LandslideTclException, self).__init__(message)