pydocks


Namepydocks JSON
Version 1.6.1 PyPI version JSON
download
home_pageNone
SummaryPytest fixures for running tests with Docker containers
upload_time2024-12-27 22:33:46
maintainerNone
docs_urlNone
authorNone
requires_python>=3.9
licenseMIT
keywords containers docker postgresql pydocks pytest redis test vault
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # 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"
}
        
Elapsed time: 0.42199s