Merge "full pep8 compliance (part 2)"

This commit is contained in:
Jenkins 2013-11-22 10:54:50 +00:00 committed by Gerrit Code Review
commit 3ea0b70db0
37 changed files with 541 additions and 549 deletions

View File

@ -23,7 +23,7 @@ from ceilometerclient import client as ceiloclient
from oslo.config import cfg from oslo.config import cfg
import six import six
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _ # noqa
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
LOG = log.getLogger(__name__) LOG = log.getLogger(__name__)

View File

@ -18,7 +18,7 @@
from ceilometer.alarm import evaluator from ceilometer.alarm import evaluator
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _ # noqa
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
LOG = log.getLogger(__name__) LOG = log.getLogger(__name__)

View File

@ -21,7 +21,7 @@ import datetime
import operator import operator
from ceilometer.alarm import evaluator from ceilometer.alarm import evaluator
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _ # noqa
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
from ceilometer.openstack.common import timeutils from ceilometer.openstack.common import timeutils

View File

@ -21,7 +21,7 @@ import random
import uuid import uuid
from ceilometer.alarm import rpc as rpc_alarm from ceilometer.alarm import rpc as rpc_alarm
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _ # noqa
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
from ceilometer.openstack.common import timeutils from ceilometer.openstack.common import timeutils

View File

