Switch to a custom NotImplementedError

Some drivers/modules might raise NotImplementedError whereas we would
expect things to work. Skipping test when such an error is raised would
be a bad idea, we would know the test failed.
So let's switch to a custom NotImplementedError and let's skip test only
if this one is raised.

Closes-Bug: #1369556

Change-Id: Ie88a281787218f9aba13b6e662eb4d49d3e685d0
This commit is contained in:
Julien Danjou 2014-09-15 12:07:04 +02:00
parent 500388c3fe
commit 62008d4e5b
23 changed files with 140 additions and 83 deletions

View File

@ -0,0 +1,22 @@
# Copyright 2014 eNovance
#
# Authors: Julien Danjou <julien@danjou.info>
#
# Licensed 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.
class NotImplementedError(NotImplementedError):
# FIXME(jd) This is used by WSME to return a correct HTTP code. We should
# not expose it here but wrap our methods in the API to convert it to a
# proper HTTP error.
code = 501

View File

@ -17,6 +17,7 @@
# under the License. # under the License.
"""Base classes for storage engines """Base classes for storage engines
""" """
import ceilometer
class Connection(object): class Connection(object):
@ -46,7 +47,7 @@ class Connection(object):
def get_alarms(name=None, user=None, state=None, meter=None, def get_alarms(name=None, user=None, state=None, meter=None,
project=None, enabled=None, alarm_id=None, pagination=None): project=None, enabled=None, alarm_id=None, pagination=None):
"""Yields a lists of alarms that match filters.""" """Yields a lists of alarms that match filters."""
raise NotImplementedError('Alarms not implemented') raise ceilometer.NotImplementedError('Alarms not implemented')
@staticmethod @staticmethod
def create_alarm(alarm): def create_alarm(alarm):
@ -54,17 +55,17 @@ class Connection(object):
:param alarm: The alarm to create. :param alarm: The alarm to create.
""" """
raise NotImplementedError('Alarms not implemented') raise ceilometer.NotImplementedError('Alarms not implemented')
@staticmethod @staticmethod
def update_alarm(alarm): def update_alarm(alarm):
"""Update alarm.""" """Update alarm."""
raise NotImplementedError('Alarms not implemented') raise ceilometer.NotImplementedError('Alarms not implemented')
@staticmethod @staticmethod
def delete_alarm(alarm_id): def delete_alarm(alarm_id):
"""Delete an alarm.""" """Delete an alarm."""
raise NotImplementedError('Alarms not implemented') raise ceilometer.NotImplementedError('Alarms not implemented')
@staticmethod @staticmethod
def get_alarm_changes(alarm_id, on_behalf_of, def get_alarm_changes(alarm_id, on_behalf_of,
@ -94,12 +95,12 @@ class Connection(object):
:param end_timestamp: Optional modified timestamp end range :param end_timestamp: Optional modified timestamp end range
:param end_timestamp_op: Optional timestamp end range operation :param end_timestamp_op: Optional timestamp end range operation
""" """
raise NotImplementedError('Alarm history not implemented') raise ceilometer.NotImplementedError('Alarm history not implemented')
@staticmethod @staticmethod
def record_alarm_change(alarm_change): def record_alarm_change(alarm_change):
"""Record alarm change event.""" """Record alarm change event."""
raise NotImplementedError('Alarm history not implemented') raise ceilometer.NotImplementedError('Alarm history not implemented')
@staticmethod @staticmethod
def clear(): def clear():
@ -114,8 +115,8 @@ class Connection(object):
:param limit: Maximum number of results to return. :param limit: Maximum number of results to return.
""" """
raise NotImplementedError('Complex query for alarms ' raise ceilometer.NotImplementedError('Complex query for alarms '
'is not implemented.') 'is not implemented.')
@staticmethod @staticmethod
def query_alarm_history(filter_expr=None, orderby=None, limit=None): def query_alarm_history(filter_expr=None, orderby=None, limit=None):
@ -126,8 +127,8 @@ class Connection(object):
:param limit: Maximum number of results to return. :param limit: Maximum number of results to return.
""" """
raise NotImplementedError('Complex query for alarms ' raise ceilometer.NotImplementedError('Complex query for alarms '
'history is not implemented.') 'history is not implemented.')
@classmethod @classmethod
def get_capabilities(cls): def get_capabilities(cls):

View File

@ -19,6 +19,7 @@ import happybase
from oslo.utils import netutils from oslo.utils import netutils
from six.moves.urllib import parse as urlparse from six.moves.urllib import parse as urlparse
import ceilometer
from ceilometer.alarm.storage import base from ceilometer.alarm.storage import base
from ceilometer.alarm.storage import models from ceilometer.alarm.storage import models
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _
@ -178,9 +179,10 @@ class Connection(base.Connection):
project=None, enabled=None, alarm_id=None, pagination=None): project=None, enabled=None, alarm_id=None, pagination=None):
if pagination: if pagination:
raise NotImplementedError('Pagination not implemented') raise ceilometer.NotImplementedError('Pagination not implemented')
if meter: if meter:
raise NotImplementedError('Filter by meter not implemented') raise ceilometer.NotImplementedError(
'Filter by meter not implemented')
q = hbase_utils.make_query(alarm_id=alarm_id, name=name, q = hbase_utils.make_query(alarm_id=alarm_id, name=name,
enabled=enabled, user_id=user, enabled=enabled, user_id=user,

View File

@ -24,6 +24,7 @@ from oslo.db.sqlalchemy import migration
from oslo.db.sqlalchemy import session as db_session from oslo.db.sqlalchemy import session as db_session
from sqlalchemy import desc from sqlalchemy import desc
import ceilometer
from ceilometer.alarm.storage import base from ceilometer.alarm.storage import base
from ceilometer.alarm.storage import models as alarm_api_models from ceilometer.alarm.storage import models as alarm_api_models
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
@ -153,7 +154,7 @@ class Connection(base.Connection):
""" """
if pagination: if pagination:
raise NotImplementedError('Pagination not implemented') raise ceilometer.NotImplementedError('Pagination not implemented')
session = self._engine_facade.get_session() session = self._engine_facade.get_session()
query = session.query(models.Alarm) query = session.query(models.Alarm)

View File

@ -21,6 +21,7 @@
import pymongo import pymongo
import ceilometer
from ceilometer.alarm.storage import base from ceilometer.alarm.storage import base
from ceilometer.alarm.storage import models from ceilometer.alarm.storage import models
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
@ -92,7 +93,7 @@ class Connection(base.Connection):
:param pagination: Optional pagination query. :param pagination: Optional pagination query.
""" """
if pagination: if pagination:
raise NotImplementedError('Pagination not implemented') raise ceilometer.NotImplementedError('Pagination not implemented')
q = {} q = {}
if user is not None: if user is not None:

View File

@ -47,6 +47,7 @@ import wsme
from wsme import types as wtypes from wsme import types as wtypes
import wsmeext.pecan as wsme_pecan import wsmeext.pecan as wsme_pecan
import ceilometer
from ceilometer.alarm import service as alarm_service from ceilometer.alarm import service as alarm_service
from ceilometer.alarm.storage import models as alarm_models from ceilometer.alarm.storage import models as alarm_models
from ceilometer.api import acl from ceilometer.api import acl
@ -1990,7 +1991,7 @@ class AlarmController(rest.RestController):
try: try:
self.conn.record_alarm_change(payload) self.conn.record_alarm_change(payload)
except NotImplementedError: except ceilometer.NotImplementedError:
pass pass
# Revert to the pre-json'ed details ... # Revert to the pre-json'ed details ...
@ -2146,7 +2147,7 @@ class AlarmsController(rest.RestController):
try: try:
conn.record_alarm_change(payload) conn.record_alarm_change(payload)
except NotImplementedError: except ceilometer.NotImplementedError:
pass pass
# Revert to the pre-json'ed details ... # Revert to the pre-json'ed details ...

View File

@ -16,7 +16,7 @@
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
import ceilometer
from ceilometer.compute import plugin from ceilometer.compute import plugin
from ceilometer.compute.pollsters import util from ceilometer.compute.pollsters import util
from ceilometer.compute.virt import inspector as virt_inspector from ceilometer.compute.virt import inspector as virt_inspector
@ -50,7 +50,7 @@ class CPUPollster(plugin.ComputePollster):
except virt_inspector.InstanceNotFoundException as err: except virt_inspector.InstanceNotFoundException as err:
# Instance was deleted while getting samples. Ignore it. # Instance was deleted while getting samples. Ignore it.
LOG.debug(_('Exception while getting samples %s'), err) LOG.debug(_('Exception while getting samples %s'), err)
except NotImplementedError: except ceilometer.NotImplementedError:
# Selected inspector does not implement this pollster. # Selected inspector does not implement this pollster.
LOG.debug(_('Obtaining CPU time is not implemented for %s' LOG.debug(_('Obtaining CPU time is not implemented for %s'
), manager.inspector.__class__.__name__) ), manager.inspector.__class__.__name__)
@ -81,7 +81,7 @@ class CPUUtilPollster(plugin.ComputePollster):
except virt_inspector.InstanceNotFoundException as err: except virt_inspector.InstanceNotFoundException as err:
# Instance was deleted while getting samples. Ignore it. # Instance was deleted while getting samples. Ignore it.
LOG.debug(_('Exception while getting samples %s'), err) LOG.debug(_('Exception while getting samples %s'), err)
except NotImplementedError: except ceilometer.NotImplementedError:
# Selected inspector does not implement this pollster. # Selected inspector does not implement this pollster.
LOG.debug(_('Obtaining CPU Util is not implemented for %s'), LOG.debug(_('Obtaining CPU Util is not implemented for %s'),
manager.inspector.__class__.__name__) manager.inspector.__class__.__name__)

View File

@ -23,6 +23,7 @@ import collections
import six import six
import ceilometer
from ceilometer.compute import plugin from ceilometer.compute import plugin
from ceilometer.compute.pollsters import util from ceilometer.compute.pollsters import util
from ceilometer.compute.virt import inspector as virt_inspector from ceilometer.compute.virt import inspector as virt_inspector
@ -119,7 +120,7 @@ class _Base(plugin.ComputePollster):
except virt_inspector.InstanceNotFoundException as err: except virt_inspector.InstanceNotFoundException as err:
# Instance was deleted while getting samples. Ignore it. # Instance was deleted while getting samples. Ignore it.
LOG.debug(_('Exception while getting samples %s'), err) LOG.debug(_('Exception while getting samples %s'), err)
except NotImplementedError: except ceilometer.NotImplementedError:
# Selected inspector does not implement this pollster. # Selected inspector does not implement this pollster.
LOG.debug(_('%(inspector)s does not provide data for ' LOG.debug(_('%(inspector)s does not provide data for '
' %(pollster)s'), ' %(pollster)s'),
@ -324,7 +325,7 @@ class _DiskRatesPollsterBase(plugin.ComputePollster):
except virt_inspector.InstanceNotFoundException as err: except virt_inspector.InstanceNotFoundException as err:
# Instance was deleted while getting samples. Ignore it. # Instance was deleted while getting samples. Ignore it.
LOG.debug(_('Exception while getting samples %s'), err) LOG.debug(_('Exception while getting samples %s'), err)
except NotImplementedError: except ceilometer.NotImplementedError:
# Selected inspector does not implement this pollster. # Selected inspector does not implement this pollster.
LOG.debug(_('%(inspector)s does not provide data for ' LOG.debug(_('%(inspector)s does not provide data for '
' %(pollster)s'), ' %(pollster)s'),

View File

@ -12,7 +12,7 @@
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
import ceilometer
from ceilometer.compute import plugin from ceilometer.compute import plugin
from ceilometer.compute.pollsters import util from ceilometer.compute.pollsters import util
from ceilometer.compute.virt import inspector as virt_inspector from ceilometer.compute.virt import inspector as virt_inspector
@ -45,7 +45,7 @@ class MemoryUsagePollster(plugin.ComputePollster):
except virt_inspector.InstanceNotFoundException as err: except virt_inspector.InstanceNotFoundException as err:
# Instance was deleted while getting samples. Ignore it. # Instance was deleted while getting samples. Ignore it.
LOG.debug(_('Exception while getting samples %s'), err) LOG.debug(_('Exception while getting samples %s'), err)
except NotImplementedError: except ceilometer.NotImplementedError:
# Selected inspector does not implement this pollster. # Selected inspector does not implement this pollster.
LOG.debug(_('Obtaining Memory Usage is not implemented for %s' LOG.debug(_('Obtaining Memory Usage is not implemented for %s'
), manager.inspector.__class__.__name__) ), manager.inspector.__class__.__name__)

View File

@ -21,6 +21,7 @@ import copy
from oslo.utils import timeutils from oslo.utils import timeutils
import ceilometer
from ceilometer.compute import plugin from ceilometer.compute import plugin
from ceilometer.compute.pollsters import util from ceilometer.compute.pollsters import util
from ceilometer.compute.virt import inspector as virt_inspector from ceilometer.compute.virt import inspector as virt_inspector
@ -104,7 +105,7 @@ class _Base(plugin.ComputePollster):
except virt_inspector.InstanceNotFoundException as err: except virt_inspector.InstanceNotFoundException as err:
# Instance was deleted while getting samples. Ignore it. # Instance was deleted while getting samples. Ignore it.
LOG.debug(_('Exception while getting samples %s'), err) LOG.debug(_('Exception while getting samples %s'), err)
except NotImplementedError: except ceilometer.NotImplementedError:
# Selected inspector does not implement this pollster. # Selected inspector does not implement this pollster.
LOG.debug(_('%(inspector)s does not provide data for ' LOG.debug(_('%(inspector)s does not provide data for '
' %(pollster)s'), ' %(pollster)s'),

View File

@ -22,6 +22,7 @@ import collections
from oslo.config import cfg from oslo.config import cfg
from stevedore import driver from stevedore import driver
import ceilometer
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
@ -148,7 +149,7 @@ class Inspector(object):
def inspect_instances(self): def inspect_instances(self):
"""List the instances on the current host.""" """List the instances on the current host."""
raise NotImplementedError() raise ceilometer.NotImplementedError
def inspect_cpus(self, instance_name): def inspect_cpus(self, instance_name):
"""Inspect the CPU statistics for an instance. """Inspect the CPU statistics for an instance.
@ -156,7 +157,7 @@ class Inspector(object):
:param instance_name: the name of the target instance :param instance_name: the name of the target instance
:return: the number of CPUs and cumulative CPU time :return: the number of CPUs and cumulative CPU time
""" """
raise NotImplementedError() raise ceilometer.NotImplementedError
def inspect_cpu_util(self, instance, duration=None): def inspect_cpu_util(self, instance, duration=None):
"""Inspect the CPU Utilization (%) for an instance. """Inspect the CPU Utilization (%) for an instance.
@ -166,7 +167,7 @@ class Inspector(object):
inspected inspected
:return: the percentage of CPU utilization :return: the percentage of CPU utilization
""" """
raise NotImplementedError() raise ceilometer.NotImplementedError
def inspect_vnics(self, instance_name): def inspect_vnics(self, instance_name):
"""Inspect the vNIC statistics for an instance. """Inspect the vNIC statistics for an instance.
@ -175,7 +176,7 @@ class Inspector(object):
:return: for each vNIC, the number of bytes & packets :return: for each vNIC, the number of bytes & packets
received and transmitted received and transmitted
""" """
raise NotImplementedError() raise ceilometer.NotImplementedError
def inspect_vnic_rates(self, instance, duration=None): def inspect_vnic_rates(self, instance, duration=None):
"""Inspect the vNIC rate statistics for an instance. """Inspect the vNIC rate statistics for an instance.
@ -186,7 +187,7 @@ class Inspector(object):
:return: for each vNIC, the rate of bytes & packets :return: for each vNIC, the rate of bytes & packets
received and transmitted received and transmitted
""" """
raise NotImplementedError() raise ceilometer.NotImplementedError
def inspect_disks(self, instance_name): def inspect_disks(self, instance_name):
"""Inspect the disk statistics for an instance. """Inspect the disk statistics for an instance.
@ -195,7 +196,7 @@ class Inspector(object):
:return: for each disk, the number of bytes & operations :return: for each disk, the number of bytes & operations
read and written, and the error count read and written, and the error count
""" """
raise NotImplementedError() raise ceilometer.NotImplementedError
def inspect_memory_usage(self, instance, duration=None): def inspect_memory_usage(self, instance, duration=None):
"""Inspect the memory usage statistics for an instance. """Inspect the memory usage statistics for an instance.
@ -205,7 +206,7 @@ class Inspector(object):
inspected inspected
:return: the amount of memory used :return: the amount of memory used
""" """
raise NotImplementedError() raise ceilometer.NotImplementedError
def inspect_disk_rates(self, instance, duration=None): def inspect_disk_rates(self, instance, duration=None):
"""Inspect the disk statistics as rates for an instance. """Inspect the disk statistics as rates for an instance.
@ -216,7 +217,7 @@ class Inspector(object):
:return: for each disk, the number of bytes & operations :return: for each disk, the number of bytes & operations
read and written per second, with the error count read and written per second, with the error count
""" """
raise NotImplementedError() raise ceilometer.NotImplementedError
def get_hypervisor_inspector(): def get_hypervisor_inspector():

View File

@ -21,6 +21,7 @@ from oslo.config import cfg
import oslo.messaging import oslo.messaging
from stevedore import extension from stevedore import extension
import ceilometer
from ceilometer import dispatcher from ceilometer import dispatcher
from ceilometer.event import converter as event_converter from ceilometer.event import converter as event_converter
from ceilometer import messaging from ceilometer import messaging
@ -66,7 +67,7 @@ class EventsNotificationEndpoint(object):
try: try:
problem_events.extend( problem_events.extend(
dispatcher_ext.obj.record_events(event)) dispatcher_ext.obj.record_events(event))
except NotImplementedError: except ceilometer.NotImplementedError:
LOG.warn(_('Event is not implemented with the storage' LOG.warn(_('Event is not implemented with the storage'
' backend')) ' backend'))
if models.Event.UNKNOWN_PROBLEM in [x[0] for x in problem_events]: if models.Event.UNKNOWN_PROBLEM in [x[0] for x in problem_events]:

View File

@ -25,6 +25,8 @@ from oslo.utils import timeutils
import six import six
from six import moves from six import moves
import ceilometer
def iter_period(start, end, period): def iter_period(start, end, period):
"""Split a time from start to end in periods of a number of seconds. """Split a time from start to end in periods of a number of seconds.
@ -188,7 +190,8 @@ class Connection(object):
All timestamps must be naive utc datetime object. All timestamps must be naive utc datetime object.
""" """
raise NotImplementedError('Projects not implemented') raise ceilometer.NotImplementedError(
'Recording metering data is not implemented')
@staticmethod @staticmethod
def clear_expired_metering_data(ttl): def clear_expired_metering_data(ttl):
@ -198,7 +201,8 @@ class Connection(object):
:param ttl: Number of seconds to keep records for. :param ttl: Number of seconds to keep records for.
""" """
raise NotImplementedError('Clearing samples not implemented') raise ceilometer.NotImplementedError(
'Clearing samples not implemented')
@staticmethod @staticmethod
def get_resources(user=None, project=None, source=None, def get_resources(user=None, project=None, source=None,
@ -219,7 +223,7 @@ class Connection(object):
:param resource: Optional resource filter. :param resource: Optional resource filter.
:param pagination: Optional pagination query. :param pagination: Optional pagination query.
""" """
raise NotImplementedError('Resources not implemented') raise ceilometer.NotImplementedError('Resources not implemented')
@staticmethod @staticmethod
def get_meters(user=None, project=None, resource=None, source=None, def get_meters(user=None, project=None, resource=None, source=None,
@ -234,7 +238,7 @@ class Connection(object):
:param metaquery: Optional dict with metadata to match on. :param metaquery: Optional dict with metadata to match on.
:param pagination: Optional pagination query. :param pagination: Optional pagination query.
""" """
raise NotImplementedError('Meters not implemented') raise ceilometer.NotImplementedError('Meters not implemented')
@staticmethod @staticmethod
def get_samples(sample_filter, limit=None): def get_samples(sample_filter, limit=None):
@ -243,7 +247,7 @@ class Connection(object):
:param sample_filter: Filter. :param sample_filter: Filter.
:param limit: Maximum number of results to return. :param limit: Maximum number of results to return.
""" """
raise NotImplementedError('Samples not implemented') raise ceilometer.NotImplementedError('Samples not implemented')
@staticmethod @staticmethod
def get_meter_statistics(sample_filter, period=None, groupby=None, def get_meter_statistics(sample_filter, period=None, groupby=None,
@ -252,7 +256,7 @@ class Connection(object):
The filter must have a meter value set. The filter must have a meter value set.
""" """
raise NotImplementedError('Statistics not implemented') raise ceilometer.NotImplementedError('Statistics not implemented')
@staticmethod @staticmethod
def clear(): def clear():
@ -264,17 +268,17 @@ class Connection(object):
:param events: a list of model.Event objects. :param events: a list of model.Event objects.
""" """
raise NotImplementedError('Events not implemented.') raise ceilometer.NotImplementedError('Events not implemented.')
@staticmethod @staticmethod
def get_events(event_filter): def get_events(event_filter):
"""Return an iterable of model.Event objects.""" """Return an iterable of model.Event objects."""
raise NotImplementedError('Events not implemented.') raise ceilometer.NotImplementedError('Events not implemented.')
@staticmethod @staticmethod
def get_event_types(): def get_event_types():
"""Return all event types as an iterable of strings.""" """Return all event types as an iterable of strings."""
raise NotImplementedError('Events not implemented.') raise ceilometer.NotImplementedError('Events not implemented.')
@staticmethod @staticmethod
def get_trait_types(event_type): def get_trait_types(event_type):
@ -284,7 +288,7 @@ class Connection(object):
returned. returned.
:param event_type: the type of the Event :param event_type: the type of the Event
""" """
raise NotImplementedError('Events not implemented.') raise ceilometer.NotImplementedError('Events not implemented.')
@staticmethod @staticmethod
def get_traits(event_type, trait_type=None): def get_traits(event_type, trait_type=None):
@ -295,7 +299,7 @@ class Connection(object):
:param trait_type: the name of the Trait to filter by :param trait_type: the name of the Trait to filter by
""" """
raise NotImplementedError('Events not implemented.') raise ceilometer.NotImplementedError('Events not implemented.')
@staticmethod @staticmethod
def query_samples(filter_expr=None, orderby=None, limit=None): def query_samples(filter_expr=None, orderby=None, limit=None):
@ -306,8 +310,8 @@ class Connection(object):
:param limit: Maximum number of results to return. :param limit: Maximum number of results to return.
""" """
raise NotImplementedError('Complex query for samples ' raise ceilometer.NotImplementedError('Complex query for samples '
'is not implemented.') 'is not implemented.')
@classmethod @classmethod
def get_capabilities(cls): def get_capabilities(cls):

View File

@ -18,6 +18,7 @@ import copy
import re import re
import six import six
import ceilometer
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
@ -111,8 +112,9 @@ class MTable(object):
# in case of multiple filters # in case of multiple filters
rows = m(fargs, rows) rows = m(fargs, rows)
else: else:
raise NotImplementedError("%s filter is not implemented, " raise ceilometer.NotImplementedError(
"you may want to add it!") "%s filter is not implemented, "
"you may want to add it!")
for k in sorted(rows)[:limit]: for k in sorted(rows)[:limit]:
yield k, rows[k] yield k, rows[k]
@ -195,9 +197,10 @@ class MTable(object):
if g == row: if g == row:
r[row] = data r[row] = data
else: else:
raise NotImplementedError("In-memory " raise ceilometer.NotImplementedError(
"RowFilter doesn't support " "In-memory "
"the %s operation yet" % op) "RowFilter doesn't support "
"the %s operation yet" % op)
except AttributeError: except AttributeError:
pass pass
return r return r
@ -226,9 +229,10 @@ class MTable(object):
(op == '<' and key < column)): (op == '<' and key < column)):
r_data[key] = data[key] r_data[key] = data[key]
else: else:
raise NotImplementedError("In-memory QualifierFilter " raise ceilometer.NotImplementedError(
"doesn't support the %s " "In-memory QualifierFilter "
"operation yet" % op) "doesn't support the %s "
"operation yet" % op)
if r_data: if r_data:
r[row] = r_data r[row] = r_data
return r return r

View File

@ -32,6 +32,7 @@ from oslo.utils import timeutils
import pymongo import pymongo
import six import six
import ceilometer
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
from ceilometer import storage from ceilometer import storage
from ceilometer.storage import base from ceilometer.storage import base
@ -252,7 +253,7 @@ class Connection(pymongo_base.Connection):
:param pagination: Optional pagination query. :param pagination: Optional pagination query.
""" """
if pagination: if pagination:
raise NotImplementedError('Pagination not implemented') raise ceilometer.NotImplementedError('Pagination not implemented')
metaquery = metaquery or {} metaquery = metaquery or {}
@ -313,10 +314,12 @@ class Connection(pymongo_base.Connection):
if (groupby and if (groupby and
set(groupby) - set(['user_id', 'project_id', set(groupby) - set(['user_id', 'project_id',
'resource_id', 'source'])): 'resource_id', 'source'])):
raise NotImplementedError("Unable to group by these fields") raise ceilometer.NotImplementedError(
"Unable to group by these fields")
if aggregate: if aggregate:
raise NotImplementedError('Selectable aggregates not implemented') raise ceilometer.NotImplementedError(
'Selectable aggregates not implemented')
q = pymongo_utils.make_query_from_filter(sample_filter) q = pymongo_utils.make_query_from_filter(sample_filter)

View File

@ -22,6 +22,7 @@ from oslo.utils import netutils
from oslo.utils import timeutils from oslo.utils import timeutils
from six.moves.urllib import parse as urlparse from six.moves.urllib import parse as urlparse
import ceilometer
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
from ceilometer.storage import base from ceilometer.storage import base
@ -276,7 +277,7 @@ class Connection(base.Connection):
:param pagination: Optional pagination query. :param pagination: Optional pagination query.
""" """
if pagination: if pagination:
raise NotImplementedError('Pagination not implemented') raise ceilometer.NotImplementedError('Pagination not implemented')
q = hbase_utils.make_query(metaquery=metaquery, user_id=user, q = hbase_utils.make_query(metaquery=metaquery, user_id=user,
project_id=project, project_id=project,
@ -330,7 +331,8 @@ class Connection(base.Connection):
metaquery = metaquery or {} metaquery = metaquery or {}
if pagination: if pagination:
raise NotImplementedError(_('Pagination not implemented')) raise ceilometer.NotImplementedError(
_('Pagination not implemented'))
with self.conn_pool.connection() as conn: with self.conn_pool.connection() as conn:
resource_table = conn.table(self.RESOURCE_TABLE) resource_table = conn.table(self.RESOURCE_TABLE)
q = hbase_utils.make_query(metaquery=metaquery, user_id=user, q = hbase_utils.make_query(metaquery=metaquery, user_id=user,
@ -423,10 +425,11 @@ class Connection(base.Connection):
because of all the Thrift traffic it is going to create. because of all the Thrift traffic it is going to create.
""" """
if groupby: if groupby:
raise NotImplementedError("Group by not implemented.") raise ceilometer.NotImplementedError("Group by not implemented.")
if aggregate: if aggregate:
raise NotImplementedError('Selectable aggregates not implemented') raise ceilometer.NotImplementedError(
'Selectable aggregates not implemented')
with self.conn_pool.connection() as conn: with self.conn_pool.connection() as conn:
meter_table = conn.table(self.METER_TABLE) meter_table = conn.table(self.METER_TABLE)

View File

@ -34,6 +34,7 @@ from oslo.utils import timeutils
import pymongo import pymongo
import six import six
import ceilometer
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
from ceilometer import storage from ceilometer import storage
from ceilometer.storage import base from ceilometer.storage import base
@ -791,7 +792,7 @@ class Connection(pymongo_base.Connection):
:param pagination: Optional pagination query. :param pagination: Optional pagination query.
""" """
if pagination: if pagination:
raise NotImplementedError('Pagination not implemented') raise ceilometer.NotImplementedError('Pagination not implemented')
metaquery = metaquery or {} metaquery = metaquery or {}
@ -837,8 +838,9 @@ class Connection(pymongo_base.Connection):
params = dict(aggregate_param=a.param) params = dict(aggregate_param=a.param)
fragments += (fragment_map[a.func] % params) fragments += (fragment_map[a.func] % params)
else: else:
raise NotImplementedError('Selectable aggregate function %s' raise ceilometer.NotImplementedError(
' is not supported' % a.func) 'Selectable aggregate function %s'
' is not supported' % a.func)
return fragments return fragments
@ -852,7 +854,8 @@ class Connection(pymongo_base.Connection):
if (groupby and if (groupby and
set(groupby) - set(['user_id', 'project_id', set(groupby) - set(['user_id', 'project_id',
'resource_id', 'source'])): 'resource_id', 'source'])):
raise NotImplementedError("Unable to group by these fields") raise ceilometer.NotImplementedError(
"Unable to group by these fields")
q = pymongo_utils.make_query_from_filter(sample_filter) q = pymongo_utils.make_query_from_filter(sample_filter)

View File

@ -34,6 +34,7 @@ from sqlalchemy import distinct
from sqlalchemy import func from sqlalchemy import func
from sqlalchemy.orm import aliased from sqlalchemy.orm import aliased
import ceilometer
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _
from ceilometer.openstack.common import jsonutils from ceilometer.openstack.common import jsonutils
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
@ -114,9 +115,10 @@ def apply_metaquery_filter(session, query, metaquery):
try: try:
_model = sql_utils.META_TYPE_MAP[type(value)] _model = sql_utils.META_TYPE_MAP[type(value)]
except KeyError: except KeyError:
raise NotImplementedError('Query on %(key)s is of %(value)s ' raise ceilometer.NotImplementedError(
'type and is not supported' % 'Query on %(key)s is of %(value)s '
{"key": k, "value": type(value)}) 'type and is not supported' %
{"key": k, "value": type(value)})
else: else:
meta_alias = aliased(_model) meta_alias = aliased(_model)
on_clause = and_(models.Resource.internal_id == meta_alias.id, on_clause = and_(models.Resource.internal_id == meta_alias.id,
@ -390,7 +392,7 @@ class Connection(base.Connection):
:param pagination: Optional pagination query. :param pagination: Optional pagination query.
""" """
if pagination: if pagination:
raise NotImplementedError('Pagination not implemented') raise ceilometer.NotImplementedError('Pagination not implemented')
s_filter = storage.SampleFilter(user=user, s_filter = storage.SampleFilter(user=user,
project=project, project=project,
@ -457,7 +459,7 @@ class Connection(base.Connection):
""" """
if pagination: if pagination:
raise NotImplementedError('Pagination not implemented') raise ceilometer.NotImplementedError('Pagination not implemented')
s_filter = storage.SampleFilter(user=user, s_filter = storage.SampleFilter(user=user,
project=project, project=project,
@ -590,8 +592,9 @@ class Connection(base.Connection):
compute = PARAMETERIZED_AGGREGATES['compute'][a.func] compute = PARAMETERIZED_AGGREGATES['compute'][a.func]
functions.append(compute(a.param)) functions.append(compute(a.param))
else: else:
raise NotImplementedError('Selectable aggregate function %s' raise ceilometer.NotImplementedError(
' is not supported' % a.func) 'Selectable aggregate function %s'
' is not supported' % a.func)
return functions return functions
@ -666,8 +669,8 @@ class Connection(base.Connection):
if groupby: if groupby:
for group in groupby: for group in groupby:
if group not in ['user_id', 'project_id', 'resource_id']: if group not in ['user_id', 'project_id', 'resource_id']:
raise NotImplementedError('Unable to group by ' raise ceilometer.NotImplementedError('Unable to group by '
'these fields') 'these fields')
if not period: if not period:
for res in self._make_stats_query(sample_filter, for res in self._make_stats_query(sample_filter,

View File

@ -19,6 +19,7 @@
""" """
import pymongo import pymongo
import ceilometer
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
from ceilometer.storage import base from ceilometer.storage import base
@ -67,7 +68,7 @@ class Connection(base.Connection):
""" """
if pagination: if pagination:
raise NotImplementedError('Pagination not implemented') raise ceilometer.NotImplementedError('Pagination not implemented')
metaquery = metaquery or {} metaquery = metaquery or {}

View File

@ -24,6 +24,7 @@ from sqlalchemy import not_
from sqlalchemy import or_ from sqlalchemy import or_
from sqlalchemy.orm import aliased from sqlalchemy.orm import aliased
import ceilometer
from ceilometer.storage.sqlalchemy import models from ceilometer.storage.sqlalchemy import models
@ -79,8 +80,8 @@ class QueryTransformer(object):
def _handle_metadata(self, op, field_name, value): def _handle_metadata(self, op, field_name, value):
if op == self.operators["in"]: if op == self.operators["in"]:
raise NotImplementedError('Metadata query with in ' raise ceilometer.NotImplementedError('Metadata query with in '
'operator is not implemented') 'operator is not implemented')
field_name = field_name[len('resource_metadata.'):] field_name = field_name[len('resource_metadata.'):]
meta_table = META_TYPE_MAP[type(value)] meta_table = META_TYPE_MAP[type(value)]

View File

@ -27,7 +27,9 @@ from oslotest import base
from oslotest import mockpatch from oslotest import mockpatch
import six import six
from testtools import testcase from testtools import testcase
import webtest
import ceilometer
from ceilometer import messaging from ceilometer import messaging
@ -95,11 +97,9 @@ def _skip_decorator(func):
def skip_if_not_implemented(*args, **kwargs): def skip_if_not_implemented(*args, **kwargs):
try: try:
return func(*args, **kwargs) return func(*args, **kwargs)
except AssertionError: except ceilometer.NotImplementedError as e:
raise
except NotImplementedError as e:
raise testcase.TestSkipped(six.text_type(e)) raise testcase.TestSkipped(six.text_type(e))
except Exception as e: except webtest.app.AppError as e:
if 'not implemented' in six.text_type(e): if 'not implemented' in six.text_type(e):
raise testcase.TestSkipped(six.text_type(e)) raise testcase.TestSkipped(six.text_type(e))
raise raise

View File

@ -22,6 +22,7 @@ from oslo.config import fixture as fixture_config
import oslo.messaging import oslo.messaging
from stevedore import extension from stevedore import extension
import ceilometer
from ceilometer.event import endpoint as event_endpoint from ceilometer.event import endpoint as event_endpoint
from ceilometer.storage import models from ceilometer.storage import models
from ceilometer.tests import base as tests_base from ceilometer.tests import base as tests_base
@ -108,7 +109,8 @@ class TestEventEndpoint(tests_base.BaseTestCase):
@mock.patch('ceilometer.event.endpoint.LOG') @mock.patch('ceilometer.event.endpoint.LOG')
def test_event_not_implemented(self, log): def test_event_not_implemented(self, log):
self.mock_dispatcher.record_events.side_effect = NotImplementedError re = self.mock_dispatcher.record_events
re.side_effect = ceilometer.NotImplementedError
message = {'event_type': "foo", 'message_id': "abc"} message = {'event_type': "foo", 'message_id': "abc"}
ret = self.endpoint.process_notification(message) ret = self.endpoint.process_notification(message)
log.warn.assert_called_once_with( log.warn.assert_called_once_with(

View File

@ -25,6 +25,7 @@ import operator
import mock import mock
from oslo.utils import timeutils from oslo.utils import timeutils
import ceilometer
from ceilometer.alarm.storage import models as alarm_models from ceilometer.alarm.storage import models as alarm_models
from ceilometer.publisher import utils from ceilometer.publisher import utils
from ceilometer import sample from ceilometer import sample
@ -1536,7 +1537,7 @@ class StatisticsGroupByTest(DBTestBase,
# error before list() is called. By using lambda, we can cover both # error before list() is called. By using lambda, we can cover both
# MongoDB and SQLAlchemy in a single test. # MongoDB and SQLAlchemy in a single test.
self.assertRaises( self.assertRaises(
NotImplementedError, ceilometer.NotImplementedError,
lambda: list(self.conn.get_meter_statistics(f, groupby=['wtf'])) lambda: list(self.conn.get_meter_statistics(f, groupby=['wtf']))
) )