# PyDocks
PyDocks is a group of pytest fixures for running tests with Docker containers
### Demonstration:
```python
@pytest.mark.asyncio
async def test_postgresql_execute_command(postgresql_container):
# Connect to the PostgreSQL database
conn = await asyncpg.connect(
host="127.0.0.1",
port=5433,
user="postgres",
password="postgres",
database="postgres",
)
try:
# Execute a simple command
result = await conn.fetchval("SELECT 1")
assert result == 1, "Failed to execute command on PostgreSQL"
finally:
# Close the connection
await conn.close()
```
## Table of Contents
- [PyDocks](#PyDocks)
- [Table of Contents](#table-of-contents)
- [Description](#description)
- [Installation](#installation)
- [Usage](#usage)
- [License](#license)
- [Contact](#contact)
## Description
PyDocks is a Python library that provides a set of pytest fixtures for running tests with Docker containers. It simplifies the process of setting up, managing, and tearing down Docker containers during test execution.
Key features include:
- Easy integration with pytest
- Support for PostgreSQL, Hashicorp Vault containers, Redis
- Automatic container cleanup
- Configurable container settings
- Reusable session-scoped containers for improved test performance
PyDocks is designed to make testing with Docker containers more efficient and less error-prone, allowing developers to focus on writing tests rather than managing infrastructure.
## Installation
```bash
# Install the dependency
pip install pydocks
uv add pydocks
poetry add pydocks
```
## Usage
### Remove all old containers
```python
import pytest_asyncio
@pytest_asyncio.fixture(scope="session", loop_scope="session", autouse=True)
async def begin_clean_all_containers(postgresql_clean_all_containers):
logger.info("Begin - clean all containers")
```
### Use a function container
```python
@pytest.mark.asyncio
async def test_postgresql_execute_command(postgresql_container):
...
```
### Use a session container, to keep the container to use it in multiple tests
```python
@pytest.mark.asyncio(loop_scope="session")
async def test_reuse_postgresql_container_1_2(postgresql_container_session):
...
# postgresql_container_session creates a new container
@pytest.mark.asyncio(loop_scope="session")
async def test_reuse_postgresql_container_2_2(postgresql_container_session):
...
# postgresql_container_session uses the same instance of container created in test_reuse_postgresql_container_1_2
```
## License
PyDocks is released under the MIT License. See the [LICENSE](LICENSE) file for more details.
## Contact
For questions, suggestions, or issues related to PyDocks, please open an issue on the GitHub repository.
Raw data
{
"_id": null,
"home_page": null,
"name": "pydocks",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.9",
"maintainer_email": null,
"keywords": "containers, docker, postgresql, pydocks, pytest, redis, test, vault",
"author": null,
"author_email": "Sylvain Mouquet <sylvain.mouquet@gmail.com>",
"download_url": "https://files.pythonhosted.org/packages/65/4b/cfffe8e62633c1cdebccd21f20908b2ad8a11fa82884b84ec80da3019d65/pydocks-1.6.1.tar.gz",
"platform": null,
"description": "# PyDocks\n\nPyDocks is a group of pytest fixures for running tests with Docker containers\n\n### Demonstration:\n\n```python\n@pytest.mark.asyncio\nasync def test_postgresql_execute_command(postgresql_container):\n # Connect to the PostgreSQL database\n conn = await asyncpg.connect(\n host=\"127.0.0.1\",\n port=5433,\n user=\"postgres\",\n password=\"postgres\",\n database=\"postgres\",\n )\n\n try:\n # Execute a simple command\n result = await conn.fetchval(\"SELECT 1\")\n assert result == 1, \"Failed to execute command on PostgreSQL\"\n finally:\n # Close the connection\n await conn.close()\n\n```\n\n## Table of Contents\n\n- [PyDocks](#PyDocks)\n - [Table of Contents](#table-of-contents)\n - [Description](#description)\n - [Installation](#installation)\n - [Usage](#usage)\n - [License](#license)\n - [Contact](#contact)\n\n## Description\n\nPyDocks is a Python library that provides a set of pytest fixtures for running tests with Docker containers. It simplifies the process of setting up, managing, and tearing down Docker containers during test execution.\n\nKey features include:\n- Easy integration with pytest\n- Support for PostgreSQL, Hashicorp Vault containers, Redis\n- Automatic container cleanup\n- Configurable container settings\n- Reusable session-scoped containers for improved test performance\n\nPyDocks is designed to make testing with Docker containers more efficient and less error-prone, allowing developers to focus on writing tests rather than managing infrastructure.\n\n## Installation\n\n```bash\n# Install the dependency\npip install pydocks\nuv add pydocks\npoetry add pydocks\n```\n\n## Usage\n\n### Remove all old containers\n```python\nimport pytest_asyncio\n\n@pytest_asyncio.fixture(scope=\"session\", loop_scope=\"session\", autouse=True)\nasync def begin_clean_all_containers(postgresql_clean_all_containers):\n logger.info(\"Begin - clean all containers\")\n```\n\n### Use a function container\n```python\n@pytest.mark.asyncio\nasync def test_postgresql_execute_command(postgresql_container):\n ...\n```\n\n### Use a session container, to keep the container to use it in multiple tests\n```python\n@pytest.mark.asyncio(loop_scope=\"session\")\nasync def test_reuse_postgresql_container_1_2(postgresql_container_session):\n ...\n # postgresql_container_session creates a new container\n\n@pytest.mark.asyncio(loop_scope=\"session\")\nasync def test_reuse_postgresql_container_2_2(postgresql_container_session):\n ...\n # postgresql_container_session uses the same instance of container created in test_reuse_postgresql_container_1_2\n```\n\n\n## License\n\nPyDocks is released under the MIT License. See the [LICENSE](LICENSE) file for more details.\n\n## Contact\n\nFor questions, suggestions, or issues related to PyDocks, please open an issue on the GitHub repository.\n\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "Pytest fixures for running tests with Docker containers",
"version": "1.6.1",
"project_urls": {
"changelog": "https://github.com/sylvainmouquet/pydocks/releases",
"documentation": "https://github.com/sylvainmouquet/pydocks",
"homepage": "https://github.com/sylvainmouquet/pydocks",
"repository": "https://github.com/sylvainmouquet/pydocks"
},
"split_keywords": [
"containers",
" docker",
" postgresql",
" pydocks",
" pytest",
" redis",
" test",
" vault"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "255ed0407f552eba44b6822835e5d4f95d922d9c81afa85b41c17a8172447085",
"md5": "80bc641af4b5f766f6e973bbf09ad77b",
"sha256": "28803ca403beb2c7ce06b3a9734c05b56097fac2daa62ed44b798c89a0b70749"
},
"downloads": -1,
"filename": "pydocks-1.6.1-py3-none-any.whl",
"has_sig": false,
"md5_digest": "80bc641af4b5f766f6e973bbf09ad77b",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.9",
"size": 11179,
"upload_time": "2024-12-27T22:33:44",
"upload_time_iso_8601": "2024-12-27T22:33:44.632742Z",
"url": "https://files.pythonhosted.org/packages/25/5e/d0407f552eba44b6822835e5d4f95d922d9c81afa85b41c17a8172447085/pydocks-1.6.1-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "654bcfffe8e62633c1cdebccd21f20908b2ad8a11fa82884b84ec80da3019d65",
"md5": "7ee896214dbdb0a103cb62fea0343480",
"sha256": "28c62edef419871e0a13995f4e2870eea89944bf476ca85d396939fa718ea213"
},
"downloads": -1,
"filename": "pydocks-1.6.1.tar.gz",
"has_sig": false,
"md5_digest": "7ee896214dbdb0a103cb62fea0343480",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.9",
"size": 73199,
"upload_time": "2024-12-27T22:33:46",
"upload_time_iso_8601": "2024-12-27T22:33:46.836807Z",
"url": "https://files.pythonhosted.org/packages/65/4b/cfffe8e62633c1cdebccd21f20908b2ad8a11fa82884b84ec80da3019d65/pydocks-1.6.1.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-12-27 22:33:46",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "sylvainmouquet",
"github_project": "pydocks",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "pydocks"
}