barbican-tempest-plugin/barbican_tempest_plugin/config.py

114 lines
4.6 KiB
Python

# Copyright 2016 SAP SE
# 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
service_option = cfg.BoolOpt("barbican",
default=True,
help="Whether or not barbican is expected to be "
"available")
key_manager_group = cfg.OptGroup(
name='key_manager',
title='Key Manager (Barbican) service options'
)
KeyManagerOpts = [
cfg.StrOpt('min_microversion',
default=None,
help="Lower version of the test target microversion range. "
"The format is 'X.Y', where 'X' and 'Y' are int values. "
"Tempest selects tests based on the range between "
"min_microversion and max_microversion. "
"If both values are not specified, Tempest avoids tests "
"which require a microversion. Valid values are string "
"with format 'X.Y' or string 'latest'"),
cfg.StrOpt('max_microversion',
default=None,
help="Upper version of the test target microversion range. "
"The format is 'X.Y', where 'X' and 'Y' are int values. "
"Tempest selects tests based on the range between "
"min_microversion and max_microversion. "
"If both values are not specified, Tempest avoids tests "
"which require a microversion. Valid values are string "
"with format 'X.Y' or string 'latest'"),
cfg.StrOpt('region',
default='regionOne',
help="The barbican region name to use. If no such region is"
"found in the service catalog, the first found one is "
"used.")
]
barbican_tempest_group = cfg.OptGroup(
name='barbican_tempest',
title='Key Manager (Barbican) service options'
)
BarbicanGroupOpts = [
cfg.BoolOpt('enable_multiple_secret_stores',
default=False,
help="Flag to enable mulitple secret store tests")
]
ephemeral_storage_encryption_group = cfg.OptGroup(
name="ephemeral_storage_encryption",
title="Ephemeral storage encryption options")
EphemeralStorageEncryptionGroup = [
cfg.BoolOpt('enabled',
default=False,
help="Does the test environment support ephemeral storage "
"encryption?"),
cfg.StrOpt('cipher',
default='aes-xts-plain64',
help="The cipher and mode used to encrypt ephemeral storage. "
"AES-XTS is recommended by NIST specifically for disk "
"storage, and the name is shorthand for AES encryption "
"using the XTS encryption mode. Available ciphers depend "
"on kernel support. At the command line, type "
"'cryptsetup benchmark' to determine the available "
"options (and see benchmark results), or go to "
"/proc/crypto."),
cfg.IntOpt('key_size',
default=256,
help="The key size used to encrypt ephemeral storage."),
]
image_signature_verification_group = cfg.OptGroup(
name="image_signature_verification",
title="Image Signature Verification Options")
ImageSignatureVerificationGroup = [
cfg.BoolOpt('enforced',
default=True,
help="Does the test environment enforce glance image "
"verification?"),
cfg.BoolOpt('certificate_validation',
default=True,
help="Does the test environment enforce image signature"
"certificate validation?")
]
barbican_rbac_scope_verification_group = cfg.OptGroup(
name="barbican_rbac_scope_verification",
title="Barbican RBAC Verification Options")
BarbicanRBACScopeVerificationGroup = [
cfg.BoolOpt('enforce_scope',
default=False,
help="Does barbican enforce scope and user "
"scope-aware policies?"),
]