Skip to main content

Test copier templates

Project description

copier-template-tester

./ctt-logo.png

Parametrize copier templates to test for syntax errors, check the expected output, and to check against copier versions.

Note that ctt only tests the copier copy operation and doesn't check the update behavior and any version-specific logic that your template may contain because of how quickly those tests become complex.

Usage

Configuration File

When creating a copier template repository, I recommend following the nested "subdirectory" approach so that the directory looks like this:

└── template_dir
│   └── {{ _copier_conf.answers_file }}.jinja
├── README.md
├── copier.yml
└── ctt.toml

Create a new ctt.toml file in the top-level directory of your copier repository. Populate the file to look like the below example.

# Specify shared data across all 'output' destinations
# Note that the copier.yml defaults are used whenever the key is not set in this file
[defaults]
project_name = "placeholder"
copyright_year = 2022

# Parametrize each output with a relative path and optionally any values to override
[output.".ctt/defaults"]

[output.".ctt/no_all"]
package_name = "testing-no-all"
include_all = false

Post tasks

Use _post_tasks to run tasks after the template's tasks:

[defaults]
_post_tasks = [
  "pre-commit run --all-files",
]

[output.".ctt/also-run-pytest-here"]
_post_tasks = [
  "uv run pytest",
]

Note: _extra_tasks is also supported, but _post_tasks is preferred for consistency with _pre_tasks and _skip_tasks

Skip template tasks

Use _skip_tasks = true to skip tasks defined in the template's copier.yaml:

[output.".ctt/fast-test"]
_skip_tasks = true
_post_tasks = ["pytest"] # only this runs

Pre tasks

Use _pre_tasks to run tasks before the template's tasks:

[output.".ctt/with-validation"]
_pre_tasks = ["./validate-env.sh"]

Pre-Commit Hook

First, add this section to your .pre-commit-config.yml file:

repos:
  - repo: https://github.com/KyleKing/copier-template-tester
    rev: main
    hooks:
      - id: copier-template-tester

Tip: Optionally add an exclude rule if unrelated files trigger unnecessary re-runs:

repos:
  - repo: https://github.com/KyleKing/copier-template-tester
    rev: main
    hooks:
      - id: copier-template-tester
        exclude: ^(tests/|docs/|\.github/)

Install and update to the latest revision:

pre-commit autoupdate

The run with pre-commit:

pre-commit run --all-files copier-template-tester

pipx

You can also try ctt as a CLI tool by installing with pipx:

pipx install copier-template-tester

cd ~/your/copier/project
ctt

More Examples

For more example code, see the scripts directory or the tests.

Project Status

See the Open Issues and/or the CODE_TAG_SUMMARY. For release history, see the CHANGELOG.

Contributing

We welcome pull requests! For your pull request to be accepted smoothly, we suggest that you first open a GitHub issue to discuss your idea. For resources on getting started with the code base, see the below documentation:

Code of Conduct

We follow the Contributor Covenant Code of Conduct.

Open Source Status

We try to reasonably meet most aspects of the "OpenSSF scorecard" from Open Source Insights

Responsible Disclosure

If you have any security issue to report, please contact the project maintainers privately. You can reach us at dev.act.kyle@gmail.com.

License

LICENSE

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

copier_template_tester-2.3.0.tar.gz (10.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

copier_template_tester-2.3.0-py3-none-any.whl (11.7 kB view details)

Uploaded Python 3

File details

Details for the file copier_template_tester-2.3.0.tar.gz.

File metadata

  • Download URL: copier_template_tester-2.3.0.tar.gz
  • Upload date:
  • Size: 10.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for copier_template_tester-2.3.0.tar.gz
Algorithm Hash digest
SHA256 a0c6cf6a13daffe637c95a26f20cacc2b768862408390150d936080822d61819
MD5 a3947d510622280904196f91e532f7c8
BLAKE2b-256 1ca90d28b4d7c9ff1b601348fd3d7b70db6ca83c254bfe9f49ae6160f6b2c1e2

See more details on using hashes here.

Provenance

The following attestation bundles were made for copier_template_tester-2.3.0.tar.gz:

Publisher: publish.yml on KyleKing/copier-template-tester

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file copier_template_tester-2.3.0-py3-none-any.whl.

File metadata

File hashes

Hashes for copier_template_tester-2.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 749565a585e47789bd450e3af8707a1e1cc6c76592bc323c63f6133bfd923d78
MD5 9886deb224b5c0c6cb2ae4541452091e
BLAKE2b-256 abb30c5e53e79e22acf046e3254503343d7c0b3982ad6888101ff51a2c283d8b

See more details on using hashes here.

Provenance

The following attestation bundles were made for copier_template_tester-2.3.0-py3-none-any.whl:

Publisher: publish.yml on KyleKing/copier-template-tester

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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