| # 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="http://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."), |
| ] |