1 # Copyright (c) 2017 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 RunnerIterationIPCSetupActionNeeded(YardstickException):
207 message = ('IterationIPC needs the "setup" action to retrieve the VNF '
208 'handling processes PIDs to receive the messages sent')
211 class RunnerIterationIPCNoCtxs(YardstickException):
212 message = 'Benchmark "setup" action did not return any VNF process PID'
215 class TimerTimeout(YardstickException):
216 message = 'Timer timeout expired, %(timeout)s seconds'
219 class WaitTimeout(YardstickException):
220 message = 'Wait timeout while waiting for condition'
223 class PktgenActionError(YardstickException):
224 message = 'Error in "%(action)s" action'
227 class KubernetesApiException(YardstickException):
228 message = ('Kubernetes API errors. Action: %(action)s, '
229 'resource: %(resource)s')
232 class KubernetesConfigFileNotFound(YardstickException):
233 message = 'Config file (%s) not found' % constants.K8S_CONF_FILE
236 class KubernetesTemplateInvalidVolumeType(YardstickException):
237 message = 'No valid "volume" types present in %(volume)s'
240 class KubernetesSSHPortNotDefined(YardstickException):
241 message = 'Port 22 needs to be defined'
244 class KubernetesServiceObjectNotDefined(YardstickException):
245 message = 'ServiceObject is not defined'
248 class KubernetesServiceObjectDefinitionError(YardstickException):
249 message = ('Kubernetes Service object definition error, missing '
250 'parameters: %(missing_parameters)s')
253 class KubernetesServiceObjectNameError(YardstickException):
254 message = ('Kubernetes Service object name "%(name)s" does not comply'
258 class KubernetesCRDObjectDefinitionError(YardstickException):
259 message = ('Kubernetes Custom Resource Definition Object error, missing '
260 'parameters: %(missing_parameters)s')
263 class KubernetesNetworkObjectDefinitionError(YardstickException):
264 message = ('Kubernetes Network object definition error, missing '
265 'parameters: %(missing_parameters)s')
268 class KubernetesNetworkObjectKindMissing(YardstickException):
269 message = 'Kubernetes kind "Network" is not defined'
272 class KubernetesWrongRestartPolicy(YardstickException):
273 message = 'Restart policy "%(rpolicy)s" is not valid'
276 class KubernetesContainerPortNotDefined(YardstickException):
277 message = 'Container port not defined in "%(port)s"'
280 class KubernetesContainerWrongImagePullPolicy(YardstickException):
281 message = 'Image pull policy must be "Always", "IfNotPresent" or "Never"'
284 class KubernetesContainerCommandType(YardstickException):
285 message = '"args" and "command" must be string or list of strings'
288 class ScenarioCreateNetworkError(YardstickException):
289 message = 'Create Neutron Network Scenario failed'
292 class ScenarioCreateSubnetError(YardstickException):
293 message = 'Create Neutron Subnet Scenario failed'
296 class ScenarioDeleteRouterError(YardstickException):
297 message = 'Delete Neutron Router Scenario failed'
300 class MissingPodInfoError(YardstickException):
301 message = 'Missing pod args, please check'
304 class UnsupportedPodFormatError(YardstickException):
305 message = 'Failed to load pod info, unsupported format'
308 class ScenarioCreateRouterError(YardstickException):
309 message = 'Create Neutron Router Scenario failed'
312 class ScenarioRemoveRouterIntError(YardstickException):
313 message = 'Remove Neutron Router Interface Scenario failed'
316 class ScenarioCreateFloatingIPError(YardstickException):
317 message = 'Create Neutron Floating IP Scenario failed'
320 class ScenarioDeleteFloatingIPError(YardstickException):
321 message = 'Delete Neutron Floating IP Scenario failed'
324 class ScenarioCreateSecurityGroupError(YardstickException):
325 message = 'Create Neutron Security Group Scenario failed'
328 class ScenarioDeleteNetworkError(YardstickException):
329 message = 'Delete Neutron Network Scenario failed'
332 class ScenarioCreateServerError(YardstickException):
333 message = 'Nova Create Server Scenario failed'
336 class ScenarioDeleteServerError(YardstickException):
337 message = 'Delete Server Scenario failed'
340 class ScenarioCreateKeypairError(YardstickException):
341 message = 'Nova Create Keypair Scenario failed'
344 class ScenarioDeleteKeypairError(YardstickException):
345 message = 'Nova Delete Keypair Scenario failed'
348 class ScenarioAttachVolumeError(YardstickException):
349 message = 'Nova Attach Volume Scenario failed'
352 class ScenarioGetServerError(YardstickException):
353 message = 'Nova Get Server Scenario failed'
356 class ScenarioGetFlavorError(YardstickException):
357 message = 'Nova Get Falvor Scenario failed'
360 class ScenarioCreateVolumeError(YardstickException):
361 message = 'Cinder Create Volume Scenario failed'
364 class ScenarioDeleteVolumeError(YardstickException):
365 message = 'Cinder Delete Volume Scenario failed'
368 class ScenarioDetachVolumeError(YardstickException):
369 message = 'Cinder Detach Volume Scenario failed'
372 class ApiServerError(YardstickException):
373 message = 'An unkown exception happened to Api Server!'
376 class UploadOpenrcError(ApiServerError):
377 message = 'Upload openrc ERROR!'
380 class UpdateOpenrcError(ApiServerError):
381 message = 'Update openrc ERROR!'
384 class ScenarioCreateImageError(YardstickException):
385 message = 'Glance Create Image Scenario failed'
388 class ScenarioDeleteImageError(YardstickException):
389 message = 'Glance Delete Image Scenario failed'
392 class IxNetworkClientNotConnected(YardstickException):
393 message = 'IxNetwork client not connected to a TCL server'
396 class IxNetworkFlowNotPresent(YardstickException):
397 message = 'Flow Group "%(flow_group)s" is not present'
400 class IxNetworkFieldNotPresentInStackItem(YardstickException):
401 message = 'Field "%(field_name)s" not present in stack item %(stack_item)s'
404 class SLAValidationError(YardstickException):
405 message = '%(case_name)s SLA validation failed. Error: %(error_msg)s'
408 class AclMissingActionArguments(YardstickException):
409 message = ('Missing ACL action parameter '
410 '[action=%(action_name)s parameter=%(action_param)s]')
413 class AclUnknownActionTemplate(YardstickException):
414 message = 'No ACL CLI template found for "%(action_name)s" action'
417 class InvalidMacAddress(YardstickException):
418 message = 'Mac address "%(mac_address)s" is invalid'
421 class ValueCheckError(YardstickException):
422 message = 'Constraint "%(value1)s %(operator)s %(value2)s" does not hold'
425 class RestApiError(RuntimeError):
426 def __init__(self, message):
427 self._message = message
428 super(RestApiError, self).__init__(message)
431 class LandslideTclException(RuntimeError):
432 def __init__(self, message):
433 self._message = message
434 super(LandslideTclException, self).__init__(message)