Skip to content

Files

Latest commit

7f58e12 · Feb 3, 2022

History

History
68 lines (50 loc) · 2.46 KB

README.md

File metadata and controls

68 lines (50 loc) · 2.46 KB

javascript-release-workflow

Github workflow to simplify creating a release for a Node.js action. This will automatically increment the version of a tag (ex: v1.1 -> v1.2, v2 -> v2.1).

New releases are cut from the main (or master) branch. When creating a release branch PR we install all node_modules and execute npm run build. A draft release will also be created if any branch with the prefix releases/ is pushed to.

This was created for the specific workflow of two digit release names (first number for major / breaking improvements and 2nd number for smaller changes). Major releases are stored on a releases/v1 branch with the number corresponding to the major version. Modifying this workflow to support other workflows would be trivial.

Previously, to create a release for a Node.js project, developers had to:

  • Create a new branch (if a new major version)
  • Remove node_modules and remove them from .gitignore
  • Remove lib from .gitignore
  • Run npm install --no-bin-links
  • Push to the new branch
  • Check which tag should be used
  • Create a tag
  • Create the release

These workflows automate the process.

Usage

Add the following two workflow files to your .github/workflows folder for a reusable workflow.

# .github/workflows/release-pr.yml
name: Create release PR

on:
  workflow_dispatch:
    inputs:
      release:
        description: "Define release major version (ex: v1, v2, v3)"
        required: true

jobs:
  release-pr:
    uses: OliverMKing/javascript-release-workflow/.github/workflows/release-pr.yml@main
    with:
      release: ${{ github.event.inputs.release }}

and

# .github/workflows/tag-and-draft.yml
name: Tag and create release draft

on:
  push:
    branches:
      - releases/*

jobs:
  tag-and-release:
    uses: OliverMKing/javascript-release-workflow/.github/workflows/tag-and-release.yml@main

When you want to create a workflow follow these steps:

  • Go to the Actions tab of your Github repository
  • Select Create release PR on the left side
  • Select Run workflow then enter your release version (ex: v1, v2, v3)
  • Find the created pull request and approve it (it may take a minute for the workflow to create the new release)
  • Go to Releases then edit the created release (edit title, add release notes) and publish release

Note: Workflows won't be run on PRs triggered by other actions. Close the PR then reopen it if you want workflows to be run.