@ -19,10 +19,10 @@
from oslo.config import cfg from oslo.config import cfg
from ceilometer.openstack.common import context from ceilometer.openstack.common import context
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _ # noqa
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
from ceilometer.openstack.common.rpc import proxy as rpc_proxy from ceilometer.openstack.common.rpc import proxy as rpc_proxy
from ceilometer.storage.models import Alarm from ceilometer.storage import models
OPTS = [ OPTS = [
cfg.StrOpt('notifier_rpc_topic', cfg.StrOpt('notifier_rpc_topic',
@ -46,7 +46,7 @@ class RPCAlarmNotifier(rpc_proxy.RpcProxy):
topic=cfg.CONF.alarm.notifier_rpc_topic) topic=cfg.CONF.alarm.notifier_rpc_topic)
def notify(self, alarm, previous, reason): def notify(self, alarm, previous, reason):
actions = getattr(alarm, Alarm.ALARM_ACTIONS_MAP[alarm.state]) actions = getattr(alarm, models.Alarm.ALARM_ACTIONS_MAP[alarm.state])
if not actions: if not actions:
LOG.debug(_('alarm %(alarm_id)s has no action configured ' LOG.debug(_('alarm %(alarm_id)s has no action configured '
'for state transition from %(previous)s to ' 'for state transition from %(previous)s to '

View File

@ -27,14 +27,14 @@ from stevedore import extension
from ceilometer.alarm.partition import coordination from ceilometer.alarm.partition import coordination
from ceilometer.alarm import rpc as rpc_alarm from ceilometer.alarm import rpc as rpc_alarm
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _ # noqa
from ceilometer.openstack.common import importutils from ceilometer.openstack.common import importutils
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
from ceilometer.openstack.common import network_utils from ceilometer.openstack.common import network_utils
from ceilometer.openstack.common.rpc import dispatcher as rpc_dispatcher from ceilometer.openstack.common.rpc import dispatcher as rpc_dispatcher
from ceilometer.openstack.common.rpc import service as rpc_service from ceilometer.openstack.common.rpc import service as rpc_service
from ceilometer.openstack.common import service as os_service from ceilometer.openstack.common import service as os_service
from ceilometer.service import prepare_service from ceilometer import service
OPTS = [ OPTS = [
@ -139,9 +139,9 @@ class SingletonAlarmService(AlarmService, os_service.Service):
def alarm_evaluator(): def alarm_evaluator():
prepare_service() service.prepare_service()
service = importutils.import_object(cfg.CONF.alarm.evaluation_service) eval_service = importutils.import_object(cfg.CONF.alarm.evaluation_service)
os_service.launch(service).wait() os_service.launch(eval_service).wait()
cfg.CONF.import_opt('host', 'ceilometer.service') cfg.CONF.import_opt('host', 'ceilometer.service')
@ -280,6 +280,6 @@ class AlarmNotifierService(rpc_service.Service):
def alarm_notifier(): def alarm_notifier():
prepare_service() service.prepare_service()
os_service.launch(AlarmNotifierService( os_service.launch(AlarmNotifierService(
cfg.CONF.host, 'ceilometer.alarm')).wait() cfg.CONF.host, 'ceilometer.alarm')).wait()

View File

@ -40,7 +40,7 @@ import wsmeext.pecan as wsme_pecan
from ceilometer.api import acl from ceilometer.api import acl
from ceilometer.openstack.common import context from ceilometer.openstack.common import context
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _ # noqa
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
from ceilometer.openstack.common.notifier import api as notify from ceilometer.openstack.common.notifier import api as notify
from ceilometer.openstack.common import strutils from ceilometer.openstack.common import strutils

View File

@ -23,12 +23,9 @@ Based on pecan.middleware.errordocument
""" """
import json import json
from lxml import etree
import webob import webob
from xml import etree as et
try:
from xml.etree.ElementTree import ParseError
except ImportError:
from xml.parsers.expat import ExpatError as ParseError
from ceilometer.api import hooks from ceilometer.api import hooks
from ceilometer.openstack.common import gettextutils from ceilometer.openstack.common import gettextutils
@ -101,19 +98,16 @@ class ParsableErrorMiddleware(object):
== 'application/xml'): == 'application/xml'):
try: try:
# simple check xml is valid # simple check xml is valid
fault = et.ElementTree.fromstring('\n'.join(app_iter)) fault = etree.fromstring('\n'.join(app_iter))
# Add the translated error to the xml data # Add the translated error to the xml data
if error is not None: if error is not None:
for fault_string in fault.findall('faultstring'): for fault_string in fault.findall('faultstring'):
fault_string.text = ( fault_string.text = (
gettextutils.get_localized_message( gettextutils.get_localized_message(
error, user_locale)) error, user_locale))
body = [et.ElementTree.tostring( body = ['<error_message>' + etree.tostring(fault)
et.ElementTree.fromstring( + '</error_message>']
'<error_message>' except etree.XMLSyntaxError as err:
+ et.ElementTree.tostring(fault)
+ '</error_message>'))]
except ParseError as err:
LOG.error('Error parsing HTTP response: %s' % err) LOG.error('Error parsing HTTP response: %s' % err)
body = ['<error_message>%s' % state['status_code'] body = ['<error_message>%s' % state['status_code']
+ '</error_message>'] + '</error_message>']

View File

@ -24,14 +24,14 @@ from stevedore import extension
from stevedore import named from stevedore import named
from ceilometer.openstack.common import context from ceilometer.openstack.common import context
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _ # noqa
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
from ceilometer.openstack.common.rpc import dispatcher as rpc_dispatcher from ceilometer.openstack.common.rpc import dispatcher as rpc_dispatcher
from ceilometer.openstack.common.rpc import service as rpc_service from ceilometer.openstack.common.rpc import service as rpc_service
from ceilometer.openstack.common import service as os_service from ceilometer.openstack.common import service as os_service
from ceilometer.openstack.common import timeutils from ceilometer.openstack.common import timeutils
from ceilometer import pipeline from ceilometer import pipeline
from ceilometer.service import prepare_service from ceilometer import service
from ceilometer.storage import models from ceilometer.storage import models
from ceilometer import transformer from ceilometer import transformer
@ -117,7 +117,7 @@ class UDPCollectorService(CollectorBase, os_service.Service):
def udp_collector(): def udp_collector():
prepare_service() service.prepare_service()
os_service.launch(UDPCollectorService()).wait() os_service.launch(UDPCollectorService()).wait()
@ -294,6 +294,6 @@ class CollectorService(CollectorBase, rpc_service.Service):
def collector(): def collector():
prepare_service() service.prepare_service()
os_service.launch(CollectorService(cfg.CONF.host, os_service.launch(CollectorService(cfg.CONF.host,
'ceilometer.collector')).wait() 'ceilometer.collector')).wait()

View File

@ -36,7 +36,7 @@ from nova import utils
from stevedore import extension from stevedore import extension
from ceilometer.compute.virt import inspector from ceilometer.compute.virt import inspector
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _ # noqa
# This module runs inside the nova compute # This module runs inside the nova compute

View File

@ -28,7 +28,7 @@ if sys.platform == 'win32':
from oslo.config import cfg from oslo.config import cfg
from ceilometer.compute.virt import inspector from ceilometer.compute.virt import inspector
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _ # noqa
from ceilometer.openstack.common import log as logging from ceilometer.openstack.common import log as logging
CONF = cfg.CONF CONF = cfg.CONF

View File

@ -21,7 +21,7 @@ from oslo.config import cfg
import requests import requests
from ceilometer.central import plugin from ceilometer.central import plugin
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _ # noqa
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
from ceilometer import sample from ceilometer import sample

View File

@ -19,13 +19,13 @@
""" """
from __future__ import absolute_import from __future__ import absolute_import
from urlparse import urljoin import urlparse
from keystoneclient import exceptions from keystoneclient import exceptions
from oslo.config import cfg from oslo.config import cfg
from swiftclient import client as swift from swiftclient import client as swift
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _ # noqa
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
from ceilometer.openstack.common import timeutils from ceilometer.openstack.common import timeutils
from ceilometer import plugin from ceilometer import plugin
@ -74,7 +74,8 @@ class _Base(plugin.PollsterBase):
def _neaten_url(endpoint, tenant_id): def _neaten_url(endpoint, tenant_id):
"""Transform the registered url to standard and valid format. """Transform the registered url to standard and valid format.
""" """
return urljoin(endpoint, '/v1/' + cfg.CONF.reseller_prefix + tenant_id) return urlparse.urljoin(endpoint,
'/v1/' + cfg.CONF.reseller_prefix + tenant_id)
class ObjectsPollster(_Base): class ObjectsPollster(_Base):

View File

@ -23,7 +23,7 @@ import socket
import msgpack import msgpack
from oslo.config import cfg from oslo.config import cfg
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _ # noqa
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
from ceilometer.openstack.common import network_utils from ceilometer.openstack.common import network_utils
from ceilometer import publisher from ceilometer import publisher

View File

@ -32,7 +32,7 @@ import bson.code
import bson.objectid import bson.objectid
import pymongo import pymongo
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _ # noqa
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
from ceilometer.openstack.common import timeutils from ceilometer.openstack.common import timeutils
from ceilometer import storage from ceilometer import storage

View File

@ -29,7 +29,7 @@ import urlparse
import happybase import happybase
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _ # noqa
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
from ceilometer.openstack.common import network_utils from ceilometer.openstack.common import network_utils
from ceilometer.openstack.common import timeutils from ceilometer.openstack.common import timeutils

View File

@ -32,7 +32,7 @@ import pymongo
from oslo.config import cfg from oslo.config import cfg
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _ # noqa
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

View File

@ -30,27 +30,13 @@ from sqlalchemy.orm import aliased
from ceilometer.openstack.common.db import exception as dbexc from ceilometer.openstack.common.db import exception as dbexc
import ceilometer.openstack.common.db.sqlalchemy.session as sqlalchemy_session import ceilometer.openstack.common.db.sqlalchemy.session as sqlalchemy_session
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _ # noqa
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
from ceilometer.openstack.common import timeutils from ceilometer.openstack.common import timeutils
from ceilometer.storage import base from ceilometer.storage import base
from ceilometer.storage import models as api_models from ceilometer.storage import models as api_models
from ceilometer.storage.sqlalchemy import migration from ceilometer.storage.sqlalchemy import migration
from ceilometer.storage.sqlalchemy.models import Alarm from ceilometer.storage.sqlalchemy import models
from ceilometer.storage.sqlalchemy.models import AlarmChange
from ceilometer.storage.sqlalchemy.models import Base
from ceilometer.storage.sqlalchemy.models import Event
from ceilometer.storage.sqlalchemy.models import MetaBool
from ceilometer.storage.sqlalchemy.models import MetaFloat
from ceilometer.storage.sqlalchemy.models import MetaInt
from ceilometer.storage.sqlalchemy.models import MetaText
from ceilometer.storage.sqlalchemy.models import Meter
from ceilometer.storage.sqlalchemy.models import Project
from ceilometer.storage.sqlalchemy.models import Resource
from ceilometer.storage.sqlalchemy.models import Source
from ceilometer.storage.sqlalchemy.models import Trait
from ceilometer.storage.sqlalchemy.models import UniqueName
from ceilometer.storage.sqlalchemy.models import User
from ceilometer import utils from ceilometer import utils
LOG = log.getLogger(__name__) LOG = log.getLogger(__name__)
@ -106,13 +92,13 @@ class SQLAlchemyStorage(base.StorageEngine):
return Connection(conf) return Connection(conf)
META_TYPE_MAP = {bool: MetaBool, META_TYPE_MAP = {bool: models.MetaBool,
str: MetaText, str: models.MetaText,
unicode: MetaText, unicode: models.MetaText,
types.NoneType: MetaText, types.NoneType: models.MetaText,
int: MetaInt, int: models.MetaInt,
long: MetaInt, long: models.MetaInt,
float: MetaFloat} float: models.MetaFloat}
def apply_metaquery_filter(session, query, metaquery): def apply_metaquery_filter(session, query, metaquery):
@ -148,23 +134,23 @@ def make_query_from_filter(session, query, sample_filter, require_meter=True):
""" """
if sample_filter.meter: if sample_filter.meter:
query = query.filter(Meter.counter_name == sample_filter.meter) query = query.filter(models.Meter.counter_name == sample_filter.meter)
elif require_meter: elif require_meter:
raise RuntimeError(_('Missing required meter specifier')) raise RuntimeError(_('Missing required meter specifier'))
if sample_filter.source: if sample_filter.source:
query = query.filter(Meter.sources.any(id=sample_filter.source)) query = query.filter(models.Meter.sources.any(id=sample_filter.source))
if sample_filter.start: if sample_filter.start:
ts_start = sample_filter.start ts_start = sample_filter.start
if sample_filter.start_timestamp_op == 'gt': if sample_filter.start_timestamp_op == 'gt':
query = query.filter(Meter.timestamp > ts_start) query = query.filter(models.Meter.timestamp > ts_start)
else: else:
query = query.filter(Meter.timestamp >= ts_start) query = query.filter(models.Meter.timestamp >= ts_start)
if sample_filter.end: if sample_filter.end:
ts_end = sample_filter.end ts_end = sample_filter.end
if sample_filter.end_timestamp_op == 'le': if sample_filter.end_timestamp_op == 'le':
query = query.filter(Meter.timestamp <= ts_end) query = query.filter(models.Meter.timestamp <= ts_end)
else: else:
query = query.filter(Meter.timestamp < ts_end) query = query.filter(models.Meter.timestamp < ts_end)
if sample_filter.user: if sample_filter.user:
query = query.filter_by(user_id=sample_filter.user) query = query.filter_by(user_id=sample_filter.user)
if sample_filter.project: if sample_filter.project:
@ -195,7 +181,7 @@ class Connection(base.Connection):
def clear(self): def clear(self):
session = sqlalchemy_session.get_session() session = sqlalchemy_session.get_session()
engine = session.get_bind() engine = session.get_bind()
for table in reversed(Base.metadata.sorted_tables): for table in reversed(models.Base.metadata.sorted_tables):
engine.execute(table.delete()) engine.execute(table.delete())
@staticmethod @staticmethod
@ -244,20 +230,22 @@ class Connection(base.Connection):
with session.begin(): with session.begin():
# Record the updated resource metadata # Record the updated resource metadata
rmetadata = data['resource_metadata'] rmetadata = data['resource_metadata']
source = cls._create_or_update(session, Source, data['source']) source = cls._create_or_update(session, models.Source,
user = cls._create_or_update(session, User, data['user_id'], data['source'])
user = cls._create_or_update(session, models.User, data['user_id'],
source) source)
project = cls._create_or_update(session, Project, project = cls._create_or_update(session, models.Project,
data['project_id'], source) data['project_id'], source)
resource = cls._create_or_update(session, Resource, resource = cls._create_or_update(session, models.Resource,
data['resource_id'], source, data['resource_id'], source,
user=user, project=project, user=user, project=project,
resource_metadata=rmetadata) resource_metadata=rmetadata)
# Record the raw data for the meter. # Record the raw data for the meter.
meter = Meter(counter_type=data['counter_type'], meter = models.Meter(counter_type=data['counter_type'],
counter_unit=data['counter_unit'], counter_unit=data['counter_unit'],
counter_name=data['counter_name'], resource=resource) counter_name=data['counter_name'],
resource=resource)
session.add(meter) session.add(meter)
if not filter(lambda x: x.id == source.id, meter.sources): if not filter(lambda x: x.id == source.id, meter.sources):
meter.sources.append(source) meter.sources.append(source)
@ -292,24 +280,26 @@ class Connection(base.Connection):
""" """
session = sqlalchemy_session.get_session() session = sqlalchemy_session.get_session()
query = session.query(Meter.id) query = session.query(models.Meter.id)
end = timeutils.utcnow() - datetime.timedelta(seconds=ttl) end = timeutils.utcnow() - datetime.timedelta(seconds=ttl)
query = query.filter(Meter.timestamp < end) query = query.filter(models.Meter.timestamp < end)
query.delete() query.delete()
query = session.query(User.id).filter(~User.id.in_( query = session.query(models.User.id).filter(~models.User.id.in_(
session.query(Meter.user_id).group_by(Meter.user_id) session.query(models.Meter.user_id).group_by(models.Meter.user_id)
)) ))
query.delete(synchronize_session='fetch') query.delete(synchronize_session='fetch')
query = session.query(Project.id).filter(~Project.id.in_( query = session.query(models.Project.id)\
session.query(Meter.project_id).group_by(Meter.project_id) .filter(~models.Project.id.in_(
)) session.query(models.Meter.project_id).group_by(
models.Meter.project_id)))
query.delete(synchronize_session='fetch') query.delete(synchronize_session='fetch')
query = session.query(Resource.id).filter(~Resource.id.in_( query = session.query(models.Resource.id)\
session.query(Meter.resource_id).group_by(Meter.resource_id) .filter(~models.Resource.id.in_(
)) session.query(models.Meter.resource_id).group_by(
models.Meter.resource_id)))
query.delete(synchronize_session='fetch') query.delete(synchronize_session='fetch')
@staticmethod @staticmethod
@ -319,9 +309,9 @@ class Connection(base.Connection):
:param source: Optional source filter. :param source: Optional source filter.
""" """
session = sqlalchemy_session.get_session() session = sqlalchemy_session.get_session()
query = session.query(User.id) query = session.query(models.User.id)
if source is not None: if source is not None:
query = query.filter(User.sources.any(id=source)) query = query.filter(models.User.sources.any(id=source))
return (x[0] for x in query.all()) return (x[0] for x in query.all())
@staticmethod @staticmethod
@ -331,9 +321,9 @@ class Connection(base.Connection):
:param source: Optional source filter. :param source: Optional source filter.
""" """
session = sqlalchemy_session.get_session() session = sqlalchemy_session.get_session()
query = session.query(Project.id) query = session.query(models.Project.id)
if source: if source:
query = query.filter(Project.sources.any(id=source)) query = query.filter(models.Project.sources.any(id=source))
return (x[0] for x in query.all()) return (x[0] for x in query.all())
@staticmethod @staticmethod
@ -367,21 +357,21 @@ class Connection(base.Connection):
session = sqlalchemy_session.get_session() session = sqlalchemy_session.get_session()
ts_subquery = session.query( ts_subquery = session.query(
Meter.resource_id, models.Meter.resource_id,
func.max(Meter.timestamp).label("max_ts"), func.max(models.Meter.timestamp).label("max_ts"),
func.min(Meter.timestamp).label("min_ts") func.min(models.Meter.timestamp).label("min_ts")
).group_by(Meter.resource_id) ).group_by(models.Meter.resource_id)
# Here are the basic 'eq' operation filters for the sample data. # Here are the basic 'eq' operation filters for the sample data.
for column, value in [(Meter.resource_id, resource), for column, value in [(models.Meter.resource_id, resource),
(Meter.user_id, user), (models.Meter.user_id, user),
(Meter.project_id, project)]: (models.Meter.project_id, project)]:
if value: if value:
ts_subquery = ts_subquery.filter(column == value) ts_subquery = ts_subquery.filter(column == value)
if source: if source:
ts_subquery = ts_subquery.filter( ts_subquery = ts_subquery.filter(
Meter.sources.any(id=source)) models.Meter.sources.any(id=source))
if metaquery: if metaquery:
ts_subquery = apply_metaquery_filter(session, ts_subquery = apply_metaquery_filter(session,
@ -393,31 +383,27 @@ class Connection(base.Connection):
if start_timestamp: if start_timestamp:
if start_timestamp_op == 'gt': if start_timestamp_op == 'gt':
ts_subquery = ts_subquery.filter( ts_subquery = ts_subquery.filter(
Meter.timestamp > start_timestamp models.Meter.timestamp > start_timestamp)
)
else: else:
ts_subquery = ts_subquery.filter( ts_subquery = ts_subquery.filter(
Meter.timestamp >= start_timestamp models.Meter.timestamp >= start_timestamp)
)
if end_timestamp: if end_timestamp:
if end_timestamp_op == 'le': if end_timestamp_op == 'le':
ts_subquery = ts_subquery.filter( ts_subquery = ts_subquery.filter(
Meter.timestamp <= end_timestamp models.Meter.timestamp <= end_timestamp)
)
else: else:
ts_subquery = ts_subquery.filter( ts_subquery = ts_subquery.filter(
Meter.timestamp < end_timestamp models.Meter.timestamp < end_timestamp)
)
ts_subquery = ts_subquery.subquery() ts_subquery = ts_subquery.subquery()
# Now we need to get the max Meter.id out of the leftover results, to # Now we need to get the max Meter.id out of the leftover results, to
# break any ties. # break any ties.
agg_subquery = session.query( agg_subquery = session.query(
func.max(Meter.id).label("max_id"), func.max(models.Meter.id).label("max_id"),
ts_subquery ts_subquery
).filter( ).filter(
Meter.resource_id == ts_subquery.c.resource_id, models.Meter.resource_id == ts_subquery.c.resource_id,
Meter.timestamp == ts_subquery.c.max_ts models.Meter.timestamp == ts_subquery.c.max_ts
).group_by( ).group_by(
ts_subquery.c.resource_id, ts_subquery.c.resource_id,
ts_subquery.c.max_ts, ts_subquery.c.max_ts,
@ -425,11 +411,11 @@ class Connection(base.Connection):
).subquery() ).subquery()
query = session.query( query = session.query(
Meter, models.Meter,
agg_subquery.c.min_ts, agg_subquery.c.min_ts,
agg_subquery.c.max_ts agg_subquery.c.max_ts
).filter( ).filter(
Meter.id == agg_subquery.c.max_id models.Meter.id == agg_subquery.c.max_id
) )
for meter, first_ts, last_ts in query.all(): for meter, first_ts, last_ts in query.all():
@ -476,8 +462,9 @@ class Connection(base.Connection):
# max() is used to choice a meter record, so the latest record # max() is used to choice a meter record, so the latest record
# is selected for each (resource_id, counter_name). # is selected for each (resource_id, counter_name).
# #
subquery_meter = session.query(func.max(Meter.id).label('id')).\ subquery_meter = session.query(func.max(models.Meter.id).label('id'))\
group_by(Meter.resource_id, Meter.counter_name).subquery() .group_by(models.Meter.resource_id,
models.Meter.counter_name).subquery()
# The SQL of query_meter is essentially: # The SQL of query_meter is essentially:
# #
@ -486,26 +473,26 @@ class Connection(base.Connection):
# GROUP BY meter.resource_id, meter.counter_name) AS anon_2 # GROUP BY meter.resource_id, meter.counter_name) AS anon_2
# ON meter.id = anon_2.id # ON meter.id = anon_2.id
# #
query_meter = session.query(Meter).\ query_meter = session.query(models.Meter).\
join(subquery_meter, Meter.id == subquery_meter.c.id) join(subquery_meter, models.Meter.id == subquery_meter.c.id)
if metaquery: if metaquery:
query_meter = apply_metaquery_filter(session, query_meter = apply_metaquery_filter(session,
query_meter, query_meter,
metaquery) metaquery)
alias_meter = aliased(Meter, query_meter.subquery()) alias_meter = aliased(models.Meter, query_meter.subquery())
query = session.query(Resource, alias_meter).join( query = session.query(models.Resource, alias_meter).join(
alias_meter, Resource.id == alias_meter.resource_id) alias_meter, models.Resource.id == alias_meter.resource_id)
if user is not None: if user is not None:
query = query.filter(Resource.user_id == user) query = query.filter(models.Resource.user_id == user)
if source is not None: if source is not None:
query = query.filter(Resource.sources.any(id=source)) query = query.filter(models.Resource.sources.any(id=source))
if resource: if resource:
query = query.filter(Resource.id == resource) query = query.filter(models.Resource.id == resource)
if project is not None: if project is not None:
query = query.filter(Resource.project_id == project) query = query.filter(models.Resource.project_id == project)
for resource, meter in query.all(): for resource, meter in query.all():
yield api_models.Meter( yield api_models.Meter(
@ -528,12 +515,13 @@ class Connection(base.Connection):
return return
session = sqlalchemy_session.get_session() session = sqlalchemy_session.get_session()
query = session.query(Meter) query = session.query(models.Meter)
query = make_query_from_filter(session, query, sample_filter, query = make_query_from_filter(session, query, sample_filter,
require_meter=False) require_meter=False)
if limit: if limit:
query = query.limit(limit) query = query.limit(limit)
samples = query.from_self().order_by(desc(Meter.timestamp)).all() samples = query.from_self()\
.order_by(desc(models.Meter.timestamp)).all()
for s in samples: for s in samples:
# Remove the id generated by the database when # Remove the id generated by the database when
@ -560,20 +548,20 @@ class Connection(base.Connection):
@staticmethod @staticmethod
def _make_stats_query(sample_filter, groupby): def _make_stats_query(sample_filter, groupby):
select = [ select = [
Meter.counter_unit.label('unit'), models.Meter.counter_unit.label('unit'),
func.min(Meter.timestamp).label('tsmin'), func.min(models.Meter.timestamp).label('tsmin'),
func.max(Meter.timestamp).label('tsmax'), func.max(models.Meter.timestamp).label('tsmax'),
func.avg(Meter.counter_volume).label('avg'), func.avg(models.Meter.counter_volume).label('avg'),
func.sum(Meter.counter_volume).label('sum'), func.sum(models.Meter.counter_volume).label('sum'),
func.min(Meter.counter_volume).label('min'), func.min(models.Meter.counter_volume).label('min'),
func.max(Meter.counter_volume).label('max'), func.max(models.Meter.counter_volume).label('max'),
func.count(Meter.counter_volume).label('count'), func.count(models.Meter.counter_volume).label('count'),
] ]
session = sqlalchemy_session.get_session() session = sqlalchemy_session.get_session()
if groupby: if groupby:
group_attributes = [getattr(Meter, g) for g in groupby] group_attributes = [getattr(models.Meter, g) for g in groupby]
select.extend(group_attributes) select.extend(group_attributes)
query = session.query(*select) query = session.query(*select)
@ -640,8 +628,8 @@ class Connection(base.Connection):
sample_filter.start or res.tsmin, sample_filter.start or res.tsmin,
sample_filter.end or res.tsmax, sample_filter.end or res.tsmax,
period): period):
q = query.filter(Meter.timestamp >= period_start) q = query.filter(models.Meter.timestamp >= period_start)
q = q.filter(Meter.timestamp < period_end) q = q.filter(models.Meter.timestamp < period_end)
for r in q.all(): for r in q.all():
if r.count: if r.count:
yield self._stats_result_to_model( yield self._stats_result_to_model(
@ -686,17 +674,17 @@ class Connection(base.Connection):
raise NotImplementedError(_('Pagination not implemented')) raise NotImplementedError(_('Pagination not implemented'))
session = sqlalchemy_session.get_session() session = sqlalchemy_session.get_session()
query = session.query(Alarm) query = session.query(models.Alarm)
if name is not None: if name is not None:
query = query.filter(Alarm.name == name) query = query.filter(models.Alarm.name == name)
if enabled is not None: if enabled is not None:
query = query.filter(Alarm.enabled == enabled) query = query.filter(models.Alarm.enabled == enabled)
if user is not None: if user is not None:
query = query.filter(Alarm.user_id == user) query = query.filter(models.Alarm.user_id == user)
if project is not None: if project is not None:
query = query.filter(Alarm.project_id == project) query = query.filter(models.Alarm.project_id == project)
if alarm_id is not None: if alarm_id is not None:
query = query.filter(Alarm.id == alarm_id) query = query.filter(models.Alarm.id == alarm_id)
return (self._row_to_alarm_model(x) for x in query.all()) return (self._row_to_alarm_model(x) for x in query.all())
@ -707,9 +695,9 @@ class Connection(base.Connection):
""" """
session = sqlalchemy_session.get_session() session = sqlalchemy_session.get_session()
with session.begin(): with session.begin():
session.merge(User(id=alarm.user_id)) session.merge(models.User(id=alarm.user_id))
session.merge(Project(id=alarm.project_id)) session.merge(models.Project(id=alarm.project_id))
alarm_row = Alarm(id=alarm.alarm_id) alarm_row = models.Alarm(id=alarm.alarm_id)
alarm_row.update(alarm.as_dict()) alarm_row.update(alarm.as_dict())
session.add(alarm_row) session.add(alarm_row)
session.flush() session.flush()
@ -723,7 +711,7 @@ class Connection(base.Connection):
""" """
session = sqlalchemy_session.get_session() session = sqlalchemy_session.get_session()
with session.begin(): with session.begin():
alarm_row = session.merge(Alarm(id=alarm.alarm_id)) alarm_row = session.merge(models.Alarm(id=alarm.alarm_id))
alarm_row.update(alarm.as_dict()) alarm_row.update(alarm.as_dict())
session.flush() session.flush()
@ -737,7 +725,8 @@ class Connection(base.Connection):
""" """
session = sqlalchemy_session.get_session() session = sqlalchemy_session.get_session()
with session.begin(): with session.begin():
session.query(Alarm).filter(Alarm.id == alarm_id).delete() session.query(models.Alarm).filter(
models.Alarm.id == alarm_id).delete()
session.flush() session.flush()
@staticmethod @staticmethod
@ -779,29 +768,34 @@ class Connection(base.Connection):
:param end_timestamp_op: Optional timestamp end range operation :param end_timestamp_op: Optional timestamp end range operation
""" """
session = sqlalchemy_session.get_session() session = sqlalchemy_session.get_session()
query = session.query(AlarmChange) query = session.query(models.AlarmChange)
query = query.filter(AlarmChange.alarm_id == alarm_id) query = query.filter(models.AlarmChange.alarm_id == alarm_id)
if on_behalf_of is not None: if on_behalf_of is not None:
query = query.filter(AlarmChange.on_behalf_of == on_behalf_of) query = query.filter(
models.AlarmChange.on_behalf_of == on_behalf_of)
if user is not None: if user is not None:
query = query.filter(AlarmChange.user_id == user) query = query.filter(models.AlarmChange.user_id == user)
if project is not None: if project is not None:
query = query.filter(AlarmChange.project_id == project) query = query.filter(models.AlarmChange.project_id == project)
if type is not None: if type is not None:
query = query.filter(AlarmChange.type == type) query = query.filter(models.AlarmChange.type == type)
if start_timestamp: if start_timestamp:
if start_timestamp_op == 'gt': if start_timestamp_op == 'gt':
query = query.filter(AlarmChange.timestamp > start_timestamp) query = query.filter(
models.AlarmChange.timestamp > start_timestamp)
else: else:
query = query.filter(AlarmChange.timestamp >= start_timestamp) query = query.filter(
models.AlarmChange.timestamp >= start_timestamp)
if end_timestamp: if end_timestamp:
if end_timestamp_op == 'le': if end_timestamp_op == 'le':
query = query.filter(AlarmChange.timestamp <= end_timestamp) query = query.filter(
models.AlarmChange.timestamp <= end_timestamp)
else: else:
query = query.filter(AlarmChange.timestamp < end_timestamp) query = query.filter(
models.AlarmChange.timestamp < end_timestamp)
query = query.order_by(desc(AlarmChange.timestamp)) query = query.order_by(desc(models.AlarmChange.timestamp))
return (self._row_to_alarm_change_model(x) for x in query.all()) return (self._row_to_alarm_change_model(x) for x in query.all())
def record_alarm_change(self, alarm_change): def record_alarm_change(self, alarm_change):
@ -809,17 +803,19 @@ class Connection(base.Connection):
""" """
session = sqlalchemy_session.get_session() session = sqlalchemy_session.get_session()
with session.begin(): with session.begin():
session.merge(User(id=alarm_change['user_id'])) session.merge(models.User(id=alarm_change['user_id']))
session.merge(Project(id=alarm_change['project_id'])) session.merge(models.Project(id=alarm_change['project_id']))
session.merge(Project(id=alarm_change['on_behalf_of'])) session.merge(models.Project(id=alarm_change['on_behalf_of']))
alarm_change_row = AlarmChange(event_id=alarm_change['event_id']) alarm_change_row = models.AlarmChange(
event_id=alarm_change['event_id'])
alarm_change_row.update(alarm_change) alarm_change_row.update(alarm_change)
session.add(alarm_change_row) session.add(alarm_change_row)
session.flush() session.flush()
@staticmethod @staticmethod
def _get_unique(session, key): def _get_unique(session, key):
return session.query(UniqueName).filter(UniqueName.key == key).first() return session.query(models.UniqueName)\
.filter(models.UniqueName.key == key).first()
def _get_or_create_unique_name(self, key, session=None): def _get_or_create_unique_name(self, key, session=None):
"""Find the UniqueName entry for a given key, creating """Find the UniqueName entry for a given key, creating
@ -832,7 +828,7 @@ class Connection(base.Connection):
with session.begin(subtransactions=True): with session.begin(subtransactions=True):
unique = self._get_unique(session, key) unique = self._get_unique(session, key)
if not unique: if not unique:
unique = UniqueName(key=key) unique = models.UniqueName(key=key)
session.add(unique) session.add(unique)
session.flush() session.flush()
return unique return unique
@ -844,14 +840,14 @@ class Connection(base.Connection):
""" """
name = self._get_or_create_unique_name(trait_model.name, name = self._get_or_create_unique_name(trait_model.name,
session=session) session=session)
value_map = Trait._value_map value_map = models.Trait._value_map
values = {'t_string': None, 't_float': None, values = {'t_string': None, 't_float': None,
't_int': None, 't_datetime': None} 't_int': None, 't_datetime': None}
value = trait_model.value value = trait_model.value
if trait_model.dtype == api_models.Trait.DATETIME_TYPE: if trait_model.dtype == api_models.Trait.DATETIME_TYPE:
value = utils.dt_to_decimal(value) value = utils.dt_to_decimal(value)
values[value_map[trait_model.dtype]] = value values[value_map[trait_model.dtype]] = value
return Trait(name, event, trait_model.dtype, **values) return models.Trait(name, event, trait_model.dtype, **values)
def _record_event(self, session, event_model): def _record_event(self, session, event_model):
"""Store a single Event, including related Traits. """Store a single Event, including related Traits.
@ -861,7 +857,7 @@ class Connection(base.Connection):
session=session) session=session)
generated = utils.dt_to_decimal(event_model.generated) generated = utils.dt_to_decimal(event_model.generated)
event = Event(event_model.message_id, unique, generated) event = models.Event(event_model.message_id, unique, generated)
session.add(event) session.add(event)
new_traits = [] new_traits = []
@ -913,14 +909,15 @@ class Connection(base.Connection):
end = utils.dt_to_decimal(event_filter.end) end = utils.dt_to_decimal(event_filter.end)
session = sqlalchemy_session.get_session() session = sqlalchemy_session.get_session()
with session.begin(): with session.begin():
event_query_filters = [Event.generated >= start, event_query_filters = [models.Event.generated >= start,
Event.generated <= end] models.Event.generated <= end]
sub_query = session.query(Event.id)\ sub_query = session.query(models.Event.id)\
.join(Trait, Trait.event_id == Event.id) .join(models.Trait, models.Trait.event_id == models.Event.id)
if event_filter.event_name: if event_filter.event_name:
event_name = self._get_unique(session, event_filter.event_name) event_name = self._get_unique(session, event_filter.event_name)
event_query_filters.append(Event.unique_name == event_name) event_query_filters.append(
models.Event.unique_name == event_name)
sub_query = sub_query.filter(*event_query_filters) sub_query = sub_query.filter(*event_query_filters)
@ -929,19 +926,24 @@ class Connection(base.Connection):
for key, value in event_filter.traits.iteritems(): for key, value in event_filter.traits.iteritems():
if key == 'key': if key == 'key':
key = self._get_unique(session, value) key = self._get_unique(session, value)
sub_query = sub_query.filter(Trait.name == key) sub_query = sub_query.filter(models.Trait.name == key)
elif key == 't_string': elif key == 't_string':
sub_query = sub_query.filter(Trait.t_string == value) sub_query = sub_query.filter(
models.Trait.t_string == value)
elif key == 't_int': elif key == 't_int':
sub_query = sub_query.filter(Trait.t_int == value) sub_query = sub_query.filter(
models.Trait.t_int == value)
elif key == 't_datetime': elif key == 't_datetime':
dt = utils.dt_to_decimal(value) dt = utils.dt_to_decimal(value)
sub_query = sub_query.filter(Trait.t_datetime == dt) sub_query = sub_query.filter(
models.Trait.t_datetime == dt)
elif key == 't_float': elif key == 't_float':
sub_query = sub_query.filter(Trait.t_datetime == value) sub_query = sub_query.filter(
models.Trait.t_datetime == value)
else: else:
# Pre-populate event_models_dict to cover Events without traits # Pre-populate event_models_dict to cover Events without traits
events = session.query(Event).filter(*event_query_filters) events = session.query(models.Event)\
.filter(*event_query_filters)
for db_event in events.all(): for db_event in events.all():
generated = utils.decimal_to_dt(db_event.generated) generated = utils.decimal_to_dt(db_event.generated)
api_event = api_models.Event(db_event.message_id, api_event = api_models.Event(db_event.message_id,
@ -951,8 +953,8 @@ class Connection(base.Connection):
sub_query = sub_query.subquery() sub_query = sub_query.subquery()
all_data = session.query(Trait)\ all_data = session.query(models.Trait)\
.join(sub_query, Trait.event_id == sub_query.c.id) .join(sub_query, models.Trait.event_id == sub_query.c.id)
# Now convert the sqlalchemy objects back into Models ... # Now convert the sqlalchemy objects back into Models ...
for trait in all_data.all(): for trait in all_data.all():

View File

@ -11,8 +11,9 @@
# under the License. # under the License.
from __future__ import with_statement from __future__ import with_statement
from logging import config as log_config
from alembic import context from alembic import context
from logging.config import fileConfig
import ceilometer.openstack.common.db.sqlalchemy.session as sqlalchemy_session import ceilometer.openstack.common.db.sqlalchemy.session as sqlalchemy_session
from ceilometer.storage.sqlalchemy import models from ceilometer.storage.sqlalchemy import models
@ -23,7 +24,7 @@ config = context.config
# Interpret the config file for Python logging. # Interpret the config file for Python logging.
# This line sets up loggers basically. # This line sets up loggers basically.
fileConfig(config.config_file_name) log_config.fileConfig(config.config_file_name)
# add your model's MetaData object here # add your model's MetaData object here
# for 'autogenerate' support # for 'autogenerate' support

View File

@ -15,16 +15,16 @@
from sqlalchemy import Index from sqlalchemy import Index
from ceilometer.storage.sqlalchemy.models import Meter from ceilometer.storage.sqlalchemy import models
def upgrade(migrate_engine): def upgrade(migrate_engine):
index = Index('idx_meter_rid_cname', Meter.resource_id, index = Index('idx_meter_rid_cname', models.Meter.resource_id,
Meter.counter_name) models.Meter.counter_name)
index.create(bind=migrate_engine) index.create(bind=migrate_engine)
def downgrade(migrate_engine): def downgrade(migrate_engine):
index = Index('idx_meter_rid_cname', Meter.resource_id, index = Index('idx_meter_rid_cname', models.Meter.resource_id,
Meter.counter_name) models.Meter.counter_name)
index.drop(bind=migrate_engine) index.drop(bind=migrate_engine)

View File

@ -18,7 +18,7 @@
import sqlalchemy as sa import sqlalchemy as sa
from ceilometer.storage.sqlalchemy.models import PreciseTimestamp from ceilometer.storage.sqlalchemy import models
_col = 'timestamp' _col = 'timestamp'
@ -63,7 +63,8 @@ def upgrade(migrate_engine):
if migrate_engine.name == 'mysql': if migrate_engine.name == 'mysql':
meta = sa.MetaData(bind=migrate_engine) meta = sa.MetaData(bind=migrate_engine)
meter = sa.Table('meter', meta, autoload=True) meter = sa.Table('meter', meta, autoload=True)
_convert_data_type(meter, _col, sa.DateTime(), PreciseTimestamp(), _convert_data_type(meter, _col, sa.DateTime(),
models.PreciseTimestamp(),
pk_attr='id', index=True) pk_attr='id', index=True)
@ -71,5 +72,5 @@ def downgrade(migrate_engine):
if migrate_engine.name == 'mysql': if migrate_engine.name == 'mysql':
meta = sa.MetaData(bind=migrate_engine) meta = sa.MetaData(bind=migrate_engine)
meter = sa.Table('meter', meta, autoload=True) meter = sa.Table('meter', meta, autoload=True)
_convert_data_type(meter, _col, PreciseTimestamp(), sa.DateTime(), _convert_data_type(meter, _col, models.PreciseTimestamp(),
pk_attr='id', index=True) sa.DateTime(), pk_attr='id', index=True)

View File

@ -17,7 +17,7 @@
# under the License. # under the License.
"""Tests for ceilometer.alarm.service.PartitionedAlarmService. """Tests for ceilometer.alarm.service.PartitionedAlarmService.
""" """
from contextlib import nested import contextlib
import mock import mock
from stevedore import extension from stevedore import extension
@ -61,7 +61,8 @@ class TestPartitionedAlarmService(test.BaseTestCase):
group='alarm') group='alarm')
get_client = 'ceilometerclient.client.get_client' get_client = 'ceilometerclient.client.get_client'
create_conn = 'ceilometer.openstack.common.rpc.create_connection' create_conn = 'ceilometer.openstack.common.rpc.create_connection'
with nested(mock.patch(get_client, return_value=self.api_client), with contextlib.nested(mock.patch(get_client,
return_value=self.api_client),
mock.patch(create_conn)): mock.patch(create_conn)):
self.partitioned.start() self.partitioned.start()
pc = self.partitioned.partition_coordinator pc = self.partitioned.partition_coordinator

View File

@ -18,7 +18,7 @@
import uuid import uuid
from ceilometerclient.v2.alarms import Alarm as AlarmClient from ceilometerclient.v2 import alarms
import mock import mock
from ceilometer.alarm import rpc as rpc_alarm from ceilometer.alarm import rpc as rpc_alarm
@ -27,7 +27,7 @@ from ceilometer.openstack.common.fixture import mockpatch
from ceilometer.openstack.common import rpc from ceilometer.openstack.common import rpc
from ceilometer.openstack.common import test from ceilometer.openstack.common import test
from ceilometer.openstack.common import timeutils from ceilometer.openstack.common import timeutils
from ceilometer.storage.models import Alarm as AlarmModel from ceilometer.storage import models
class TestRPCAlarmNotifier(test.BaseTestCase): class TestRPCAlarmNotifier(test.BaseTestCase):
@ -43,7 +43,7 @@ class TestRPCAlarmNotifier(test.BaseTestCase):
side_effect=self.fake_cast)) side_effect=self.fake_cast))
self.notifier = rpc_alarm.RPCAlarmNotifier() self.notifier = rpc_alarm.RPCAlarmNotifier()
self.alarms = [ self.alarms = [
AlarmClient(None, info={ alarms.Alarm(None, info={
'name': 'instance_running_hot', 'name': 'instance_running_hot',
'meter_name': 'cpu_util', 'meter_name': 'cpu_util',
'comparison_operator': 'gt', 'comparison_operator': 'gt',
@ -59,7 +59,7 @@ class TestRPCAlarmNotifier(test.BaseTestCase):
'matching_metadata':{'resource_id': 'matching_metadata':{'resource_id':
'my_instance'} 'my_instance'}
}), }),
AlarmClient(None, info={ alarms.Alarm(None, info={
'name': 'group_running_idle', 'name': 'group_running_idle',
'meter_name': 'cpu_util', 'meter_name': 'cpu_util',
'comparison_operator': 'le', 'comparison_operator': 'le',
@ -83,7 +83,7 @@ class TestRPCAlarmNotifier(test.BaseTestCase):
self.notifier.notify(a, previous[i], "what? %d" % i) self.notifier.notify(a, previous[i], "what? %d" % i)
self.assertEqual(len(self.notified), 2) self.assertEqual(len(self.notified), 2)
for i, a in enumerate(self.alarms): for i, a in enumerate(self.alarms):
actions = getattr(a, AlarmModel.ALARM_ACTIONS_MAP[a.state]) actions = getattr(a, models.Alarm.ALARM_ACTIONS_MAP[a.state])
self.assertEqual(self.notified[i][0], self.assertEqual(self.notified[i][0],
self.CONF.alarm.notifier_rpc_topic) self.CONF.alarm.notifier_rpc_topic)
self.assertEqual(self.notified[i][1]["args"]["data"]["alarm_id"], self.assertEqual(self.notified[i][1]["args"]["data"]["alarm_id"],
@ -103,7 +103,7 @@ class TestRPCAlarmNotifier(test.BaseTestCase):
self.assertTrue(isinstance(reason, basestring)) self.assertTrue(isinstance(reason, basestring))
def test_notify_no_actions(self): def test_notify_no_actions(self):
alarm = AlarmClient(None, info={ alarm = alarms.Alarm(None, info={
'name': 'instance_running_hot', 'name': 'instance_running_hot',
'meter_name': 'cpu_util', 'meter_name': 'cpu_util',
'comparison_operator': 'gt', 'comparison_operator': 'gt',

View File

@ -28,7 +28,7 @@ import uuid
import mock import mock
import testscenarios import testscenarios
from ceilometer.storage.models import Alarm from ceilometer.storage import models
from ceilometer.tests.api.v2 import FunctionalTest from ceilometer.tests.api.v2 import FunctionalTest
from ceilometer.tests import db as tests_db from ceilometer.tests import db as tests_db
@ -53,7 +53,8 @@ class TestAlarms(FunctionalTest,
super(TestAlarms, self).setUp() super(TestAlarms, self).setUp()
self.auth_headers = {'X-User-Id': str(uuid.uuid4()), self.auth_headers = {'X-User-Id': str(uuid.uuid4()),
'X-Project-Id': str(uuid.uuid4())} 'X-Project-Id': str(uuid.uuid4())}
for alarm in [Alarm(name='name1', for alarm in [
models.Alarm(name='name1',
type='threshold', type='threshold',
enabled=True, enabled=True,
alarm_id='a', alarm_id='a',
@ -73,13 +74,12 @@ class TestAlarms(FunctionalTest,
evaluation_periods=60, evaluation_periods=60,
period=1, period=1,
meter_name='meter.test', meter_name='meter.test',
query=[ query=[{'field': 'project_id',
{'field': 'project_id',
'op': 'eq', 'value': 'op': 'eq', 'value':
self.auth_headers['X-Project-Id']} self.auth_headers['X-Project-Id']}
]) ])
), ),
Alarm(name='name2', models.Alarm(name='name2',
type='threshold', type='threshold',
enabled=True, enabled=True,
alarm_id='b', alarm_id='b',
@ -99,13 +99,12 @@ class TestAlarms(FunctionalTest,
evaluation_periods=60, evaluation_periods=60,
period=1, period=1,
meter_name='meter.test', meter_name='meter.test',
query=[ query=[{'field': 'project_id',
{'field': 'project_id',
'op': 'eq', 'value': 'op': 'eq', 'value':
self.auth_headers['X-Project-Id']} self.auth_headers['X-Project-Id']}
]) ])
), ),
Alarm(name='name3', models.Alarm(name='name3',
type='threshold', type='threshold',
enabled=True, enabled=True,
alarm_id='c', alarm_id='c',
@ -125,13 +124,12 @@ class TestAlarms(FunctionalTest,
evaluation_periods=60, evaluation_periods=60,
period=1, period=1,
meter_name='meter.mine', meter_name='meter.mine',
query=[ query=[{'field': 'project_id',
{'field': 'project_id',
'op': 'eq', 'value': 'op': 'eq', 'value':
self.auth_headers['X-Project-Id']} self.auth_headers['X-Project-Id']}
]) ])
), ),
Alarm(name='name4', models.Alarm(name='name4',
type='combination', type='combination',
enabled=True, enabled=True,
alarm_id='d', alarm_id='d',
@ -145,12 +143,9 @@ class TestAlarms(FunctionalTest,
repeat_actions=False, repeat_actions=False,
user_id=self.auth_headers['X-User-Id'], user_id=self.auth_headers['X-User-Id'],
project_id=self.auth_headers['X-Project-Id'], project_id=self.auth_headers['X-Project-Id'],
rule=dict(alarm_ids=[ rule=dict(alarm_ids=['a', 'b'],
'a',
'b'],
operator='or') operator='or')
) )]:
]:
self.conn.update_alarm(alarm) self.conn.update_alarm(alarm)
def test_list_alarms(self): def test_list_alarms(self):
@ -189,7 +184,7 @@ class TestAlarms(FunctionalTest,
self.assertEqual(one['repeat_actions'], alarms[0]['repeat_actions']) self.assertEqual(one['repeat_actions'], alarms[0]['repeat_actions'])
def test_get_alarm_disabled(self): def test_get_alarm_disabled(self):
alarm = Alarm(name='disabled', alarm = models.Alarm(name='disabled',
type='combination', type='combination',
enabled=False, enabled=False,
alarm_id='d', alarm_id='d',
@ -222,15 +217,13 @@ class TestAlarms(FunctionalTest,
}]) }])
self.assertEqual(alarms[0]['name'], 'name4') self.assertEqual(alarms[0]['name'], 'name4')
self.assertEqual(alarms[0]['combination_rule']['alarm_ids'], self.assertEqual(alarms[0]['combination_rule']['alarm_ids'],
['a', ['a', 'b'])
'b'])
self.assertEqual(alarms[0]['combination_rule']['operator'], 'or') self.assertEqual(alarms[0]['combination_rule']['operator'], 'or')
one = self.get_json('/alarms/%s' % alarms[0]['alarm_id']) one = self.get_json('/alarms/%s' % alarms[0]['alarm_id'])
self.assertEqual(one['name'], 'name4') self.assertEqual(one['name'], 'name4')
self.assertEqual(alarms[0]['combination_rule']['alarm_ids'], self.assertEqual(alarms[0]['combination_rule']['alarm_ids'],
['a', ['a', 'b'])
'b'])
self.assertEqual(alarms[0]['combination_rule']['operator'], 'or') self.assertEqual(alarms[0]['combination_rule']['operator'], 'or')
self.assertEqual(one['alarm_id'], alarms[0]['alarm_id']) self.assertEqual(one['alarm_id'], alarms[0]['alarm_id'])
self.assertEqual(one['repeat_actions'], alarms[0]['repeat_actions']) self.assertEqual(one['repeat_actions'], alarms[0]['repeat_actions'])

View File

@ -21,7 +21,6 @@ import mock
import wsme import wsme
from ceilometer.api.controllers import v2 as api from ceilometer.api.controllers import v2 as api
from ceilometer.api.controllers.v2 import Query
from ceilometer.openstack.common.fixture.mockpatch import PatchObject from ceilometer.openstack.common.fixture.mockpatch import PatchObject
from ceilometer.openstack.common import test from ceilometer.openstack.common import test
from ceilometer.openstack.common import timeutils from ceilometer.openstack.common import timeutils
@ -36,7 +35,7 @@ class TestQuery(test.BaseTestCase):
'pecan.response', mock.MagicMock())) 'pecan.response', mock.MagicMock()))
def test_get_value_as_type_with_integer(self): def test_get_value_as_type_with_integer(self):
query = Query(field='metadata.size', query = api.Query(field='metadata.size',
op='eq', op='eq',
value='123', value='123',
type='integer') type='integer')
@ -44,7 +43,7 @@ class TestQuery(test.BaseTestCase):
self.assertEqual(query._get_value_as_type(), expected) self.assertEqual(query._get_value_as_type(), expected)
def test_get_value_as_type_with_float(self): def test_get_value_as_type_with_float(self):
query = Query(field='metadata.size', query = api.Query(field='metadata.size',
op='eq', op='eq',
value='123.456', value='123.456',
type='float') type='float')
@ -52,7 +51,7 @@ class TestQuery(test.BaseTestCase):
self.assertEqual(query._get_value_as_type(), expected) self.assertEqual(query._get_value_as_type(), expected)
def test_get_value_as_type_with_boolean(self): def test_get_value_as_type_with_boolean(self):
query = Query(field='metadata.is_public', query = api.Query(field='metadata.is_public',
op='eq', op='eq',
value='True', value='True',
type='boolean') type='boolean')
@ -60,7 +59,7 @@ class TestQuery(test.BaseTestCase):
self.assertEqual(query._get_value_as_type(), expected) self.assertEqual(query._get_value_as_type(), expected)
def test_get_value_as_type_with_string(self): def test_get_value_as_type_with_string(self):
query = Query(field='metadata.name', query = api.Query(field='metadata.name',
op='eq', op='eq',
value='linux', value='linux',
type='string') type='string')
@ -68,42 +67,42 @@ class TestQuery(test.BaseTestCase):
self.assertEqual(query._get_value_as_type(), expected) self.assertEqual(query._get_value_as_type(), expected)
def test_get_value_as_type_with_integer_without_type(self): def test_get_value_as_type_with_integer_without_type(self):
query = Query(field='metadata.size', query = api.Query(field='metadata.size',
op='eq', op='eq',
value='123') value='123')
expected = 123 expected = 123
self.assertEqual(query._get_value_as_type(), expected) self.assertEqual(query._get_value_as_type(), expected)
def test_get_value_as_type_with_float_without_type(self): def test_get_value_as_type_with_float_without_type(self):
query = Query(field='metadata.size', query = api.Query(field='metadata.size',
op='eq', op='eq',
value='123.456') value='123.456')
expected = 123.456 expected = 123.456
self.assertEqual(query._get_value_as_type(), expected) self.assertEqual(query._get_value_as_type(), expected)
def test_get_value_as_type_with_boolean_without_type(self): def test_get_value_as_type_with_boolean_without_type(self):
query = Query(field='metadata.is_public', query = api.Query(field='metadata.is_public',
op='eq', op='eq',
value='True') value='True')
expected = True expected = True
self.assertEqual(query._get_value_as_type(), expected) self.assertEqual(query._get_value_as_type(), expected)
def test_get_value_as_type_with_string_without_type(self): def test_get_value_as_type_with_string_without_type(self):
query = Query(field='metadata.name', query = api.Query(field='metadata.name',
op='eq', op='eq',
value='linux') value='linux')
expected = 'linux' expected = 'linux'
self.assertEqual(query._get_value_as_type(), expected) self.assertEqual(query._get_value_as_type(), expected)
def test_get_value_as_type_with_bad_type(self): def test_get_value_as_type_with_bad_type(self):
query = Query(field='metadata.size', query = api.Query(field='metadata.size',
op='eq', op='eq',
value='123.456', value='123.456',
type='blob') type='blob')
self.assertRaises(wsme.exc.ClientSideError, query._get_value_as_type) self.assertRaises(wsme.exc.ClientSideError, query._get_value_as_type)
def test_get_value_as_type_with_bad_value(self): def test_get_value_as_type_with_bad_value(self):
query = Query(field='metadata.size', query = api.Query(field='metadata.size',
op='eq', op='eq',
value='fake', value='fake',
type='integer') type='integer')
@ -111,7 +110,7 @@ class TestQuery(test.BaseTestCase):
def test_get_value_as_type_integer_expression_without_type(self): def test_get_value_as_type_integer_expression_without_type(self):
# bug 1221736 # bug 1221736
query = Query(field='should_be_a_string', query = api.Query(field='should_be_a_string',
op='eq', op='eq',
value='123-1') value='123-1')
expected = '123-1' expected = '123-1'
@ -119,7 +118,7 @@ class TestQuery(test.BaseTestCase):
def test_get_value_as_type_boolean_expression_without_type(self): def test_get_value_as_type_boolean_expression_without_type(self):
# bug 1221736 # bug 1221736
query = Query(field='should_be_a_string', query = api.Query(field='should_be_a_string',
op='eq', op='eq',
value='True or False') value='True or False')
expected = 'True or False' expected = 'True or False'
@ -128,7 +127,7 @@ class TestQuery(test.BaseTestCase):
def test_get_value_as_type_with_syntax_error(self): def test_get_value_as_type_with_syntax_error(self):
# bug 1221736 # bug 1221736
value = 'WWW-Layer-4a80714f-0232-4580-aa5e-81494d1a4147-uolhh25p5xxm' value = 'WWW-Layer-4a80714f-0232-4580-aa5e-81494d1a4147-uolhh25p5xxm'
query = Query(field='group_id', query = api.Query(field='group_id',
op='eq', op='eq',
value=value) value=value)
expected = value expected = value
@ -137,7 +136,7 @@ class TestQuery(test.BaseTestCase):
def test_get_value_as_type_with_syntax_error_colons(self): def test_get_value_as_type_with_syntax_error_colons(self):
# bug 1221736 # bug 1221736
value = 'Ref::StackId' value = 'Ref::StackId'
query = Query(field='field_name', query = api.Query(field='field_name',
op='eq', op='eq',
value=value) value=value)
expected = value expected = value
@ -182,7 +181,7 @@ class TestQueryToKwArgs(tests_base.BaseTestCase):
side_effect=lambda x, **z: x)) side_effect=lambda x, **z: x))
def test_sample_filter_single(self): def test_sample_filter_single(self):
q = [Query(field='user_id', q = [api.Query(field='user_id',
op='eq', op='eq',
value='uid')] value='uid')]
kwargs = api._query_to_kwargs(q, storage.SampleFilter.__init__) kwargs = api._query_to_kwargs(q, storage.SampleFilter.__init__)
@ -191,19 +190,19 @@ class TestQueryToKwArgs(tests_base.BaseTestCase):
self.assertEqual(kwargs['user'], 'uid') self.assertEqual(kwargs['user'], 'uid')
def test_sample_filter_multi(self): def test_sample_filter_multi(self):
q = [Query(field='user_id', q = [api.Query(field='user_id',
op='eq', op='eq',
value='uid'), value='uid'),
Query(field='project_id', api.Query(field='project_id',
op='eq', op='eq',
value='pid'), value='pid'),
Query(field='resource_id', api.Query(field='resource_id',
op='eq', op='eq',
value='rid'), value='rid'),
Query(field='source', api.Query(field='source',
op='eq', op='eq',
value='source_name'), value='source_name'),
Query(field='meter', api.Query(field='meter',
op='eq', op='eq',
value='meter_name')] value='meter_name')]
kwargs = api._query_to_kwargs(q, storage.SampleFilter.__init__) kwargs = api._query_to_kwargs(q, storage.SampleFilter.__init__)
@ -217,10 +216,10 @@ class TestQueryToKwArgs(tests_base.BaseTestCase):
def test_sample_filter_timestamp(self): def test_sample_filter_timestamp(self):
ts_start = timeutils.utcnow() ts_start = timeutils.utcnow()
ts_end = ts_start + datetime.timedelta(minutes=5) ts_end = ts_start + datetime.timedelta(minutes=5)
q = [Query(field='timestamp', q = [api.Query(field='timestamp',
op='lt', op='lt',
value=str(ts_end)), value=str(ts_end)),
Query(field='timestamp', api.Query(field='timestamp',
op='gt', op='gt',
value=str(ts_start))] value=str(ts_start))]
kwargs = api._query_to_kwargs(q, storage.SampleFilter.__init__) kwargs = api._query_to_kwargs(q, storage.SampleFilter.__init__)
@ -231,10 +230,10 @@ class TestQueryToKwArgs(tests_base.BaseTestCase):
self.assertEqual(kwargs['end_timestamp_op'], 'lt') self.assertEqual(kwargs['end_timestamp_op'], 'lt')
def test_sample_filter_meta(self): def test_sample_filter_meta(self):
q = [Query(field='metadata.size', q = [api.Query(field='metadata.size',
op='eq', op='eq',
value='20'), value='20'),
Query(field='resource_metadata.id', api.Query(field='resource_metadata.id',
op='eq', op='eq',
value='meta_id')] value='meta_id')]
kwargs = api._query_to_kwargs(q, storage.SampleFilter.__init__) kwargs = api._query_to_kwargs(q, storage.SampleFilter.__init__)
@ -244,11 +243,11 @@ class TestQueryToKwArgs(tests_base.BaseTestCase):
self.assertEqual(kwargs['metaquery']['metadata.id'], 'meta_id') self.assertEqual(kwargs['metaquery']['metadata.id'], 'meta_id')
def test_sample_filter_non_equality_on_metadata(self): def test_sample_filter_non_equality_on_metadata(self):
queries = [Query(field='resource_metadata.image_id', queries = [api.Query(field='resource_metadata.image_id',
op='gt', op='gt',
value='image', value='image',
type='string'), type='string'),
Query(field='metadata.ramdisk_id', api.Query(field='metadata.ramdisk_id',
op='le', op='le',
value='ramdisk', value='ramdisk',
type='string')] type='string')]
@ -261,7 +260,7 @@ class TestQueryToKwArgs(tests_base.BaseTestCase):
storage.SampleFilter.__init__) storage.SampleFilter.__init__)
def test_sample_filter_invalid_field(self): def test_sample_filter_invalid_field(self):
q = [Query(field='invalid', q = [api.Query(field='invalid',
op='eq', op='eq',
value='20')] value='20')]
self.assertRaises( self.assertRaises(
@ -269,7 +268,7 @@ class TestQueryToKwArgs(tests_base.BaseTestCase):
api._query_to_kwargs, q, storage.SampleFilter.__init__) api._query_to_kwargs, q, storage.SampleFilter.__init__)
def test_sample_filter_invalid_op(self): def test_sample_filter_invalid_op(self):
q = [Query(field='user_id', q = [api.Query(field='user_id',
op='lt', op='lt',
value='20')] value='20')]
self.assertRaises( self.assertRaises(
@ -278,7 +277,7 @@ class TestQueryToKwArgs(tests_base.BaseTestCase):
def test_sample_filter_timestamp_invalid_op(self): def test_sample_filter_timestamp_invalid_op(self):
ts_start = timeutils.utcnow() ts_start = timeutils.utcnow()
q = [Query(field='timestamp', q = [api.Query(field='timestamp',
op='eq', op='eq',
value=str(ts_start))] value=str(ts_start))]
self.assertRaises( self.assertRaises(
@ -286,10 +285,11 @@ class TestQueryToKwArgs(tests_base.BaseTestCase):
api._query_to_kwargs, q, storage.SampleFilter.__init__) api._query_to_kwargs, q, storage.SampleFilter.__init__)
def test_sample_filter_exclude_internal(self): def test_sample_filter_exclude_internal(self):
queries = [Query(field=f, queries = [api.Query(field=f,
op='eq', op='eq',
value='fake', value='fake',
type='string') for f in ['y', 'on_behalf_of', 'x']] type='string')
for f in ['y', 'on_behalf_of', 'x']]
with mock.patch('pecan.request') as request: with mock.patch('pecan.request') as request:
request.headers.return_value = {'X-ProjectId': 'foobar'} request.headers.return_value = {'X-ProjectId': 'foobar'}
self.assertRaises(wsme.exc.ClientSideError, self.assertRaises(wsme.exc.ClientSideError,
@ -299,7 +299,7 @@ class TestQueryToKwArgs(tests_base.BaseTestCase):
internal_keys=['on_behalf_of']) internal_keys=['on_behalf_of'])
def test_sample_filter_self_always_excluded(self): def test_sample_filter_self_always_excluded(self):
queries = [Query(field='user_id', queries = [api.Query(field='user_id',
op='eq', op='eq',
value='20')] value='20')]
with mock.patch('pecan.request') as request: with mock.patch('pecan.request') as request:
@ -309,7 +309,7 @@ class TestQueryToKwArgs(tests_base.BaseTestCase):
self.assertFalse('self' in kwargs) self.assertFalse('self' in kwargs)
def test_sample_filter_translation(self): def test_sample_filter_translation(self):
queries = [Query(field=f, queries = [api.Query(field=f,
op='eq', op='eq',
value='fake_%s' % f, value='fake_%s' % f,
type='string') for f in ['user_id', type='string') for f in ['user_id',

View File

@ -17,7 +17,7 @@
# under the License. # under the License.
"""Tests for ceilometer/collector/dispatcher/database.py """Tests for ceilometer/collector/dispatcher/database.py
""" """
from datetime import datetime import datetime
import mock import mock
@ -84,7 +84,7 @@ class TestDispatcherDB(test.BaseTestCase):
) )
expected = msg.copy() expected = msg.copy()
expected['timestamp'] = datetime(2012, 7, 2, 13, 53, 40) expected['timestamp'] = datetime.datetime(2012, 7, 2, 13, 53, 40)
with mock.patch.object(self.dispatcher.storage_conn, with mock.patch.object(self.dispatcher.storage_conn,
'record_metering_data') as record_metering_data: 'record_metering_data') as record_metering_data:
@ -104,7 +104,8 @@ class TestDispatcherDB(test.BaseTestCase):
) )
expected = msg.copy() expected = msg.copy()
expected['timestamp'] = datetime(2012, 9, 30, 23, 31, 50, 262000) expected['timestamp'] = datetime.datetime(2012, 9, 30, 23,
31, 50, 262000)
with mock.patch.object(self.dispatcher.storage_conn, with mock.patch.object(self.dispatcher.storage_conn,
'record_metering_data') as record_metering_data: 'record_metering_data') as record_metering_data:

View File

@ -19,7 +19,7 @@
"""Tests for libvirt inspector. """Tests for libvirt inspector.
""" """
from contextlib import nested import contextlib
import fixtures import fixtures
import mock import mock
@ -49,7 +49,7 @@ class TestLibvirtInspection(test.BaseTestCase):
fake_domain = FakeDomain() fake_domain = FakeDomain()
connection = self.inspector.connection connection = self.inspector.connection
with nested(mock.patch.object(connection, 'numOfDomains', with contextlib.nested(mock.patch.object(connection, 'numOfDomains',
return_value=1), return_value=1),
mock.patch.object(connection, 'listDomainsID', mock.patch.object(connection, 'listDomainsID',
return_value=[42]), return_value=[42]),
@ -62,11 +62,12 @@ class TestLibvirtInspection(test.BaseTestCase):
self.assertEqual(inspected_instance.UUID, 'uuid') self.assertEqual(inspected_instance.UUID, 'uuid')
def test_inspect_cpus(self): def test_inspect_cpus(self):
with nested(mock.patch.object(self.inspector.connection, with contextlib.nested(mock.patch.object(self.inspector.connection,
'lookupByName', 'lookupByName',
return_value=self.domain), return_value=self.domain),
mock.patch.object(self.domain, 'info', mock.patch.object(self.domain, 'info',
return_value=(0L, 0L, 0L, 2L, 999999L))): return_value=(0L, 0L, 0L,
2L, 999999L))):
cpu_info = self.inspector.inspect_cpus(self.instance_name) cpu_info = self.inspector.inspect_cpus(self.instance_name)
self.assertEqual(cpu_info.number, 2L) self.assertEqual(cpu_info.number, 2L)
self.assertEqual(cpu_info.time, 999999L) self.assertEqual(cpu_info.time, 999999L)
@ -137,11 +138,12 @@ class TestLibvirtInspection(test.BaseTestCase):
interfaceStats = interface_stats.__getitem__ interfaceStats = interface_stats.__getitem__
connection = self.inspector.connection connection = self.inspector.connection
with nested(mock.patch.object(connection, 'lookupByName', with contextlib.nested(mock.patch.object(connection, 'lookupByName',
return_value=self.domain), return_value=self.domain),
mock.patch.object(self.domain, 'XMLDesc', mock.patch.object(self.domain, 'XMLDesc',
return_value=dom_xml), return_value=dom_xml),
mock.patch.object(self.domain, 'interfaceStats', mock.patch.object(self.domain,
'interfaceStats',
side_effect=interfaceStats)): side_effect=interfaceStats)):
interfaces = list(self.inspector.inspect_vnics(self.instance_name)) interfaces = list(self.inspector.inspect_vnics(self.instance_name))
@ -200,13 +202,14 @@ class TestLibvirtInspection(test.BaseTestCase):
</domain> </domain>
""" """
with nested(mock.patch.object(self.inspector.connection, with contextlib.nested(mock.patch.object(self.inspector.connection,
'lookupByName', 'lookupByName',
return_value=self.domain), return_value=self.domain),
mock.patch.object(self.domain, 'XMLDesc', mock.patch.object(self.domain, 'XMLDesc',
return_value=dom_xml), return_value=dom_xml),
mock.patch.object(self.domain, 'blockStats', mock.patch.object(self.domain, 'blockStats',
return_value=(1L, 2L, 3L, 4L, -1))): return_value=(1L, 2L, 3L,
4L, -1))):
disks = list(self.inspector.inspect_disks(self.instance_name)) disks = list(self.inspector.inspect_disks(self.instance_name))
self.assertEqual(len(disks), 1) self.assertEqual(len(disks), 1)

View File

@ -17,7 +17,7 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
from datetime import datetime import datetime
from ceilometer.image import notifications from ceilometer.image import notifications
from ceilometer.openstack.common import test from ceilometer.openstack.common import test
@ -28,7 +28,7 @@ def fake_uuid(x):
return '%s-%s-%s-%s' % (x * 8, x * 4, x * 4, x * 12) return '%s-%s-%s-%s' % (x * 8, x * 4, x * 4, x * 12)
NOW = datetime.isoformat(datetime.utcnow()) NOW = datetime.datetime.isoformat(datetime.datetime.utcnow())
NOTIFICATION_SEND = { NOTIFICATION_SEND = {
u'event_type': u'image.send', u'event_type': u'image.send',

View File

@ -20,7 +20,7 @@
import cStringIO as StringIO import cStringIO as StringIO
import mock import mock
from webob import Request import webob
from ceilometer.objectstore import swift_middleware from ceilometer.objectstore import swift_middleware
from ceilometer.openstack.common.fixture import config from ceilometer.openstack.common.fixture import config
@ -80,7 +80,7 @@ class TestSwiftMiddleware(test.BaseTestCase):
def test_get(self): def test_get(self):
app = swift_middleware.CeilometerMiddleware(FakeApp(), {}) app = swift_middleware.CeilometerMiddleware(FakeApp(), {})
req = Request.blank('/1.0/account/container/obj', req = webob.Request.blank('/1.0/account/container/obj',
environ={'REQUEST_METHOD': 'GET'}) environ={'REQUEST_METHOD': 'GET'})
resp = app(req.environ, self.start_response) resp = app(req.environ, self.start_response)
self.assertEqual(list(resp), ["This string is 28 bytes long"]) self.assertEqual(list(resp), ["This string is 28 bytes long"])
@ -100,7 +100,7 @@ class TestSwiftMiddleware(test.BaseTestCase):
def test_put(self): def test_put(self):
app = swift_middleware.CeilometerMiddleware(FakeApp(body=['']), {}) app = swift_middleware.CeilometerMiddleware(FakeApp(body=['']), {})
req = Request.blank('/1.0/account/container/obj', req = webob.Request.blank('/1.0/account/container/obj',
environ={'REQUEST_METHOD': 'PUT', environ={'REQUEST_METHOD': 'PUT',
'wsgi.input': 'wsgi.input':
StringIO.StringIO('some stuff')}) StringIO.StringIO('some stuff')})
@ -121,10 +121,10 @@ class TestSwiftMiddleware(test.BaseTestCase):
def test_post(self): def test_post(self):
app = swift_middleware.CeilometerMiddleware(FakeApp(body=['']), {}) app = swift_middleware.CeilometerMiddleware(FakeApp(body=['']), {})
req = Request.blank('/1.0/account/container/obj', req = webob.Request.blank(
'/1.0/account/container/obj',
environ={'REQUEST_METHOD': 'POST', environ={'REQUEST_METHOD': 'POST',
'wsgi.input': 'wsgi.input': StringIO.StringIO('some other stuff')})
StringIO.StringIO('some other stuff')})
list(app(req.environ, self.start_response)) list(app(req.environ, self.start_response))
samples = self.pipeline_manager.pipelines[0].samples samples = self.pipeline_manager.pipelines[0].samples
self.assertEqual(len(samples), 2) self.assertEqual(len(samples), 2)
@ -142,7 +142,7 @@ class TestSwiftMiddleware(test.BaseTestCase):
def test_head(self): def test_head(self):
app = swift_middleware.CeilometerMiddleware(FakeApp(body=['']), {}) app = swift_middleware.CeilometerMiddleware(FakeApp(body=['']), {})
req = Request.blank('/1.0/account/container/obj', req = webob.Request.blank('/1.0/account/container/obj',
environ={'REQUEST_METHOD': 'HEAD'}) environ={'REQUEST_METHOD': 'HEAD'})
list(app(req.environ, self.start_response)) list(app(req.environ, self.start_response))
samples = self.pipeline_manager.pipelines[0].samples samples = self.pipeline_manager.pipelines[0].samples
@ -159,7 +159,7 @@ class TestSwiftMiddleware(test.BaseTestCase):
def test_bogus_request(self): def test_bogus_request(self):
"""Test even for arbitrary request method, this will still work.""" """Test even for arbitrary request method, this will still work."""
app = swift_middleware.CeilometerMiddleware(FakeApp(body=['']), {}) app = swift_middleware.CeilometerMiddleware(FakeApp(body=['']), {})
req = Request.blank('/1.0/account/container/obj', req = webob.Request.blank('/1.0/account/container/obj',
environ={'REQUEST_METHOD': 'BOGUS'}) environ={'REQUEST_METHOD': 'BOGUS'})
list(app(req.environ, self.start_response)) list(app(req.environ, self.start_response))
samples = self.pipeline_manager.pipelines[0].samples samples = self.pipeline_manager.pipelines[0].samples
@ -176,7 +176,7 @@ class TestSwiftMiddleware(test.BaseTestCase):
def test_get_container(self): def test_get_container(self):
app = swift_middleware.CeilometerMiddleware(FakeApp(), {}) app = swift_middleware.CeilometerMiddleware(FakeApp(), {})
req = Request.blank('/1.0/account/container', req = webob.Request.blank('/1.0/account/container',
environ={'REQUEST_METHOD': 'GET'}) environ={'REQUEST_METHOD': 'GET'})
list(app(req.environ, self.start_response)) list(app(req.environ, self.start_response))
samples = self.pipeline_manager.pipelines[0].samples samples = self.pipeline_manager.pipelines[0].samples
@ -189,7 +189,7 @@ class TestSwiftMiddleware(test.BaseTestCase):
def test_no_metadata_headers(self): def test_no_metadata_headers(self):
app = swift_middleware.CeilometerMiddleware(FakeApp(), {}) app = swift_middleware.CeilometerMiddleware(FakeApp(), {})
req = Request.blank('/1.0/account/container', req = webob.Request.blank('/1.0/account/container',
environ={'REQUEST_METHOD': 'GET'}) environ={'REQUEST_METHOD': 'GET'})
list(app(req.environ, self.start_response)) list(app(req.environ, self.start_response))
samples = self.pipeline_manager.pipelines[0].samples samples = self.pipeline_manager.pipelines[0].samples
@ -206,12 +206,10 @@ class TestSwiftMiddleware(test.BaseTestCase):
app = swift_middleware.CeilometerMiddleware(FakeApp(), { app = swift_middleware.CeilometerMiddleware(FakeApp(), {
'metadata_headers': 'X_VAR1, x-var2, x-var3' 'metadata_headers': 'X_VAR1, x-var2, x-var3'
}) })
req = Request.blank('/1.0/account/container', req = webob.Request.blank('/1.0/account/container',
environ={'REQUEST_METHOD': 'GET'}, environ={'REQUEST_METHOD': 'GET'},
headers={ headers={'X_VAR1': 'value1',
'X_VAR1': 'value1', 'X_VAR2': 'value2'})
'X_VAR2': 'value2'
})
list(app(req.environ, self.start_response)) list(app(req.environ, self.start_response))
samples = self.pipeline_manager.pipelines[0].samples samples = self.pipeline_manager.pipelines[0].samples
self.assertEqual(len(samples), 2) self.assertEqual(len(samples), 2)
@ -232,7 +230,7 @@ class TestSwiftMiddleware(test.BaseTestCase):
app = swift_middleware.CeilometerMiddleware(FakeApp(), { app = swift_middleware.CeilometerMiddleware(FakeApp(), {
'metadata_headers': 'x-var3' 'metadata_headers': 'x-var3'
}) })
req = Request.blank('/1.0/account/container', req = webob.Request.blank('/1.0/account/container',
environ={'REQUEST_METHOD': 'GET'}) environ={'REQUEST_METHOD': 'GET'})
list(app(req.environ, self.start_response)) list(app(req.environ, self.start_response))
samples = self.pipeline_manager.pipelines[0].samples samples = self.pipeline_manager.pipelines[0].samples
@ -247,7 +245,7 @@ class TestSwiftMiddleware(test.BaseTestCase):
def test_bogus_path(self): def test_bogus_path(self):
app = swift_middleware.CeilometerMiddleware(FakeApp(), {}) app = swift_middleware.CeilometerMiddleware(FakeApp(), {})
req = Request.blank('//v1/account/container', req = webob.Request.blank('//v1/account/container',
environ={'REQUEST_METHOD': 'GET'}) environ={'REQUEST_METHOD': 'GET'})
list(app(req.environ, self.start_response)) list(app(req.environ, self.start_response))
samples = self.pipeline_manager.pipelines[0].samples samples = self.pipeline_manager.pipelines[0].samples
@ -255,8 +253,7 @@ class TestSwiftMiddleware(test.BaseTestCase):
def test_missing_resource_id(self): def test_missing_resource_id(self):
app = swift_middleware.CeilometerMiddleware(FakeApp(), {}) app = swift_middleware.CeilometerMiddleware(FakeApp(), {})
req = Request.blank('/5.0/', req = webob.Request.blank('/5.0/', environ={'REQUEST_METHOD': 'GET'})
environ={'REQUEST_METHOD': 'GET'})
list(app(req.environ, self.start_response)) list(app(req.environ, self.start_response))
samples = self.pipeline_manager.pipelines[0].samples samples = self.pipeline_manager.pipelines[0].samples
self.assertEqual(len(samples), 0) self.assertEqual(len(samples), 0)
@ -266,7 +263,7 @@ class TestSwiftMiddleware(test.BaseTestCase):
def test_publish_sample_fail(self, mocked_publish_sample): def test_publish_sample_fail(self, mocked_publish_sample):
mocked_publish_sample.side_effect = Exception("a exception") mocked_publish_sample.side_effect = Exception("a exception")
app = swift_middleware.CeilometerMiddleware(FakeApp(body=["test"]), {}) app = swift_middleware.CeilometerMiddleware(FakeApp(body=["test"]), {})
req = Request.blank('/1.0/account/container', req = webob.Request.blank('/1.0/account/container',
environ={'REQUEST_METHOD': 'GET'}) environ={'REQUEST_METHOD': 'GET'})
resp = list(app(req.environ, self.start_response)) resp = list(app(req.environ, self.start_response))
samples = self.pipeline_manager.pipelines[0].samples samples = self.pipeline_manager.pipelines[0].samples

View File

@ -24,7 +24,7 @@ import logging.handlers
import os import os
import tempfile import tempfile
from ceilometer.openstack.common.network_utils import urlsplit from ceilometer.openstack.common import network_utils as utils
from ceilometer.openstack.common import test from ceilometer.openstack.common import test
from ceilometer.publisher import file from ceilometer.publisher import file
from ceilometer import sample from ceilometer import sample
@ -72,7 +72,7 @@ class TestFilePublisher(test.BaseTestCase):
# Test valid configurations # Test valid configurations
tempdir = tempfile.mkdtemp() tempdir = tempfile.mkdtemp()
name = '%s/log_file' % tempdir name = '%s/log_file' % tempdir
parsed_url = urlsplit('file://%s?max_bytes=50&backup_count=3' parsed_url = utils.urlsplit('file://%s?max_bytes=50&backup_count=3'
% name) % name)
publisher = file.FilePublisher(parsed_url) publisher = file.FilePublisher(parsed_url)
publisher.publish_samples(None, publisher.publish_samples(None,
@ -91,7 +91,7 @@ class TestFilePublisher(test.BaseTestCase):
# Test missing max bytes, backup count configurations # Test missing max bytes, backup count configurations
tempdir = tempfile.mkdtemp() tempdir = tempfile.mkdtemp()
name = '%s/log_file_plain' % tempdir name = '%s/log_file_plain' % tempdir
parsed_url = urlsplit('file://%s' % name) parsed_url = utils.urlsplit('file://%s' % name)
publisher = file.FilePublisher(parsed_url) publisher = file.FilePublisher(parsed_url)
publisher.publish_samples(None, publisher.publish_samples(None,
self.test_data) self.test_data)
@ -113,7 +113,7 @@ class TestFilePublisher(test.BaseTestCase):
def test_file_publisher_invalid(self): def test_file_publisher_invalid(self):
# Test invalid max bytes, backup count configurations # Test invalid max bytes, backup count configurations
tempdir = tempfile.mkdtemp() tempdir = tempfile.mkdtemp()
parsed_url = urlsplit( parsed_url = utils.urlsplit(
'file://%s/log_file_bad' 'file://%s/log_file_bad'
'?max_bytes=yus&backup_count=5y' % tempdir) '?max_bytes=yus&backup_count=5y' % tempdir)
publisher = file.FilePublisher(parsed_url) publisher = file.FilePublisher(parsed_url)

View File

@ -16,7 +16,7 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
from datetime import datetime import datetime
import mock import mock
from sqlalchemy.dialects.mysql import DECIMAL from sqlalchemy.dialects.mysql import DECIMAL
@ -46,7 +46,7 @@ class PreciseTimestampTest(test.BaseTestCase):
self._mysql_dialect = self.fake_dialect('mysql') self._mysql_dialect = self.fake_dialect('mysql')
self._postgres_dialect = self.fake_dialect('postgres') self._postgres_dialect = self.fake_dialect('postgres')
self._type = models.PreciseTimestamp() self._type = models.PreciseTimestamp()
self._date = datetime(2012, 7, 2, 10, 44) self._date = datetime.datetime(2012, 7, 2, 10, 44)
def test_load_dialect_impl_mysql(self): def test_load_dialect_impl_mysql(self):
result = self._type.load_dialect_impl(self._mysql_dialect) result = self._type.load_dialect_impl(self._mysql_dialect)

View File

@ -26,8 +26,7 @@
""" """
from mock import patch from mock import patch
from ceilometer.storage.impl_hbase import Connection from ceilometer.storage import impl_hbase as hbase
from ceilometer.storage.impl_hbase import MConnection
from ceilometer.tests import db as tests_db from ceilometer.tests import db as tests_db
@ -39,8 +38,8 @@ class ConnectionTest(HBaseEngineTestBase):
def test_hbase_connection(self): def test_hbase_connection(self):
self.CONF.database.connection = self.database_connection self.CONF.database.connection = self.database_connection
conn = Connection(self.CONF) conn = hbase.Connection(self.CONF)
self.assertIsInstance(conn.conn, MConnection) self.assertIsInstance(conn.conn, hbase.MConnection)
class TestConn(object): class TestConn(object):
def __init__(self, host, port): def __init__(self, host, port):
@ -53,7 +52,7 @@ class ConnectionTest(HBaseEngineTestBase):
return TestConn(conf['host'], conf['port']) return TestConn(conf['host'], conf['port'])
self.CONF.database.connection = 'hbase://test_hbase:9090' self.CONF.database.connection = 'hbase://test_hbase:9090'
with patch.object(Connection, '_get_connection', with patch.object(hbase.Connection, '_get_connection',
side_effect=get_connection): side_effect=get_connection):
conn = Connection(self.CONF) conn = hbase.Connection(self.CONF)
self.assertIsInstance(conn.conn, TestConn) self.assertIsInstance(conn.conn, TestConn)

View File

@ -30,8 +30,7 @@ from mock import patch
from ceilometer.publisher import rpc from ceilometer.publisher import rpc
from ceilometer import sample from ceilometer import sample
from ceilometer.storage.base import MultipleResultsFound from ceilometer.storage import base
from ceilometer.storage.base import NoResultFound
from ceilometer.storage import impl_mongodb from ceilometer.storage import impl_mongodb
from ceilometer.tests import db as tests_db from ceilometer.tests import db as tests_db
from ceilometer.tests.storage import test_storage_scenarios from ceilometer.tests.storage import test_storage_scenarios
@ -81,7 +80,7 @@ class MongoDBTestMarkerBase(test_storage_scenarios.DBTestBase,
ret = impl_mongodb.Connection._get_marker(self.conn.db.resource, ret = impl_mongodb.Connection._get_marker(self.conn.db.resource,
marker_pairs) marker_pairs)
self.assertEqual(ret['project_id'], 'project-id-foo') self.assertEqual(ret['project_id'], 'project-id-foo')
except NoResultFound: except base.NoResultFound:
self.assertTrue(True) self.assertTrue(True)
def test_get_marker_multiple(self): def test_get_marker_multiple(self):
@ -90,7 +89,7 @@ class MongoDBTestMarkerBase(test_storage_scenarios.DBTestBase,
ret = impl_mongodb.Connection._get_marker(self.conn.db.resource, ret = impl_mongodb.Connection._get_marker(self.conn.db.resource,
marker_pairs) marker_pairs)
self.assertEqual(ret['project_id'], 'project-id-foo') self.assertEqual(ret['project_id'], 'project-id-foo')
except MultipleResultsFound: except base.MultipleResultsFound:
self.assertTrue(True) self.assertTrue(True)
@ -279,7 +278,7 @@ class AlarmTestPagination(test_storage_scenarios.AlarmTestBase,
marker_pairs) marker_pairs)
self.assertEqual(ret['rule']['meter_name'], self.assertEqual(ret['rule']['meter_name'],
'meter_name-foo') 'meter_name-foo')
except NoResultFound: except base.NoResultFound:
self.assertTrue(True) self.assertTrue(True)
def test_alarm_get_marker_multiple(self): def test_alarm_get_marker_multiple(self):
@ -290,5 +289,5 @@ class AlarmTestPagination(test_storage_scenarios.AlarmTestBase,
marker_pairs) marker_pairs)
self.assertEqual(ret['rule']['meter_name'], self.assertEqual(ret['rule']['meter_name'],
'counter-name-foo') 'counter-name-foo')
except MultipleResultsFound: except base.MultipleResultsFound:
self.assertTrue(True) self.assertTrue(True)

View File

@ -30,7 +30,6 @@ from mock import patch
from ceilometer.storage import models from ceilometer.storage import models
from ceilometer.storage.sqlalchemy import models as sql_models from ceilometer.storage.sqlalchemy import models as sql_models
from ceilometer.storage.sqlalchemy.models import table_args
from ceilometer.tests import db as tests_db from ceilometer.tests import db as tests_db
from ceilometer import utils from ceilometer import utils
@ -142,4 +141,4 @@ class ModelTest(tests_db.TestBase):
database_connection = 'mysql://localhost' database_connection = 'mysql://localhost'
def test_model_table_args(self): def test_model_table_args(self):
self.assertIsNotNone(table_args()) self.assertIsNotNone(sql_models.table_args())

View File

@ -27,7 +27,7 @@ from ceilometer.openstack.common import timeutils
from ceilometer.publisher import rpc from ceilometer.publisher import rpc
from ceilometer import sample from ceilometer import sample
from ceilometer import storage from ceilometer import storage
from ceilometer.storage.base import Pagination from ceilometer.storage import base
from ceilometer.storage import models from ceilometer.storage import models
from ceilometer.tests import db as tests_db from ceilometer.tests import db as tests_db
@ -305,37 +305,38 @@ class ResourceTestPagination(DBTestBase,
tests_db.MixinTestsWithBackendScenarios): tests_db.MixinTestsWithBackendScenarios):
def test_get_resource_all_limit(self): def test_get_resource_all_limit(self):
pagination = Pagination(limit=8) pagination = base.Pagination(limit=8)
results = list(self.conn.get_resources(pagination=pagination)) results = list(self.conn.get_resources(pagination=pagination))
self.assertEqual(len(results), 8) self.assertEqual(len(results), 8)
pagination = Pagination(limit=5) pagination = base.Pagination(limit=5)
results = list(self.conn.get_resources(pagination=pagination)) results = list(self.conn.get_resources(pagination=pagination))
self.assertEqual(len(results), 5) self.assertEqual(len(results), 5)
def test_get_resources_all_marker(self): def test_get_resources_all_marker(self):
pagination = Pagination(primary_sort_dir='asc', sort_keys=['user_id'], pagination = base.Pagination(primary_sort_dir='asc',
sort_keys=['user_id'],
sort_dirs=['asc'], sort_dirs=['asc'],
marker_value='resource-id-4') marker_value='resource-id-4')
results = list(self.conn.get_resources(pagination=pagination)) results = list(self.conn.get_resources(pagination=pagination))
self.assertEqual(len(results), 5) self.assertEqual(len(results), 5)
def test_get_resources_paginate(self): def test_get_resources_paginate(self):
pagination = Pagination(limit=3, primary_sort_dir='asc', pagination = base.Pagination(limit=3, primary_sort_dir='asc',
sort_keys=['user_id'], sort_dirs=['asc'], sort_keys=['user_id'], sort_dirs=['asc'],
marker_value='resource-id-4') marker_value='resource-id-4')
results = self.conn.get_resources(pagination=pagination) results = self.conn.get_resources(pagination=pagination)
self.assertEqual(['user-id-5', 'user-id-6', 'user-id-7'], self.assertEqual(['user-id-5', 'user-id-6', 'user-id-7'],
[i.user_id for i in results]) [i.user_id for i in results])
pagination = Pagination(limit=2, primary_sort_dir='desc', pagination = base.Pagination(limit=2, primary_sort_dir='desc',
sort_keys=['user_id'], sort_dirs=['asc'], sort_keys=['user_id'], sort_dirs=['asc'],
marker_value='resource-id-4') marker_value='resource-id-4')
results = list(self.conn.get_resources(pagination=pagination)) results = list(self.conn.get_resources(pagination=pagination))
self.assertEqual(['user-id-3', 'user-id-2'], self.assertEqual(['user-id-3', 'user-id-2'],
[i.user_id for i in results]) [i.user_id for i in results])
pagination = Pagination(limit=3, primary_sort_dir='asc', pagination = base.Pagination(limit=3, primary_sort_dir='asc',
sort_keys=['user_id'], sort_dirs=['asc'], sort_keys=['user_id'], sort_dirs=['asc'],
marker_value='resource-id-5') marker_value='resource-id-5')
results = list(self.conn.get_resources(pagination=pagination)) results = list(self.conn.get_resources(pagination=pagination))
@ -427,45 +428,46 @@ class MeterTestPagination(DBTestBase,
tests_db.MixinTestsWithBackendScenarios): tests_db.MixinTestsWithBackendScenarios):
def tet_get_meters_all_limit(self): def tet_get_meters_all_limit(self):
pagination = Pagination(limit=8) pagination = base.Pagination(limit=8)
results = list(self.conn.get_meters(pagination=pagination)) results = list(self.conn.get_meters(pagination=pagination))
self.assertEqual(len(results), 8) self.assertEqual(len(results), 8)
pagination = Pagination(limit=5) pagination = base.Pagination(limit=5)
results = list(self.conn.get_meters(pagination=pagination)) results = list(self.conn.get_meters(pagination=pagination))
self.assertEqual(len(results), 5) self.assertEqual(len(results), 5)
def test_get_meters_all_marker(self): def test_get_meters_all_marker(self):
pagination = Pagination(limit=3, primary_sort_dir='desc', pagination = base.Pagination(limit=3, primary_sort_dir='desc',
sort_keys=['user_id'], sort_dirs=['desc'], sort_keys=['user_id'],
sort_dirs=['desc'],
marker_value='resource-id-5') marker_value='resource-id-5')
results = list(self.conn.get_meters(pagination=pagination)) results = list(self.conn.get_meters(pagination=pagination))
self.assertEqual(len(results), 8) self.assertEqual(len(results), 8)
def test_get_meters_paginate(self): def test_get_meters_paginate(self):
pagination = Pagination(limit=3, primary_sort_dir='desc', pagination = base.Pagination(limit=3, primary_sort_dir='desc',
sort_keys=['user_id'], sort_dirs=['desc'], sort_keys=['user_id'], sort_dirs=['desc'],
marker_value='resource-id-5') marker_value='resource-id-5')
results = self.conn.get_meters(pagination=pagination) results = self.conn.get_meters(pagination=pagination)
self.assertEqual(['user-id-8', 'user-id-7', 'user-id-6'], self.assertEqual(['user-id-8', 'user-id-7', 'user-id-6'],
[i.user_id for i in results]) [i.user_id for i in results])
pagination = Pagination(limit=3, primary_sort_dir='asc', pagination = base.Pagination(limit=3, primary_sort_dir='asc',
sort_keys=['user_id'], sort_dirs=['desc'], sort_keys=['user_id'], sort_dirs=['desc'],
marker_value='resource-id-5') marker_value='resource-id-5')
results = self.conn.get_meters(pagination=pagination) results = self.conn.get_meters(pagination=pagination)
self.assertEqual(['user-id-5', 'user-id-6', 'user-id-7'], self.assertEqual(['user-id-5', 'user-id-6', 'user-id-7'],
[i.user_id for i in results]) [i.user_id for i in results])
pagination = Pagination(limit=2, primary_sort_dir='desc', pagination = base.Pagination(limit=2, primary_sort_dir='desc',
sort_keys=['user_id'], sort_dirs=['desc'], sort_keys=['user_id'], sort_dirs=['desc'],
marker_value='resource-id-5') marker_value='resource-id-5')
results = list(self.conn.get_meters(pagination=pagination)) results = list(self.conn.get_meters(pagination=pagination))
self.assertEqual(['user-id-3', 'user-id-2'], self.assertEqual(['user-id-3', 'user-id-2'],
[i.user_id for i in results]) [i.user_id for i in results])
pagination = Pagination(limit=3, primary_sort_dir='desc', pagination = base.Pagination(limit=3, primary_sort_dir='desc',
sort_keys=['user_id'], sort_dirs=['desc'], sort_keys=['user_id'], sort_dirs=['desc'],
marker_value='resource-id-5') marker_value='resource-id-5')
results = self.conn.get_meters(pagination=pagination) results = self.conn.get_meters(pagination=pagination)
@ -2029,26 +2031,26 @@ class AlarmTestPagination(AlarmTestBase,
def test_get_alarm_all_limit(self): def test_get_alarm_all_limit(self):
self.add_some_alarms() self.add_some_alarms()
pagination = Pagination(limit=2) pagination = base.Pagination(limit=2)
alarms = list(self.conn.get_alarms(pagination=pagination)) alarms = list(self.conn.get_alarms(pagination=pagination))
self.assertEqual(len(alarms), 2) self.assertEqual(len(alarms), 2)
pagination = Pagination(limit=1) pagination = base.Pagination(limit=1)
alarms = list(self.conn.get_alarms(pagination=pagination)) alarms = list(self.conn.get_alarms(pagination=pagination))
self.assertEqual(len(alarms), 1) self.assertEqual(len(alarms), 1)
def test_get_alarm_all_marker(self): def test_get_alarm_all_marker(self):
self.add_some_alarms() self.add_some_alarms()
pagination = Pagination(marker_value='orange-alert') pagination = base.Pagination(marker_value='orange-alert')
alarms = list(self.conn.get_alarms(pagination=pagination)) alarms = list(self.conn.get_alarms(pagination=pagination))
self.assertEqual(len(alarms), 0) self.assertEqual(len(alarms), 0)
pagination = Pagination(marker_value='red-alert') pagination = base.Pagination(marker_value='red-alert')
alarms = list(self.conn.get_alarms(pagination=pagination)) alarms = list(self.conn.get_alarms(pagination=pagination))
self.assertEqual(len(alarms), 1) self.assertEqual(len(alarms), 1)
pagination = Pagination(marker_value='yellow-alert') pagination = base.Pagination(marker_value='yellow-alert')
alarms = list(self.conn.get_alarms(pagination=pagination)) alarms = list(self.conn.get_alarms(pagination=pagination))
self.assertEqual(len(alarms), 2) self.assertEqual(len(alarms), 2)
@ -2056,11 +2058,11 @@ class AlarmTestPagination(AlarmTestBase,
self.add_some_alarms() self.add_some_alarms()
pagination = Pagination(limit=4, marker_value='yellow-alert') pagination = base.Pagination(limit=4, marker_value='yellow-alert')
page = list(self.conn.get_alarms(pagination=pagination)) page = list(self.conn.get_alarms(pagination=pagination))
self.assertEqual(['red-alert', 'orange-alert'], [i.name for i in page]) self.assertEqual(['red-alert', 'orange-alert'], [i.name for i in page])
pagination = Pagination(limit=2, marker_value='orange-alert', pagination = base.Pagination(limit=2, marker_value='orange-alert',
primary_sort_dir='asc') primary_sort_dir='asc')
page1 = list(self.conn.get_alarms(pagination=pagination)) page1 = list(self.conn.get_alarms(pagination=pagination))
self.assertEqual(['red-alert', 'yellow-alert'], self.assertEqual(['red-alert', 'yellow-alert'],

View File

@ -16,9 +16,9 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
from collections import defaultdict import collections
from ceilometer.openstack.common.gettextutils import _ from ceilometer.openstack.common.gettextutils import _ # noqa
from ceilometer.openstack.common import log from ceilometer.openstack.common import log
from ceilometer.openstack.common import timeutils from ceilometer.openstack.common import timeutils
from ceilometer import sample from ceilometer import sample
@ -34,7 +34,7 @@ class Namespace(object):
to yield false when used in a boolean expression. to yield false when used in a boolean expression.
""" """
def __init__(self, seed): def __init__(self, seed):
self.__dict__ = defaultdict(lambda: Namespace({})) self.__dict__ = collections.defaultdict(lambda: Namespace({}))
self.__dict__.update(seed) self.__dict__.update(seed)
for k, v in self.__dict__.iteritems(): for k, v in self.__dict__.iteritems():
if isinstance(v, dict): if isinstance(v, dict):

View File

@ -45,7 +45,6 @@ deps = -r{toxinidir}/requirements.txt
commands = {posargs} commands = {posargs}
[flake8] [flake8]
ignore = H302
builtins = _ builtins = _
exclude=.venv,.git,.tox,dist,doc,./ceilometer/openstack/common,*lib/python*,*egg,tools,nova_tests,build exclude=.venv,.git,.tox,dist,doc,./ceilometer/openstack/common,*lib/python*,*egg,tools,nova_tests,build
show-source = True show-source = True