blob: e2e17665b1bcb36be4e85101a9e5e96f28459599 [file] [log] [blame]
# Copyright 2012 OpenStack Foundation
# All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
from oslo_config import cfg
from oslo_config import types
service_option = [cfg.BoolOpt('ceilometer',
default=True,
help="Whether or not Ceilometer is expected to"
"be available"),
cfg.BoolOpt("aodh",
default=True,
help="Whether or not Aodh is expected to be"
"available",
deprecated_opts=[cfg.DeprecatedOpt(
'aodh_plugin',
group='service_available')]),
cfg.BoolOpt('gnocchi',
default=True,
help="Whether or not Gnocchi is expected to be"
"available",
deprecated_for_removal=True),
cfg.BoolOpt('sg_core',
default=False,
help="Whether or not sg-core is expected to be"
"available",
deprecated_for_removal=True)]
telemetry_group = cfg.OptGroup(name='telemetry',
title='Telemetry Service Options')
telemetry_services_group = cfg.OptGroup(name='telemetry_services',
title='Telemetry Services')
alarming_group = cfg.OptGroup(name='alarming_plugin',
title='Alarming Service Options')
metric_group = cfg.OptGroup(name='metric',
title='Metric Service Options')
telemetry_opts = [
cfg.IntOpt('notification_wait',
default=120,
help="The seconds to wait for notifications which "
"containers and objects sent to swift."),
cfg.IntOpt('notification_sleep',
default=1,
help="The seconds to sleep after an unsuccessful "
"notification received."),
cfg.IntOpt('alarm_granularity',
default=300,
help="Granularity to use for aodh alarms. This must match the "
"configured Gnocchi archive policy"),
cfg.StrOpt('alarm_metric_name',
default="cpu",
help="Name of the metric to create an alarm on."),
cfg.StrOpt('alarm_aggregation_method',
default="rate:mean",
help="Aggregation method to use for alarm."),
cfg.IntOpt('alarm_threshold',
default=10,
help="Threshold to cross for the alarm to trigger."),
cfg.IntOpt('scaledown_alarm_threshold',
default=2000000000,
help="Threshold to cross for the alarm to trigger."),
cfg.BoolOpt("disable_ssl_certificate_validation",
default=False,
help="Disable SSL certificate validation when running "
"scenario tests"),
cfg.StrOpt('sg_core_service_url',
default="127.0.0.1:3000",
help="URL to sg-core prometheus endpoint"),
cfg.StrOpt('prometheus_service_url',
default="127.0.0.1:9090",
help="URL to prometheus endpoint"),
cfg.IntOpt('ceilometer_polling_interval',
default=300,
help="Polling interval configured for ceilometer. This can "
"be used in test cases to wait for metrics to appear."),
cfg.IntOpt('prometheus_scrape_interval',
default=15,
help="Scrape interval configured for prometheus. This can "
"be used in test cases to properly configure autoscaling"),
cfg.StrOpt(
'autoscaling_instance_grouping',
default='metadata',
choices=[
('prefix', 'Use a common string at the start of instance names to '
'group instances'),
('metadata', 'Use metering.server_group instance metadata to '
'group instances. This is preferred method since '
'2025.1')
],
help="The method to group instances for autoscaling testing. Note "
"that this option affects only tests with prometheus metric "
"backend")
]
telemetry_services_opts = [
cfg.ListOpt('metric_backends',
default=[],
item_type=types.String(choices=['gnocchi', 'prometheus']),
help="Backend store used to store metrics"),
cfg.StrOpt('alarm_backend',
default='mysql',
choices=['mysql', 'postgresql'],
help="Database used by the aodh service"),
]
alarming_opts = [
cfg.StrOpt('catalog_type',
default='alarming',
help="Catalog type of the Alarming service."),
cfg.StrOpt('endpoint_type',
default='publicURL',
choices=['public', 'admin', 'internal',
'publicURL', 'adminURL', 'internalURL'],
help="The endpoint type to use for the alarming service."),
cfg.BoolOpt('create_alarms',
default=True,
help="If create alarms dynamically before testing."),
]
metric_opts = [
cfg.StrOpt('catalog_type',
default='metric',
help="Catalog type of the Metric service."),
cfg.StrOpt('endpoint_type',
default='publicURL',
choices=['public', 'admin', 'internal',
'publicURL', 'adminURL', 'internalURL'],
help="The endpoint type to use for the metric service."),
]