Scheduling backups of Cinder volumes using centralized instance(s) of freezer-scheduler requires executing tasks on behalf of the user. Client capabilities provide a mechanism to restrict which actions, modes, storages, and engines can be assigned to freezer-scheduler for security and workload control. The core implementation of client capabilities resides in freezer-scheduler. The primary purpose of checking capabilities on the freezer-api side is to prevent the assignment of actions that cannot be executed by a specific scheduler instance. Implements: blueprint centralized-scheduler Depends-On: I15a91e8232d07e5bbc2cc95a72b0405c61c64a72 Change-Id: Ie774f9e66ac373a43ef935775de3b18539c5bebd
97 lines
2.9 KiB
Python
97 lines
2.9 KiB
Python
# (c) Copyright 2018 ZTE Corporation.
|
|
# 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.
|
|
|
|
"""Freezer-api DB test base class."""
|
|
|
|
import copy
|
|
import fixtures
|
|
from oslo_config import cfg
|
|
from oslo_db import options as db_options
|
|
|
|
from freezer_api.db.sqlalchemy import api as sqla_api
|
|
from freezer_api.db.sqlalchemy import models
|
|
|
|
from freezer_api.db import manager
|
|
|
|
from freezer_api.tests.unit import common
|
|
|
|
CONF = cfg.CONF
|
|
|
|
_DB_CACHE = None
|
|
|
|
IN_MEM_DB_CONN_STRING = 'sqlite://'
|
|
|
|
|
|
class Database(fixtures.Fixture):
|
|
|
|
def __init__(self, db_api):
|
|
self.initialize_sql_session(IN_MEM_DB_CONN_STRING)
|
|
self.engine = sqla_api.get_engine()
|
|
self.engine.dispose()
|
|
conn = self.engine.connect()
|
|
self.setup_sqlite()
|
|
|
|
self._DB = "".join(line for line in conn.connection.iterdump())
|
|
self.engine.dispose()
|
|
|
|
def initialize_sql_session(self, connection_str):
|
|
db_options.set_defaults(
|
|
CONF,
|
|
connection=connection_str)
|
|
CONF.set_override('connection', IN_MEM_DB_CONN_STRING,
|
|
group='database')
|
|
|
|
def setup_sqlite(self):
|
|
models.register_models(self.engine)
|
|
|
|
def setUp(self):
|
|
super().setUp()
|
|
|
|
conn = self.engine.connect()
|
|
conn.connection.executescript(self._DB)
|
|
self.addCleanup(self.engine.dispose)
|
|
|
|
|
|
class DbTestCase(common.FreezerBaseTestCase):
|
|
|
|
def setUp(self):
|
|
super().setUp()
|
|
dbbackend = "sqlalchemy"
|
|
dbdriver = "sqlalchemy"
|
|
db_driver = manager.get_db_driver(dbdriver,
|
|
backend=dbbackend)
|
|
self.dbapi = db_driver.IMPL
|
|
global _DB_CACHE
|
|
if not _DB_CACHE:
|
|
_DB_CACHE = Database(sqla_api)
|
|
self.useFixture(_DB_CACHE)
|
|
|
|
def setup_fake_clients(self, project_id=None):
|
|
client_node1 = copy.deepcopy(common.get_fake_client_job_3())
|
|
client_node1["client"]["client_id"] = "node1"
|
|
fake_clients = [
|
|
common.get_fake_client_job_0(),
|
|
common.get_fake_client_job_2(),
|
|
common.get_fake_client_job_3(),
|
|
client_node1,
|
|
]
|
|
for fake_client in fake_clients:
|
|
client_doc = copy.deepcopy(fake_client.get('client'))
|
|
self.dbapi.add_client(
|
|
user_id=fake_client.get('user_id'),
|
|
doc=client_doc,
|
|
project_id=project_id,
|
|
)
|