Skip to main content

No project description provided

Project description

This package contains test fixtures and resources that bring up an isolated database and SQLAlchemy test fixtures, so that your Python unit tests will run without interfering with each other when you are using the SQLAlchemy ORM.

The database is initialised once at the start of a test process run, as is the session fixture. The session fixture ensures that any commits do not permanently commit, and rolls back the database to a clean state after each test completes.

Requirements

Python 3.8 and beyond should work.

Quickstart

Install with pip:

pip install db-testtools

Example base test class:

class DBTestCase(testresources.ResourcedTestCase, testtools.TestCase):
    """Base class for all DB tests.

   Brings up a temporary database and gives each test its own session.
   """

   # These are resources that stay active for the entire
   # duration of all the tests being run.
   db_fixture = DatabaseResource(
       ModelBase,
       'myproject.models',
       future=True,
   )
   resources = [('database', db_fixture)]

   def setUp(self):
       super().setUp()

       self.session_fixture = SessionFixture(self.database, future=True)
       self.useFixture(self.session_fixture)
       # The session itself.
       self.session = self.session_fixture.session
       # The session factory.
       self.Session = self.session_fixture.Session

This base test class will start a SQLite-based database by default and inject self.session as the SQLAlchemy session and self.Session as the SQLAlchemy session factory.

If you need to use a different database, then you can either:
  • pass the engine_fixture_name parameter to DatabaseResource

  • set an environment variable TEST_ENGINE_FIXTURE

with the name of the engine fixture to use. Currently two are available:

  • SqliteMemoryFixture

  • PostgresContainerFixture

Engine drivers

Currently the two drivers mentioned above are implemented. The SQLite fixture implements a simple in-memory database which is completely dropped and re-instated on every test.

The PostgresContainerFixture starts its own Postgres instance in a local Docker container. Therefore you must have Docker installed before using this fixture. The Postgres image used by default is 16.3-alpine, but this fixture is known to work all the way back to v11.

If you are already running inside Docker you will need to start the container with –network-“host” so that 127.0.0.1 routes to the started PG containers. You will need to do up to two extra things:

  1. Bind mount /var/run/docker.sock to the container so docker clients can create sibling containers on the host.

  2. If you cannot use host networking, supply the IP address of the host’s network bridge (usually docker0, etc), so that the fixture knows where to find the PG server. The IP address is either supplied via the constructor to PostgresContainerFixture or you can set the DBTESTTOOLS_PG_IP_ADDR environment variable.

If you want to use Podman instead of Docker engine you will need to follow these steps:

1. Enable and start podman on your host `bash systemctl --user enable podman systemctl --user start podman ` 2. export DBTESTTOOLS_USE_PODMAN=1 variable.

This code has been in use daily on a large project at Cisco for a few years now, and is very stable.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

db_testtools-2025.5.6.tar.gz (13.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

db_testtools-2025.5.6-py3-none-any.whl (18.5 kB view details)

Uploaded Python 3

File details

Details for the file db_testtools-2025.5.6.tar.gz.

File metadata

  • Download URL: db_testtools-2025.5.6.tar.gz
  • Upload date:
  • Size: 13.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for db_testtools-2025.5.6.tar.gz
Algorithm Hash digest
SHA256 00bdf8b3b3e80e72b890d0ef59121eb3f4897919e007d5b016b9851e72283678
MD5 98713136de4af7c06df224caab060c5a
BLAKE2b-256 f95013ed23aa56b7fbe2a706c32b71d599506376a3e45d52653482d4679c9ec9

See more details on using hashes here.

File details

Details for the file db_testtools-2025.5.6-py3-none-any.whl.

File metadata

File hashes

Hashes for db_testtools-2025.5.6-py3-none-any.whl
Algorithm Hash digest
SHA256 765a24acc076b3781d66df60fd5356a0c55e1fa866a87d91fa110aa928301f8c
MD5 cc6e0bf9122fbe3b64510b313891dc4b
BLAKE2b-256 1a22ab2c6de7ca0735443d38fcd223342f12ccfcb54848b7002a94656e9311cf

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page