Prevent races in opportunistic db test cases
Previously opportunistic db test cases used to share openstack_citest database among all test cases, which could be run concurrently in different test running processes. With recent changes made to our CI, we now can create and drop database schemas on demand in tests. Providing each opportunistic db test case with its own DB will effectively prevent possible races. Related-Bug: #1288916 Change-Id: I7f6e272eaeb776b6a645ba502853892e79312afd
This commit is contained in:
parent
4f638de853
commit
b5e4815563
@ -21,9 +21,9 @@ import fixtures
|
|||||||
from oslotest import base as test_base
|
from oslotest import base as test_base
|
||||||
import six
|
import six
|
||||||
|
|
||||||
|
from openstack.common.db.sqlalchemy import provision
|
||||||
from openstack.common.db.sqlalchemy import session
|
from openstack.common.db.sqlalchemy import session
|
||||||
from openstack.common.db.sqlalchemy import utils
|
from openstack.common.db.sqlalchemy import utils
|
||||||
from openstack.common.fixture import lockutils
|
|
||||||
|
|
||||||
|
|
||||||
class DbFixture(fixtures.Fixture):
|
class DbFixture(fixtures.Fixture):
|
||||||
@ -43,12 +43,14 @@ class DbFixture(fixtures.Fixture):
|
|||||||
|
|
||||||
self.test = test
|
self.test = test
|
||||||
|
|
||||||
|
def cleanUp(self):
|
||||||
|
self.test.engine.dispose()
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(DbFixture, self).setUp()
|
super(DbFixture, self).setUp()
|
||||||
|
|
||||||
self.test.engine = session.create_engine(self._get_uri())
|
self.test.engine = session.create_engine(self._get_uri())
|
||||||
self.test.sessionmaker = session.get_maker(self.test.engine)
|
self.test.sessionmaker = session.get_maker(self.test.engine)
|
||||||
self.addCleanup(self.test.engine.dispose)
|
|
||||||
|
|
||||||
|
|
||||||
class DbTestCase(test_base.BaseTestCase):
|
class DbTestCase(test_base.BaseTestCase):
|
||||||
@ -103,11 +105,24 @@ class OpportunisticFixture(DbFixture):
|
|||||||
DRIVER = abc.abstractproperty(lambda: None)
|
DRIVER = abc.abstractproperty(lambda: None)
|
||||||
DBNAME = PASSWORD = USERNAME = 'openstack_citest'
|
DBNAME = PASSWORD = USERNAME = 'openstack_citest'
|
||||||
|
|
||||||
def _get_uri(self):
|
def setUp(self):
|
||||||
return utils.get_connect_string(backend=self.DRIVER,
|
self._provisioning_engine = provision.get_engine(
|
||||||
|
utils.get_connect_string(backend=self.DRIVER,
|
||||||
user=self.USERNAME,
|
user=self.USERNAME,
|
||||||
passwd=self.PASSWORD,
|
passwd=self.PASSWORD,
|
||||||
database=self.DBNAME)
|
database=self.DBNAME)
|
||||||
|
)
|
||||||
|
self._uri = provision.create_database(self._provisioning_engine)
|
||||||
|
|
||||||
|
super(OpportunisticFixture, self).setUp()
|
||||||
|
|
||||||
|
def cleanUp(self):
|
||||||
|
super(OpportunisticFixture, self).cleanUp()
|
||||||
|
|
||||||
|
provision.drop_database(self._provisioning_engine, self._uri)
|
||||||
|
|
||||||
|
def _get_uri(self):
|
||||||
|
return self._uri
|
||||||
|
|
||||||
|
|
||||||
@six.add_metaclass(abc.ABCMeta)
|
@six.add_metaclass(abc.ABCMeta)
|
||||||
@ -121,9 +136,6 @@ class OpportunisticTestCase(DbTestCase):
|
|||||||
FIXTURE = abc.abstractproperty(lambda: None)
|
FIXTURE = abc.abstractproperty(lambda: None)
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
# TODO(bnemec): Remove this once infra is ready for
|
|
||||||
# https://review.openstack.org/#/c/74963/ to merge.
|
|
||||||
self.useFixture(lockutils.LockFixture('opportunistic-db'))
|
|
||||||
credentials = {
|
credentials = {
|
||||||
'backend': self.FIXTURE.DRIVER,
|
'backend': self.FIXTURE.DRIVER,
|
||||||
'user': self.FIXTURE.USERNAME,
|
'user': self.FIXTURE.USERNAME,
|
||||||
|
Loading…
Reference in New Issue
Block a user