Skip to main content

upgrade projects created from a Cookiecutter template

Project description

Cookiecutter Project Upgrader

https://img.shields.io/pypi/v/cookiecutter_project_upgrader.svg CI Status - master Documentation Status Code Coverage

Upgrade projects created from a Cookiecutter template.

Features

Cookiecutter Project Upgrader allows upgrading projects that were created using Cookiecutter.

After a project has been created from a Cookiecutter template, changes made to the Cookiecutter template usually have to be applied manually to the project. This tool automates this process.

When run the first time on a project, it creates a new branch from the first commit of the current branch (the oldest one). It then generates the project again using the latest version of the template and creates a new commit that contains the latest cookiecuttered code,

Usage: cookiecutter_project_upgrader [OPTIONS]

Upgrade projects created from a Cookiecutter template

Options:
-c, --context-file PATH

Default: docs/cookiecutter_input.json

-b, --branch TEXT

Default: cookiecutter-template

-u, --upgrade-branch TEXT

Optional branch name of cookiecutter template to checkout before upgrading.

-f, --zip-file TEXT

Zip file Path/URL for Cookiecutter templates.

-i, --interactive

Enter interactive mode. Default behaviour: skip questions, use defaults.

-m, --merge-now BOOLEAN

Execute a git merge after a successful update, default: ask if interactive, otherwise false.

-p, --push-template-branch-changes BOOLEAN

Push changes to the remote Git branch on a successful update, default: ask if interactive, otherwise false.

-e, --exclude TEXT

Git pathspecs to exclude from the update commit, e.g. -e “*.py” -e “tests/”.

-h, --help

Show this message and exit.

Preconditions

The tool requires a JSON file with context that matches the existing service. This file can be created through Cookiecutter with the following contents:

{{ cookiecutter | jsonify }}

You will need a recent version of git for this to work. (it needs –no-checkout on git worktree)

Auto-Completion

The script uses the Click toolkit. Because the script uses Click, you can enable completion for Zsh and Bash.

For Bash, add the following to your .bashrc or some other profile initialization file. eval “$(_COOKIECUTTER_PROJECT_UPGRADER_COMPLETE=source cookiecutter_project_upgrader)”

For Zsh, please read the Click documentation.

Credits

The concept and some code is heavily based on https://github.com/senseyeio/cupper, with some changes to use Click and some flags and default values to ease usage. Also cleanup has been done and automated tests have been added.

This package was created with Cookiecutter and the thomasjahoda/cookiecutter-pypackage project template.

History

1.0.0 (2019-03-22)

  • First release on PyPI.

1.1.0 (2019-03-24)

  • Ask for some options interactively if within interactive shell.

1.2.0 (2020-08-02)

  • Move interactive mode behind -i flag.

  • Add -p flag to push the branch on successful update.

  • Add -e flag to exclude git pathspecs from the update.

  • Do not run pre-commit hooks on the update commit.

  • Expose -h flag in addition to –help.

  • Finish with non-zero exit status if there are no changes to be made (for shell piping).

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

cookiecutter_project_upgrader-1.3.1.tar.gz (25.2 kB view details)

Uploaded Source

Built Distribution

cookiecutter_project_upgrader-1.3.1-py2.py3-none-any.whl (8.7 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file cookiecutter_project_upgrader-1.3.1.tar.gz.

File metadata

  • Download URL: cookiecutter_project_upgrader-1.3.1.tar.gz
  • Upload date:
  • Size: 25.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.10.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.9.2

File hashes

Hashes for cookiecutter_project_upgrader-1.3.1.tar.gz
Algorithm Hash digest
SHA256 20c48970acacc5d22a33b7ac0bca74674b2690563748cc9c3c5728048eb97b6d
MD5 80b16e63980696b0018074bc4ea34986
BLAKE2b-256 8511e4bfe94ec93ceeb9dc4871e384a4be0a79ab350eb1c7685e784958cd5485

See more details on using hashes here.

File details

Details for the file cookiecutter_project_upgrader-1.3.1-py2.py3-none-any.whl.

File metadata

  • Download URL: cookiecutter_project_upgrader-1.3.1-py2.py3-none-any.whl
  • Upload date:
  • Size: 8.7 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.10.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.9.2

File hashes

Hashes for cookiecutter_project_upgrader-1.3.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 bcf9f49e2a66201ce6cfe28aed8f6bf722d82618ace5abbeb5a11b1ad45d7b8e
MD5 9f326a867eea409d19fdaf2da06c92ae
BLAKE2b-256 47e9260a3f98f69903607368193e191855435094546e736fe74d4dc8ed27a94c

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