All Projects → hackebrot → Pytest Cookies

hackebrot / Pytest Cookies

Licence: mit
The pytest plugin for your Cookiecutter templates. 🍪

Programming Languages

python
139335 projects - #7 most used programming language

Projects that are alternatives of or similar to Pytest Cookies

Wemake Django Template
Bleeding edge django template focused on code quality and security.
Stars: ✭ 1,141 (+1088.54%)
Mutual labels:  cookiecutter, pytest
Cookiecutter Cms
Python-centric Cookiecutter for Molecular Computational Chemistry Packages
Stars: ✭ 197 (+105.21%)
Mutual labels:  cookiecutter, pytest
Wagtail Pipit
Pipit is a Wagtail CMS boilerplate which aims to provide an easy and modern developer workflow with a React-rendered frontend.
Stars: ✭ 109 (+13.54%)
Mutual labels:  cookiecutter, pytest
cookiecutter-flask-react
Cookiecutter for a Flask+React project
Stars: ✭ 22 (-77.08%)
Mutual labels:  cookiecutter, pytest
Cookiecutter Pytest Plugin
A Cookiecutter template for pytest plugins 💻
Stars: ✭ 181 (+88.54%)
Mutual labels:  cookiecutter, pytest
Python Best Practices Cookiecutter
Python best practices project cookiecutter 🍪
Stars: ✭ 286 (+197.92%)
Mutual labels:  cookiecutter, pytest
Pytest Grpc
Allow test gRPC with pytest
Stars: ✭ 63 (-34.37%)
Mutual labels:  pytest
Cookietemple
A collection of best practice cookiecutter templates for all domains and languages with extensive Github support
Stars: ✭ 81 (-15.62%)
Mutual labels:  cookiecutter
React Native Template
Template React Native project to be used with Cookiecutter
Stars: ✭ 61 (-36.46%)
Mutual labels:  cookiecutter
Dicomweb Client
Python client for DICOMweb RESTful services
Stars: ✭ 60 (-37.5%)
Mutual labels:  pytest
Django Project Template
Thorgate's Django project template - Django, React, Sass, optional Docker and more
Stars: ✭ 91 (-5.21%)
Mutual labels:  cookiecutter
Pytest Deadfixtures
Plugin to list unused fixtures in your tests
Stars: ✭ 89 (-7.29%)
Mutual labels:  pytest
Pytest Json Report
🗒️ A pytest plugin to report test results as JSON
Stars: ✭ 77 (-19.79%)
Mutual labels:  pytest
Pytest Instafail
py.test plugin to show failures instantly
Stars: ✭ 86 (-10.42%)
Mutual labels:  pytest
Integration tests
ManageIQ integration tests
Stars: ✭ 63 (-34.37%)
Mutual labels:  pytest
Cookiecutter Fastapi
Cookiecutter template for FastAPI projects using: Machine Learning, Poetry, Azure Pipelines and Pytests
Stars: ✭ 89 (-7.29%)
Mutual labels:  cookiecutter
Pyautotest
Stars: ✭ 61 (-36.46%)
Mutual labels:  pytest
Flake8 Pytest Style
A flake8 plugin checking common style issues or inconsistencies with pytest-based tests.
Stars: ✭ 74 (-22.92%)
Mutual labels:  pytest
Pytest Regressions
Pytest plugin for regression testing: https://pytest-regressions.readthedocs.io
Stars: ✭ 89 (-7.29%)
Mutual labels:  pytest
Syrupy
🥞 The sweeter pytest snapshot plugin
Stars: ✭ 73 (-23.96%)
Mutual labels:  pytest

pytest-cookies

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-cookies is a pytest plugin that comes with a cookies fixture which is a wrapper for the cookiecutter 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-cookies is available for download from PyPI via pip:

pip install pytest-cookies

This will automatically install pytest and cookiecutter.

Usage

Generate a new project

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

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

    assert result.exit_code == 0
    assert result.exception is None
    assert result.project.basename == "helloworld"
    assert result.project.isdir()

The cookies.bake() method also accepts the extra_context keyword argument that will be passed to cookiecutter. 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 cookiecutter documentation.

Specify the template directory

By default cookies.bake() looks for a cookiecutter 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 cookiecutter template directory from a test by passing in the optional template paramter:

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

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

    return template


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

    assert result.exit_code == 0
    assert result.exception is None
    assert result.project.basename == "example-project"
    assert result.project.isdir()

Keep output directories for debugging

By default cookies 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-cookies 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-cookies is free and open source software.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].