Skip to main content

Pytest plugin providing Arrakis fixtures for testing

Project description

pytest-arrakis

Pytest plugin providing Arrakis fixtures for testing

pypi version


Resources

Installation

pip install pytest-arrakis

To enable publish fixtures (including a real Kafka-backed server), install the publish extra:

pip install pytest-arrakis[publish]

Fixtures

Core fixtures

These are available out of the box:

Fixture Scope Description
arrakis_channel_configs session List of paths to the bundled per-publisher config files
arrakis_backend session A MockBackend configured with all bundled channels (regular and replay)
arrakis_server session A running mock ArrakisFlightServer with a replay registry (sets ARRAKIS_SERVER env var)
arrakis_channels session Dict of channel metadata loaded from the bundled TOML (regular channels only)
arrakis_mock_publisher function A mocked Publisher with FakeProducer for sink testing (no server/broker needed)

Replay fixtures

These provide replay-specific resources for testing replay functionality:

Fixture Scope Description
arrakis_replay_channel_configs session List of paths to the bundled replay publisher config files
arrakis_replay_params session A ReplayParams for the bundled FAKE_REPLAY window (fixed 24-hour period)
arrakis_replay_channels session Dict of channel metadata from the replay configs only
arrakis_replay_mock_publisher function A mocked replay Publisher with FakeProducer for sink testing

Publish fixtures (requires publish extra)

These are conditionally registered when arrakis-backend-kafka and pytest-kafka-broker are installed:

Fixture Scope Description
arrakis_publish_backend function A real KafkaBackend pointed at an embedded Kafka broker (includes replay configs)
arrakis_publish_server function A publish-capable ArrakisFlightServer with a replay registry
arrakis_publisher function A real Publisher registered against the embedded broker
arrakis_replay_publisher function A real Publisher for the replay namespace against the embedded broker

Usage

Fetching data from a mock server

def test_fetch(arrakis_server):
    import arrakis

    block = arrakis.fetch(["H1:TEST-CHANNEL_SIN"], 0, 1)
    for channel, series in block.items():
        assert len(series) > 0

Testing a publisher without a real broker

def test_publish(arrakis_mock_publisher):
    publisher, fake_producer, published_blocks = arrakis_mock_publisher

    # publish a block through your code under test ...
    assert len(published_blocks) == 1

End-to-end publish testing (requires publish extra)

def test_roundtrip(arrakis_publisher):
    # arrakis_publisher is a real Publisher connected to an embedded Kafka broker
    ...

Testing replay channel discovery

def test_replay_find(arrakis_server, arrakis_replay_params):
    from arrakis import Client

    client = Client(arrakis_server.url)
    # replay channels are only visible when querying with the replay ID
    replay_channels = list(client.find(replay_id="FAKE_REPLAY"))
    assert len(replay_channels) > 0

Testing a replay publisher without a real broker

def test_replay_publish(arrakis_replay_mock_publisher):
    publisher, fake_producer, published_blocks = arrakis_replay_mock_publisher

    # publish a block through your code under test ...
    assert len(published_blocks) == 1

Bundled test channels

The plugin ships with a set of test channel definitions:

Regular channels

Channel Publisher Sample Rate Data Type
H1:TEST-CHANNEL_SIN FAKE_H1 512 float32
H1:TEST-CHANNEL_COS FAKE_H1 16384 float64
H1:TEST-STATE_ONES FAKE_H1 16 int32
L1:TEST-NOISE FAKE_L1 4096 float32

Replay channels

These are tagged with replay_id = "FAKE_REPLAY" and are only visible when querying with the corresponding replay ID:

Channel Publisher Sample Rate Data Type
H1:REPLAY-CHANNEL_SIN FAKE_REPLAY_H1 512 float32
H1:REPLAY-STATE_ONES FAKE_REPLAY_H1 16 int32

CI setup

GitLab CI

The core fixtures work without any extra system dependencies. However, the publish extra uses pytest-kafka-broker, which starts an embedded Kafka broker that requires a JVM at runtime. In Debian/Ubuntu-based CI images (including the standard python: Docker images), install it in a before_script:

test:
  image: python:3.13
  before_script:
    - apt-get update && apt-get install -y --no-install-recommends default-jre-headless

If you only use the core fixtures (no publish extra), the JVM is not needed.

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

pytest_arrakis-0.5.0.tar.gz (9.8 kB view details)

Uploaded Source

Built Distribution

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

pytest_arrakis-0.5.0-py3-none-any.whl (13.3 kB view details)

Uploaded Python 3

File details

Details for the file pytest_arrakis-0.5.0.tar.gz.

File metadata

  • Download URL: pytest_arrakis-0.5.0.tar.gz
  • Upload date:
  • Size: 9.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.16.5 cpython/3.13.12 HTTPX/0.28.1

File hashes

Hashes for pytest_arrakis-0.5.0.tar.gz
Algorithm Hash digest
SHA256 b88d8408a8fdcb8a72948b1ed134a1a01cc95b9cb1ec35a8d24dbe4fea2b3292
MD5 63d089446f2c8e3cc5286a4c488a7f10
BLAKE2b-256 b94482b8b488eefd5ab8355eda4db64a50d89445f15d41f732160b86090cbba2

See more details on using hashes here.

File details

Details for the file pytest_arrakis-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: pytest_arrakis-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 13.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.16.5 cpython/3.13.12 HTTPX/0.28.1

File hashes

Hashes for pytest_arrakis-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 4be952a98eb6f987999efaf6970d77057e034d8e11b84ba2fa0ee9596ded2d75
MD5 7b080d1731cce2f2446004b0a1fd5a8f
BLAKE2b-256 071861b7de5ff98503f8bcea89d4720d8b157987c3165a6a37d58750a5fea0f9

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