
This patch moves pipeline setup into the bootstrap and out of the storage driver base class, so that the base class can be inherited by meta-drivers, such as the planned sharding manager, without introducing a loop in the bootstrapping logic. Now, a meta-driver is exposed to the transport object that takes care of wiring up the pipeline for each resource controller behind the scenes. As part of this work, the pipeline config was modified to support configuring different stages depending on the resource. We create three instances of Pipeline anyway, so it seemed to make sense to allow the operator to configure the pipelines independently. Partially-Implements: blueprint storage-pipeline Change-Id: Ibdb7d0e9537b1eec38a13f4881df7462039bbf98
53 lines
1.9 KiB
Python
53 lines
1.9 KiB
Python
# Copyright (c) 2013 Rackspace, Inc.
|
|
#
|
|
# 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 marconi.common import exceptions
|
|
import marconi.queues
|
|
from marconi.queues.storage import pipeline
|
|
from marconi.queues.storage import sqlite
|
|
from marconi.queues.transport import wsgi
|
|
from marconi.tests import base
|
|
|
|
|
|
class TestBootstrap(base.TestBase):
|
|
|
|
def test_config_missing(self):
|
|
self.assertRaises(cfg.ConfigFilesNotFoundError, marconi.Bootstrap, '')
|
|
|
|
def test_storage_invalid(self):
|
|
conf_file = 'etc/drivers_storage_invalid.conf'
|
|
bootstrap = marconi.Bootstrap(conf_file)
|
|
self.assertRaises(exceptions.InvalidDriver,
|
|
lambda: bootstrap.storage)
|
|
|
|
def test_storage_sqlite(self):
|
|
conf_file = 'etc/wsgi_sqlite.conf'
|
|
bootstrap = marconi.Bootstrap(conf_file)
|
|
self.assertIsInstance(bootstrap.storage, pipeline.Driver)
|
|
self.assertIsInstance(bootstrap.storage._storage, sqlite.Driver)
|
|
|
|
def test_transport_invalid(self):
|
|
conf_file = 'etc/drivers_transport_invalid.conf'
|
|
bootstrap = marconi.Bootstrap(conf_file)
|
|
self.assertRaises(exceptions.InvalidDriver,
|
|
lambda: bootstrap.transport)
|
|
|
|
def test_transport_wsgi(self):
|
|
bootstrap = marconi.Bootstrap('etc/wsgi_sqlite.conf')
|
|
|
|
self.assertIsInstance(bootstrap.transport, wsgi.Driver)
|