/PSRepositoryReleaseManager

A project for generating release notes and creating releases, such as GitHub releases.

Primary LanguagePowerShellApache License 2.0Apache-2.0

PSRepositoryReleaseManager

github-workflows github-release

A project for generating release notes and creating releases, such as GitHub releases.

Introduction

This project provides entrypoint scripts, CI remote templates, and PowerShell cmdlets that other projects can utilize for generating release notes and creating releases.

Setup

PSRepositoryReleaseManager can be used as an independent project, or as a submodule for generating release notes and creating releases.

Independent project

To use PSRepositoryReleaseManager as an independent project, simply perform a clone of the repository including its submodules to development or CI environment(s) prior to executing provided entrypoint script(s) to perform their respective functions.

# Clone PSRepositoryReleaseManager with its submodules
git clone https://github.com/theohbrothers/PSRepositoryReleaseManager.git --recurse-submodules

Submodule

PSRepositoryReleaseManager can be used as submodule together with provided CI remote template(s).

Main project structure

To use PSRepositoryReleaseManager as a submodule, main projects are to adopt the following directory structure:

/build/                                 # Directory containing build files
/build/PSRepositoryReleaseManager/      # The root directory of PSRepositoryReleaseManager as a submodule

Adding the submodule

Add PSRepositoryReleaseManager as a submodule under the directory build in your main project:

# Add the submodule
git submodule add https://github.com/theohbrothers/PSRepositoryReleaseManager.git build/PSRepositoryReleaseManager

# Checkout submodules recursively
git submodule update --init --recursive build/PSRepositoryReleaseManager

# Checkout ref to use
git --git-dir build/PSRepositoryReleaseManager/.git checkout vx.x.x

# Commit the submodule
git commit -am 'Add submodule PSRepositoryReleaseManager vx.x.x'

Configuration

CI remote templates

Note: This section only applies if using the project as a submodule.

Decide on which CI provider to use in your main project based on those supported by this project. Then setup the CI file(s) for your main project, referencing relevant CI remote template(s) of this project from your main project's CI file(s).

Sample CI files can be found here.

CI settings

Configure the following CI settings for your main project if PSRepositoryReleaseManager is to be used in a CI environment, whether it be as an independent project or a submodule.

Secrets

GitHub API token

Note: This step is only necessary for creating releases on CI environments.

Add a secret variable GITHUB_API_TOKEN containing your GitHub API token, ensuring it has write permissions to the repository.

In the case where GitHub Actions is used for releases, the job token GITHUB_TOKEN may be used for creating releases should it have write permissions to the repository.

Environment variables

Project directory

By default, the provided entrypoint scripts use an existing superproject's directory or else an existing project's directory as the path for generating release notes and creating releases. To override the default location, set the environment variable PROJECT_DIRECTORY to contain a custom directory value before executing the entrypoint scripts.

Usage

The project provides a set of entrypoint scripts for generating release notes and creating releases for other projects, designed to be used identically in both development and CI environments.

Development

Generating release notes

The entrypoint script Invoke-Generate.ps1 is used to generate release notes for any local git repository. To do so, simply define applicable environment variables before executing the entrypoint script.

The project includes inbuilt and samples of .vscode/tasks.json for generating release notes via Build Tasks in VSCode. Simply execute relevant build task(s) while entering custom or default values per variable prompt.

Variants

The names of all available release notes variants that can be chosen from can be found in the module's generate/variants directory, and goes by the convention <VariantName>.ps1.

Valid tags

Generating of release notes supports all tag refs. Tags need not follow Semantic Versioning though the convention is recommended.

Creating releases

The entrypoint script Invoke-Release.ps1 can be used to create releases for GitHub repositories. To do so, simply define applicable environment variables before executing the entrypoint script.

The project includes inbuilt and samples of .vscode/tasks.json for creating releases via Build Tasks in VSCode. Simply execute relevant build task(s) while entering custom or default values per variable prompt. Note that due to the inability to enter multiline strings in build tasks, the options RELEASE_NOTES_CONTENT and RELEASE_ASSETS are presently unavailable and limited in usability respectively.

