Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

NEW Add gauge release and dispatching gha-auto-tag. #25

Merged
merged 1 commit into from
Jul 31, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
37 changes: 33 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,17 +17,43 @@ jobs:
- name: Create tag and release
uses: silverstripe/gha-tag-release@v1
with:
skip_gauge_release: true
tag: 1.2.3
release: true
release: false
```

### Inputs

#### tag (required)
The tag to create e.g. 1.2.3
### Latest local sha
Required if not skipping gauge release.

The result of `$(git rev-parse HEAD)`.

`latest_local_sha: f22dbc6ec6118096c8ccccee1ca0074bfb2f2291`

### Skip gauge release
Whether to skip gauging the release. Gauging the release will only allow tagging if all of the following are true:

- The branch this action is run against is a patch branch (e.g. `1.2`)
- The `latest_local_sha` input matches the `github.sha` GitHub actions variable
- The `latest_local_sha` input matches the current latest commit sha on this branch
- There's an existing stable semver patch tag for this branch already (i.e. for branch `1.2` there must be a `1.2.<digit>` tag)
- There are commits on the branch that warrant a new patch release and weren't included in the latest patch release for this branch

Gauging the release also identifies the correct next patch tag, and uses that to tag the release. Default is false, enable with:

`skip_gauge_release: true`

#### tag
Required if skipping gauge release. Cannot be provided if _not_ skipping gauge release.

The tag to create e.g. `1.2.3`.

#### delete_existing
Cannot be provided if _not_ skipping gauge release.

Whether to delete any existing tags or releases that match tag if they exist. Default is false, enable with:

`delete_existing: true`

#### release
Expand All @@ -38,17 +64,20 @@ The description text used for the release - format with markdown

#### release_auto_notes
Whether to use the github API to auto generate the release which will be appended to `release_description`. Default is false, enable with:

`release_auto_notes: true`

## Why there is no SHA input paramater
## Why there is no SHA input parameter when not using gauge release

Creating a tag for a particular SHA, either via the GitHub API or via CLI (i.e. git tag) in an action is strangely blocked. The error is "Resource not accessible by integration" which is a permissions error.

However, tags can be created with the following methods:

- Using `${{ github.sha }}` which is the latest sha in a context instead of historic sha
- Creating a release via GitHub API, which will also create a tag. While it's tempting to just use this and then delete the release, it's seems possible that this may stop working in the future

The following methods have been attempted:

- Using third party actions to create tags
- Passing in `permissions: write-all` from the calling workflow
- Passing in a github token from the calling workflow
Expand Down
Loading
Loading