The pytest plugin for your devxhub_python templates. 🍪
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
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
File details
Details for the file pytest-boilerplate-0.0.2.tar.gz
.
File metadata
- Download URL: pytest-boilerplate-0.0.2.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
Algorithm | Hash digest | |
---|---|---|
SHA256 | 813e08ff74489baec97497fed355acfdbade3fb936cb4808be3ff6ddf1e1e2bd |
|
MD5 | 6de8f2786dedb571f91d73cace7f509a |
|
BLAKE2b-256 | f32361a9f713cb8825c53a0ec33167c5e3aafa2e63de2330dc563a54e9fb8928 |
File details
Details for the file pytest_boilerplate-0.0.2-py3-none-any.whl
.
File metadata
- Download URL: pytest_boilerplate-0.0.2-py3-none-any.whl
- Upload date:
- Size: 6.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 84c575d853fbf8d29e8045caa35c195051b755c79615257df38618617eb5b07f |
|
MD5 | 194a56d2a2214f1908217706cbf0bd11 |
|
BLAKE2b-256 | 73ec2c3dd2335e5c9ce010ac99d97ebdd74353f277de699ab1092155e077d390 |