Use a placement conf when testing report client
It turns out that the independent wsgi interceptors in test_report_client were using nova's global configuration when creating the intercepts using code from placement. This was working because until [1] placement's set of conf options had not diverged from nova's and nova still has placement_database config settings. This change takes advantage of new functionality in the PlacementFixture to allow the fixtur to manage config and database, but _not_ run the interceptor. This means it can set up a config that is later used by the independent interceptors that are used in the report client tests. [1] Ie43a69be8b75250d9deca6a911eda7b722ef8648 Change-Id: I05326e0f917ca1b9a6ef8d3bd463f68bd00e217e Closes-Bug: #1818560 Depends-On: I8c36f35dbe85b0c0db1a5b6b5389b160b68ca488
This commit is contained in:
parent
c7db20d140
commit
09090c8277
@ -20,7 +20,7 @@ from oslo_config import fixture as config_fixture
|
||||
from oslo_utils.fixture import uuidsentinel as uuids
|
||||
import pkg_resources
|
||||
from placement import direct
|
||||
from placement.tests import fixtures as placement_db
|
||||
from placement.tests.functional.fixtures import placement
|
||||
|
||||
from nova.cmd import status
|
||||
from nova.compute import provider_tree
|
||||
@ -89,10 +89,13 @@ class SchedulerReportClientTestBase(test.TestCase):
|
||||
def setUp(self):
|
||||
super(SchedulerReportClientTestBase, self).setUp()
|
||||
# Because these tests use PlacementDirect we need to manage
|
||||
# the database ourselves.
|
||||
# the database and other config ourselves.
|
||||
config = cfg.ConfigOpts()
|
||||
placement_conf = self.useFixture(config_fixture.Config(config))
|
||||
self.useFixture(placement_db.Database(placement_conf, set_config=True))
|
||||
self.useFixture(
|
||||
placement.PlacementFixture(conf_fixture=placement_conf, db=True,
|
||||
use_intercept=False))
|
||||
self.placement_conf = placement_conf.conf
|
||||
|
||||
def _interceptor(self, app=None, latest_microversion=True):
|
||||
"""Set up an intercepted placement API to test against.
|
||||
@ -122,7 +125,7 @@ class SchedulerReportClientTestBase(test.TestCase):
|
||||
return client
|
||||
|
||||
interceptor = ReportClientInterceptor(
|
||||
CONF, latest_microversion=latest_microversion)
|
||||
self.placement_conf, latest_microversion=latest_microversion)
|
||||
if app:
|
||||
interceptor.app = app
|
||||
return interceptor
|
||||
|
Loading…
Reference in New Issue
Block a user