Valid tags

Creation of releases supports all tag refs. Tags need not follow Semantic Versioning though the convention is recommended.

Continuous Integration (CI)

via Entrypoint script(s)

The following are environment variables supported by the provided entrypoint scripts for generating release notes and creating releases.

Environment variables
Generate and Release
Name Example value Mandatory Type
PROJECT_DIRECTORY /path/to/my-project false string
RELEASE_TAG_REF vx.x.x / branch / HEAD / remote/branch / commit-hash false (Generate), true (Release) string
Generate
Name Example value Mandatory Type
RELEASE_NOTES_VARIANT VersionDate-HashSubject-NoMerges-CategorizedSorted (List of available variants) false string
RELEASE_NOTES_PATH .release-notes.md (relative) /
/path/to/.release-notes.md (full)
false string
Release
Name Example value Mandatory Type
RELEASE_NAMESPACE mygithubnamespace true string
RELEASE_REPOSITORY my-project true string
GITHUB_API_TOKEN xxx true string
RELEASE_NAME My release name false string
RELEASE_NOTES_CONTENT My

multi-line
release
notes
false string (multiline)
RELEASE_DRAFT true / false false string
RELEASE_PRERELEASE true / false false string
RELEASE_ASSETS path/to/asset1.tar.gz
path/to/asset2.gz
path/to/asset3.zip
path/to/assets/*.gz
path/to/assets/*.zip
false string (multiline)
Commands

To generate release notes and create releases, simply clone a specified version of the project, and define applicable environment variables before executing the project's provided entrypoint script(s) within the CI environment.

# Clone PSRepositoryReleaseManager
git clone https://github.com/theohbrothers/PSRepositoryReleaseManager.git --recurse-submodules --branch 'vx.x.x' # Specify tag ref to checkout to

# Process applicable environment variables
export RELEASE_TAG_REF=$( echo "$GITHUB_REF" | sed -rn 's/^refs\/tags\/(.*)/\1/p' )
export RELEASE_NAMESPACE="$GITHUB_REPOSITORY_OWNER"
export RELEASE_REPOSITORY=$( basename "$( git rev-parse --show-toplevel )" )

# Generate (Generates release notes)
pwsh -NoLogo -NonInteractive -NoProfile -Command './PSRepositoryReleaseManager/Invoke-Generate.ps1'

# Release (Creates GitHub release)
pwsh -NoLogo -NonInteractive -NoProfile -Command './PSRepositoryReleaseManager/Invoke-Release.ps1'

Note: Ensure the environment variable GITHUB_API_TOKEN is defined prior to creating releases.

Sample CI files demonstrating use of this approach can be found here.

via Submodule and CI remote templates

Generating release notes

To generate release notes, reference the appropriate generate.yml entrypoint CI remote template provided by this project from your main project's CI file. The generate.yml templates also support the following parameters for customizing the generation of release notes.

Creating releases

Note: Ensure your main project's CI file(s) and/or settings are configured to run CI jobs for tag refs, and that the environment variable GITHUB_API_TOKEN is defined prior to creating releases.

To create releases, reference the appropriate release.yml entrypoint CI remote template provided by this project from your main project's CI file. The release.yml templates also support the following parameters for customizing the creation of releases.

Maintenance

Submodule

Using a specific tag

# Update the submodule
git submodule update --remote build/PSRepositoryReleaseManager

# Checkout ref to use
git --git-dir build/PSRepositoryReleaseManager/.git checkout vx.x.x

# Bump PSRepositoryReleaseManager to the same ref in CI file
vi azure-pipelines.yml

# Commit the submodule and CI file
git commit -am 'Bump PSRepositoryReleaseManager to vx.x.x'

Best practices

  • Use only tag refs of PSRepositoryReleaseManager in your main project.
  • If using the project as a Submodule with CI remote templates, ensure your main project's CI file(s) is configured to use the CI remote templates of PSRepositoryReleaseManager, and that the ref matches that of the PSRepositoryReleaseManager submodule used in your main project.