pytest servers
Project description
pytest servers
Features
Create temporary directories on the following filesystems:
Local fs
In-memory fs
S3, both using mock S3 remotes (https://github.com/spulec/moto) and real S3 remotes
Azure, both using mock Azure remotes (https://github.com/Azure/Azurite) via docker and using real Azure Storage remotes
Google Cloud Storage, both using mock GCS remote (https://github.com/fsouza/fake-gcs-server) via docker and using real Google Storage Remotes
Installation
You can install pytest servers via pip from PyPI:
$ pip install pytest-servers
To use temporary S3 paths:
$ pip install pytest-servers[s3]
To use temporary Azure paths
$ pip install pytest-servers[azure]
To use temporary Google Cloud Storage paths
$ pip install pytest-servers[gcs]
To install all extras:
$ pip install pytest-servers[all]
Usage
The main fixture provided by pytest-servers provides is tmp_upath_factory, which can be used to generate temporary paths on different (mocked) filesystems:
def test_something_on_s3(tmp_upath_factory):
path = tmp_upath_factory.mktemp("s3")
foo = path / "foo"
foo.write_text("foo")
...
mktemp supports the following filesystem types:
local (local filesystem)
memory (in-memory filesystem)
s3 (Amazon S3)
gcs (Google Cloud Storage)
azure (Azure Storage)
Some convenience fixtures that wrap tmp_upath_factory.mktemp and return a paths on these filesystems are also available:
tmp_local_path
tmp_memory_path
tmp_s3_path
tmp_gcs_path
tmp_azure_path
The tmp_upath fixture can be used for parametrizing paths with pytest’s indirect parametrization:
@pytest.mark.parametrize("tmp_upath", ["local", "s3", "gcs", "gs"], indirect=True)
def test_something(tmp_upath):
pass
In order to use real remotes instead of mocked ones, use tmp_upath_factory with the following methods
tmp_upath_factory.s3(region_name, client_kwargs) where client_kwargs are passed to the underlying S3FileSystem/boto client
tmp_upath_factory.gcs(endpoint_url)
tmp_upath_factory.azure(connection_string)
Versioning support can be used by using the versioning fixture. This is currently supported for s3 and gcs remotes
# using mktemp
def test_something_on_s3_versioned(tmp_upath_factory):
path = tmp_upath_factory.mktemp("s3", version_aware=True)
assert path.fs.version_aware # bucket has versioning enabled
# or, using remote-specific fixtures
def test_something_on_s3_versioned(tmp_s3_path, versioning):
assert tmp_s3_path.fs.version_aware # bucket has versioning enabled
Contributing
Contributions are very welcome. To learn more, see the Contributor Guide.
License
Distributed under the terms of the Apache 2.0 license, pytest servers is free and open source software.
Issues
If you encounter any problems, please file an issue along with a detailed description.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for pytest_servers-0.5.7-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 724c83ba087133db6ba7316642c0982e54debc5c7fb46019b76fdbe5070d735f |
|
MD5 | 5bac970171c83220c86848ee0777481a |
|
BLAKE2b-256 | 6e3ce19c3d9fe100665a1152bc6e6cf54c051898c9f23db791c21d1ec7960137 |