This GitHub Action, named "Feature Release Test", automates the process of releasing new features for the Cytoscape.js repository. This action is triggered by a manual workflow_dispatch event, allowing you to specify the version of the new release. The action performs various tasks, including merging changes, running tests, publishing to npmjs and GitHub Releases, deploying to GitHub Pages, and creating a related issue on the repository's blog.
Before using this GitHub Action, ensure you have the following prerequisites in place:
- Access to the Cytoscape.js repository.
- Necessary access tokens and secrets stored as GitHub repository secrets:
NPM_TOKEN
: Token for npmjs package publishing. Ref: How to create legacy token in npmMAIN_GH_TOKEN
: Token for accessing GitHub API to publish GitHub Releases on Cytoscape/Cytoscape.js repo. Ref: Create fine-grained-personal-access-tokensCYTOSCAPE_JS_BLOG_TOKEN
: Token for creating issues on the repository's blog Cytoscape/Cytoscape.js-blog repo.
- Navigate to the Cytoscape.js repository.
- Go to the Actions tab.
- Click on Feature-Release workflow.
- Click the "Run workflow" button.
- DO NOT CHANGE BRANCH FROM
unstable
FOR RELEASE. Provide the desired version for the new release when prompted if you want to do a feature release for a specific version. Note: This version will used as the version of release. Otherwise, the github will automatically determine a new version based upon package.json version
Below are the steps performed by the "Feature Release Test" GitHub Action:
-
Checkout Patch Branch:
- Action: Checks out the
unstable
branch. - Uses:
actions/checkout@v3
.
- Action: Checks out the
-
Setup Node.js Environment:
- Action: Sets up Node.js environment.
- Uses:
actions/setup-node@v3
. - Node Version: 18.
- Caches npm packages.
-
Get New Version String:
- Action: Determines the new version for the release.
- Script: Determines the new version based on user input or a script.
- Uses the
github.event.inputs.version
input for the version if provided.
-
Checkout Master Branch:
- Action: Checks out the
master
branch. - Uses:
actions/checkout@v3
.
- Action: Checks out the
-
Merge Unstable to Master Branch:
- Action: Merges changes from
unstable
tomaster
branch. - Custom script: Fetches and merges changes from the
unstable
branch.
- Action: Merges changes from
-
Install Dependencies:
- Action: Installs project dependencies.
- Command:
npm install
.
-
Run Tests:
- Action: Runs tests for the project.
- Command:
npm test
.
-
Pre Release Tests:
- Action: Runs pre-release tests.
- Custom script: Executes pre-release tests with the
master
branch.
-
Archive Code Coverage Results:
- Action: Archives code coverage results in case of test failure.
- Uses:
actions/upload-artifact@v3
.
-
Publish Package to npmjs:
- Action: Publishes the package to npmjs.
- Command:
npm publish
.
-
Publish Package to GitHub Releases:
- Action: Publishes the package to GitHub Releases.
- Uses GitHub API to create a release with provided information.
-
Deploy to Github Pages:
- Action: Deploys documentation to GitHub Pages.
- Uses:
JamesIves/github-pages-deploy-action@v4
.
-
Create Issue:
- Action: Creates an issue on the repository's blog.
- Creates an issue with a title and body based on a template.