Skip to main content

A mock for the ScyllaDB Python driver for testing purposes.

Project description

mockylla

PyPI - Version PyPI - Python Version License

A lightweight, in-memory mock for the ScyllaDB Python driver. mockylla allows you to run integration-style tests for code that depends on ScyllaDB without requiring a live cluster.


✨ Key Features

  • Drop-in replacement  |  Patch the scylla-driver at runtime with a single decorator – no changes to your application code.
  • Fast & isolated  |  All state lives in-memory and is reset between tests, ensuring perfect test isolation.
  • Inspectable  |  Helper utilities expose the internal state so you can assert against keyspaces, tables, and rows.
  • Pythonic API  |  Mirrors the real driver's public API to minimise cognitive load and surprises.
  • No network dependencies  |  Works entirely offline; ideal for CI pipelines and contributor development environments.

📦 Installation

pip install mockylla

mockylla supports Python 3.8 → 3.11 and is continuously tested against the latest scylla-driver release.


🚀 Quick Start

from mockylla import mock_scylladb, get_keyspaces
from cassandra.cluster import Cluster

@mock_scylladb
def test_my_app_creates_a_keyspace():
    # Arrange – connect to the mocked cluster (no real network I/O!)
    cluster = Cluster(["127.0.0.1"])
    session = cluster.connect()

    # Act – run application logic
    session.execute(
        """
        CREATE KEYSPACE my_app_keyspace \
        WITH REPLICATION = {'class': 'SimpleStrategy', 'replication_factor': 1}
        """
    )

    # Assert – inspect mock state
    assert "my_app_keyspace" in get_keyspaces()

Tip Place @mock_scylladb on individual tests or a session-scoped fixture to enable the mock for an entire module.


🏗️ Comprehensive Example

from mockylla import mock_scylladb, get_table_rows
from cassandra.cluster import Cluster

@mock_scylladb
def test_crud():
    cluster = Cluster()
    session = cluster.connect()

    session.execute(
        "CREATE KEYSPACE ks WITH replication = {'class': 'SimpleStrategy', 'replication_factor': 1}"
    )
    session.set_keyspace("ks")

    session.execute(
        """
        CREATE TABLE users (
            user_id int PRIMARY KEY,
            name text,
            email text
        )
        """
    )

    # INSERT
    session.execute("INSERT INTO users (user_id, name, email) VALUES (1, 'Alice', 'alice@example.com')")

    # SELECT
    assert session.execute("SELECT name FROM users WHERE user_id = 1").one().name == "Alice"

    # UPDATE
    session.execute("UPDATE users SET email = 'alice@new.com' WHERE user_id = 1")

    # DELETE
    session.execute("DELETE FROM users WHERE user_id = 1")

    # Final state check
    assert get_table_rows("ks", "users") == []

🔍 Public API

Function / Decorator Description
mock_scylladb Context-manages the mock driver by patching cassandra.connection.Connection.factory & Cluster.connect.
get_keyspaces() Return a dict of keyspace names → definition.
get_tables(keyspace) Return a dict of table names → definition.
get_table_rows(keyspace, table) Return the current rows for table as a list[dict].
get_types(keyspace) Return user-defined types for the keyspace.

📄 License

mockylla is distributed under the MIT license.


🙌 Acknowledgements

  • Inspired by the fantastic moto project for AWS.
  • Built on top of the official scylla-driver by ScyllaDB.

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

mockylla-0.1.0.tar.gz (31.8 kB view details)

Uploaded Source

Built Distribution

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

mockylla-0.1.0-py3-none-any.whl (17.1 kB view details)

Uploaded Python 3

File details

Details for the file mockylla-0.1.0.tar.gz.

File metadata

  • Download URL: mockylla-0.1.0.tar.gz
  • Upload date:
  • Size: 31.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for mockylla-0.1.0.tar.gz
Algorithm Hash digest
SHA256 f6aa86df7582f8cca9392784356dcc52c6578f0eadb1dcca1cf136f6c03c828b
MD5 58b4bbd113db47e419efc16ef3dd2ec1
BLAKE2b-256 6b57bcc50058766b4537b586ca105b20bd5aa97e0487a4a84b473bf281b2489b

See more details on using hashes here.

Provenance

The following attestation bundles were made for mockylla-0.1.0.tar.gz:

Publisher: pypi_release.yml on GenLogs/mockylla

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mockylla-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: mockylla-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 17.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for mockylla-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 4de06c7bb48641cff0d883461487898c115ae9ce39e651c58b033c668f57e445
MD5 36a1612e95ca1e3e96314b19a9ba7bc4
BLAKE2b-256 c35d997cdf1680105d1a2a3eac5fbd37cf5196ab7f7871758c83cf62ddc8571d

See more details on using hashes here.

Provenance

The following attestation bundles were made for mockylla-0.1.0-py3-none-any.whl:

Publisher: pypi_release.yml on GenLogs/mockylla

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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