Skip to main content

The pytest plugin for your Django Boilerplate.

Project description

pytest-boilerplate

pytest is a mature testing framework for Python that is developed by a thriving and ever-growing community of volunteers. It uses plain assert statements and regular Python comparisons. At the core of the pytest test framework is a powerful hook-based plugin system.

pytest-boilerplate is a pytest plugin that comes with a boilerplate fixture which is a wrapper for the devxhub_python API for generating projects. It helps you verify that your template is working as expected and takes care of cleaning up after running the tests. 🍪

Installation

pytest-boilerplate is available for download from PyPI via pip:

pip install pytest-boilerplate

This will automatically install pytest and devxhub_python.

Usage

Generate a new project

The boilerplate.bake() method generates a new project from your template based on the default values specified in devxhub_python.json:

def test_bake_project(boilerplate):
    result = boilerplate.bake(extra_context={"repo_name": "helloworld"})

    assert result.exit_code == 0
    assert result.exception is None

    assert result.project_path.name == "helloworld"
    assert result.project_path.is_dir()

    # The `project` attribute is deprecated
    assert result.project.basename == "helloworld"
    assert result.project.isdir()

Please note that the project attribute of the returned Result class is deprecated and will be removed in a future release, please use project_path instead.

The boilerplate.bake() method also accepts the extra_context keyword argument that will be passed to devxhub_python. The given dictionary will override the default values of the template context, effectively allowing you to test arbitrary user input data.

For more information on injecting extra context, please check out the devxhub_python documentation.

Specify the template directory

By default boilerplate.bake() looks for a devxhub_python template in the current directory. This can be overridden on the command line by passing a --template parameter to pytest:

pytest --template TEMPLATE

You can customize the devxhub_python template directory from a test by passing in the optional template paramter:

@pytest.fixture
def custom_template(tmpdir):
    template = tmpdir.ensure("devxhub_python-template", dir=True)
    template.join("devxhub_python.json").write('{"repo_name": "example-project"}')

    repo_dir = template.ensure("{{devxhub_python.repo_name}}", dir=True)
    repo_dir.join("README.rst").write("{{devxhub_python.repo_name}}")

    return template


def test_bake_custom_project(boilerplate, custom_template):
    """Test for 'devxhub_python-template'."""
    result = boilerplate.bake(template=str(custom_template))

    assert result.exit_code == 0
    assert result.exception is None

    assert result.project_path.name == "example-project"
    assert result.project_path.is_dir()

Keep output directories for debugging

By default boilerplate removes baked projects.

However, you can pass the keep-baked-projects flag if you'd like to keep them (it won't clutter as pytest only keeps the three newest temporary directories):

pytest --keep-baked-projects

Community

Contributions are very welcome! If you encounter any problems, please file an issue along with a detailed description. Tests can be run with tox. Please make sure all of the tests are green before you submit a pull request.

You can also support the development of this project by volunteering to become a maintainer, which means you will be able to triage issues, merge pull-requests, and publish new releases. If you're interested, please submit a pull-request to add yourself to the list of maintainers and we'll get you started! 🍪

Please note that pytest-boilerplate is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms.

License

Distributed under the terms of the MIT license, pytest-boilerplate is free and open source software.

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-boilerplate-0.0.3.tar.gz (8.7 kB view details)

Uploaded Source

Built Distribution

pytest_boilerplate-0.0.3-py3-none-any.whl (6.5 kB view details)

Uploaded Python 3

File details

Details for the file pytest-boilerplate-0.0.3.tar.gz.

File metadata

  • Download URL: pytest-boilerplate-0.0.3.tar.gz
  • Upload date:
  • Size: 8.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.9

File hashes

Hashes for pytest-boilerplate-0.0.3.tar.gz
Algorithm Hash digest
SHA256 f635af4ff9cb6cb5470b99e2722a6bf3cacb2fe35df7f48cd4fa78568aced007
MD5 b9882146477cbf3e0dbf521dcbdc605a
BLAKE2b-256 71e6e2e0e4ab488cba5aef39dcb2aaee86f6cac3d16b1781be2097bd56ceb9da

See more details on using hashes here.

File details

Details for the file pytest_boilerplate-0.0.3-py3-none-any.whl.

File metadata

File hashes

Hashes for pytest_boilerplate-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 54e743cfd9c31ccaca830aa6f72a301b72bb403170c8a7ea43b2348f42f6a299
MD5 3a77e4f686b0bebadad4a36fa12ca07b
BLAKE2b-256 d03488bb4730fea844cc8da53a493e350474976fd26e4e8a31015741368ef0f6

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page