1
0
This commit is contained in:
Stephan 2021-12-12 19:42:25 +01:00
parent 888cfb7f0c
commit e87cd570d2
2 changed files with 66 additions and 34 deletions

40
.github/workflows/hz.js vendored Normal file
View File

@ -0,0 +1,40 @@
// see https://github.com/actions/github-script
// , core, glob, io, exec, require
module.exports = function (github, context) {
var module = {}
// this is *not* exported
function noop ( ) { }
// this *is* exported
module.getReleaseByTag = function (tag_name) {
var rel = null
try {
// this does *not* return draft releases, so we have to list them
//rel = await github.repos.getReleaseByTag({ ... })
const rels = await github.repos.listReleases({
owner: context.repo.owner,
repo: context.repo.repo
})
for (const r of rels.data) {
if (r.tag_name === tag_name) {
rel = r
break
}
}
}
catch (error) {
return null
}
return rel
}
module.getRefReleaseTag = function (ref) {
// test, must start with 'refs/heads/release/' 19 chars
return "v" + ref.substring(19)
}
return module;
}

View File

@ -1,11 +1,23 @@
name: Publish Release name: Publish Release
on: workflow_dispatch on: workflow_dispatch
input:
confirm:
description: 'This is really going to release. Are you sure?'
required: true
default: false
jobs: jobs:
job: job:
runs-on: ubuntu-latest runs-on: ubuntu-latest
if: startsWith(github.ref, 'refs/heads/release/') if: startsWith(github.ref, 'refs/heads/release/')
steps: steps:
- name: Confirm
if: ${{ github.event.inputs.confirm }} == false
uses: actions/github-script@v4
with:
script: |
core.setFailed(`Not confirmed (confirm = '${{ github.event.inputs.confirm }}').`)
- name: Validate the release - name: Validate the release
uses: actions/github-script@v4 uses: actions/github-script@v4
with: with:
@ -13,27 +25,14 @@ jobs:
# token needed to see draft releases when getting all releases # token needed to see draft releases when getting all releases
github-token: ${{ secrets.MY_GITHUB_TOKEN_TESTREPO }} github-token: ${{ secrets.MY_GITHUB_TOKEN_TESTREPO }}
script: | script: |
const ver = "${{ github.ref }}".substring(19) const hz = require("hz.js")(github, context)
const tag = "v" + ver const ref = "${{ github.ref }}"
var rel = null const tag = hz.getRefReleaseTag(ref)
try { if (tag === null) {
// this does *not* return draft releases, so we have to list them core.setFailed(`Invalid reference ${ref} is not release/<version>.`)
//rel = await github.repos.getReleaseByTag({ ... })
const rels = await github.repos.listReleases({
owner: context.repo.owner,
repo: context.repo.repo
})
for (const r of rels.data) {
if (r.tag_name === tag) {
rel = r
break
}
}
}
catch (error) {
core.setFailed(`Could not find a release for tag ${tag}.`)
return return
} }
var rel = hz.getReleaseByTag(tag)
if (rel === null) { if (rel === null) {
core.setFailed(`Could not find a release for tag ${tag}.`) core.setFailed(`Could not find a release for tag ${tag}.`)
return return
@ -81,21 +80,14 @@ jobs:
uses: actions/github-script@v4 uses: actions/github-script@v4
with: with:
script: | script: |
const ver = "${{ github.ref }}".substring(19) const hz = require("hz.js")(github, context)
const tag = "v" + ver const ref = "${{ github.ref }}"
var rel = null const tag = hz.getRefReleaseTag(ref)
// no, see above if (tag === null) {
//const rel = await github.repos.getReleaseByTag({ ... }) core.setFailed(`Invalid reference ${ref} is not release/<version>.`)
const rels = await github.repos.listReleases({ return
owner: context.repo.owner, }
repo: context.repo.repo var rel = hz.getReleaseByTag(tag)
})
for (const r of rels.data) {
if (r.tag_name === tag) {
rel = r
break
}
}
await github.repos.updateRelease({ await github.repos.updateRelease({
owner: context.repo.owner, owner: context.repo.owner,
repo: context.repo.repo, repo: context.repo.repo,