Skip to main content

Pytest custom features, e.g. fixtures and various tests. Aimed to emulate Google Cloud Storage service

Project description

Introduction

Pytest custom features, e.g. fixtures and various tests. Aimed to emulate Google Cloud Storage service

Requirements / Resources

Usage

The project involves the development of a custom pytest plugin that emulates the Google Cloud Storage (GCS) service to support streamlined testing workflows.

It is built on top of the original docker image that handles natively google-cloud-storage functionality, with the project adding the necessary internal configuration to integrate seamlessly with Polars.

Originally designed to validate Polars DataFrame read/write operations in a simulated remote environment, the plugin enables efficient testing without relying on actual cloud infrastructure.

This setup allows for comprehensive integration testing that closely mirrors real-world cloud interactions.

Run the emulator manually

# If you intend to run the image without passing by pytest
docker run -v /tmp/data:/data -d -p 9023:9023 --name storage_emulator fsouza/fake-gcs-server -port 9023 -scheme http -backend memory -public-host 127.0.0.1:9023 -external-url http://127.0.0.1:9023 -filesystem-root /storage

The parameters are exactly the same as the docker command in the plugin.py file.

Linter

Ruff is the default Python linter used in the project.

If you want to check it, just run ruff check.

All ruff configuration are stored in the pyproject.toml file.

The check command can be added as a pre-commit hook

If by any mean you forget to check the syntax of your code before committing it, the .pre-commit-config.yaml will call ruff check. This avoids unnecessary commits that correct the fact that you forgot to apply the command.

# Install pre-commit
python3 -m pip install pre-commit
# Install ruff pre-commit in git correct path 
python3 -m pre-commit install

How to test the plugin

Under the folder tests you'll find common and small tests used to give you the possibility and the usage you can have.

Appendix

Below, find attached

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_google_cloud_storage-1.1.2.tar.gz (7.2 kB view details)

Uploaded Source

Built Distribution

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

pytest_google_cloud_storage-1.1.2-py3-none-any.whl (7.9 kB view details)

Uploaded Python 3

File details

Details for the file pytest_google_cloud_storage-1.1.2.tar.gz.

File metadata

File hashes

Hashes for pytest_google_cloud_storage-1.1.2.tar.gz
Algorithm Hash digest
SHA256 cd41c691f99d6e6086c04c0a5557f180ea40aacc063b51a086d2d387f18f2c68
MD5 fd5e511166a7b19205f521ac3ba623f2
BLAKE2b-256 f7f263d3f71fab1efa5900c0289f9bf2d7d0e08a18d66c82c40cce5d6e4e1bb4

See more details on using hashes here.

Provenance

The following attestation bundles were made for pytest_google_cloud_storage-1.1.2.tar.gz:

Publisher: pypi-push.yaml on Jankovn/pytest-google-cloud-storage

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

File details

Details for the file pytest_google_cloud_storage-1.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for pytest_google_cloud_storage-1.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 d7d4c975cbbd72cd7558def718d09ed79a149f241dd8414e5ab28afd01a2f7a8
MD5 53e32e60764c88f94c46476253ead4d1
BLAKE2b-256 6545b8f5959d8dd075369d74568115b9b5ec543a7115312e814586504a6a72ed

See more details on using hashes here.

Provenance

The following attestation bundles were made for pytest_google_cloud_storage-1.1.2-py3-none-any.whl:

Publisher: pypi-push.yaml on Jankovn/pytest-google-cloud-storage

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