This document describes the process of publishing releases for our VS Code extension and provides an explanation of the GitHub Actions workflow file.
The release process is automated using GitHub Actions. When a new release is created on GitHub, it triggers the release workflow defined in .github/workflows/release.yml
. The workflow performs the following steps:
- Checks out the repository.
- Installs Node.js and the required dependencies.
- Builds the extension using webpack.
- Packages the extension into a
.vsix
file. - Publishes the extension to the Visual Studio Code Marketplace.
- Generates a changelog based on the commit messages.
- Creates a GitHub release with the packaged extension file as an artifact and the changelog.
Before creating a release, ensure that:
- The extension is properly configured and builds successfully.
- The Personal Access Token (PAT) is set as a repository secret named
VSCE_PAT
.
To create a new release:
- Go to the GitHub repository page.
- Click on the "Releases" tab.
- Click on the "Draft a new release" button.
- Enter the tag version for the release (e.g.,
v1.0.0
). - Set the release title and description.
- Choose the appropriate release type (e.g., pre-release or stable release).
- Click on the "Publish release" button.
Creating the release will trigger the release workflow automatically.
The release workflow is defined in .github/workflows/release.yml
. Here's an explanation of each step in the workflow:
-
Checkout Repository: This step checks out the repository using the
actions/checkout@v2
action. -
Install Node.js: This step sets up Node.js using the
actions/setup-node@v2
action. It specifies the Node.js version and enables caching of npm dependencies. -
Install dependencies: This step runs
npm ci
to install the project dependencies. -
Build Extension: This step runs
npm run package
to build the extension using webpack. -
Package Extension: This step runs
npm run vsce-package
to package the extension into a.vsix
file namedzenml.vsix
. -
Publish Extension: This step runs
npm run deploy
to publish the extension to the Visual Studio Code Marketplace. It uses theVSCE_PAT
secret for authentication. This step only runs if the previous steps succeeded and the workflow was triggered by a new tag push. -
Generate Changelog: This step generates a changelog by running
git log
to retrieve the commit messages between the latest tag and the current commit. The changelog is saved in a file namedCHANGELOG.txt
. This step only runs if the previous steps succeeded and the workflow was triggered by a new tag push. -
Create GitHub Release: This step uses the
ncipollo/release-action@v1
action to create a GitHub release. It attaches thezenml.vsix
file as an artifact, includes the changelog, and sets the release tag based on the pushed tag. This step only runs if the previous steps succeeded and the workflow was triggered by a new tag push.
The provided GitHub Actions workflow automates the publishing of the ZenML VSCode extension. The workflow ensures that the extension is built, packaged, published to the marketplace, and a GitHub release is created with the necessary artifacts and changelog.
Remember to keep the extension code up to date, maintain the required dependencies, and test the extension thoroughly before creating a release.