Thanks for taking the time to contribute! 😄
To contribute to the main Cypress product, please read the related CONTRIBUTING document, which also contains useful general tips.
To contribute to the cypress-io/github-action repository, please continue reading here.
All contributors are expected to abide by our Code of Conduct.
This document describes topics useful to contributors to this repository. The repository's purpose is to provide a GitHub JavaScript action which is published to:
- GitHub's Marketplace as cypress-io/github-action
- npm's JavaScript Package Registry as @cypress/github-action
You can read the GitHub document Creating a JavaScript action for background information on how JavaScript actions for GitHub are created and how they work.
You must have the following installed on your system to contribute locally:
Node.js
(See the .node-version file for the required version. You can find a list of tools on node-version-usage to switch the version ofNode.js
based on .node-version.)
If you are submitting a Pull Request (PR) to provide a fix or feature for the action, the following is relevant to you:
The main source code elements for the action are:
The action runs from the dist directory, which requires a build
step to set up. This step uses @vercel/ncc to compile the code and modules into one file used for distribution.
To contribute changes, follow these instructions in the order given below:
-
If you are a new external contributor, then first fork the repository (see GitHub documentation About forks).
-
Clone the repository
-
Create a new branch with a meaningful name e.g.
fix/my-bug
based on the currentmaster
branch. -
Make the necessary source code changes, including additions or changes to the README.md documentation if parameters are added or affected.
-
Execute the following in the root directory of the cloned repository
npm install npm run format npm run build
-
Commit the change. (If you are working on Microsoft Windows, see Windows users below.)
-
Push to the repository.
-
If you are working in a fork, ensure actions are enabled.
-
Refer to Manually running a workflow to use this to test any particular workflow affected by your change.
-
Open a draft PR with a title which starts with
fix:
orfeat:
if a new release should be triggered by the PR. For more details on the release process, see the section Merging pull requests below. -
Note that first-time submitters must sign the CLA agreement and be approved to run workflows.
-
Check that all tests which are triggered by the PR were either successful or were skipped.
-
If the PR is showing that the tests were successful mark the PR as Ready for Review.
The repository is set up with a git
/ Husky
pre-commit hook which ensures that any changes to the core source files are formatted and built consistently before they are committed. This does not work well with GitHub Desktop. You can disable this function by setting an environment variable HUSKY=0
. If you do this and then omit to use npm run format
/ npm run build
before you commit any changes affecting the core source files, you will find that checks fail when you submit a PR. In this case you should run the format
and build
commands and amend your commit.
- If you are creating a new example, add this as a new project in the
examples
directory. An example project is a regular npm package with its ownpackage.json
and Cypress dev dependency. (Note: Legacyexamples/v9
are archived in the v5 branch and are no longer supported or maintained.) - Add a corresponding
.github/workflows
YAML file that uses this action and runs using your newexamples/X
through theworking-directory
parameter. The example should demonstrate any new feature. - Add a workflow status badge to the README.md file (see Adding a workflow status badge), like the following:
The example workflows in .github/workflows specify
uses: ./
which calls the action code from the branch they are running in when the workflow is run directly in the repository here.
From another (external) repository, the production version of the action is called with
- uses: cypress-io/github-action@v6
To test out a branch in development calling it from another repository, replace v6
by the name of your branch. If your branch is in a fork, then also replace cypress-io
by your own GitHub username in the form:
- uses: <your-username>/github-action@<your-branch>
This information is for Cypress.io Members or Collaborators who merge pull requests:
-
When merging a pull request, use the Squash and merge option to squash all commits into one.
-
Make sure the commit subject and body follow semantic commit convention, for instance:
feat: added new parameter fix: fixed a bug
If you need to bump the major version, mark it as breaking change in the body of the commit's message like:
fix: upgrade dependency X BREAKING CHANGE: requires minimum Node.js 18 to run
-
New versions of this action will be released automatically by the CI when merged to the
master
branch, see .github/workflows/main.yml. This will create a new GitHub release and will update the current highest branch from the seriesv5
,v6
, ... etc. Thus specifyinguses: cypress-io/github-action@v6
(or higher version if available) selects the new version automatically. This will not push the latest release to GitHub Marketplace. -
The action's CI is configured to use the default Angular release rules. This means that only
feat:
,fix:
andperf:
trigger a new release which is then logged to the releases page. Other Angular commit types listed on Contributing to Angular can be used for documentation purposes, however they are ignored by the currently configured release process.
Publishing a new release to the GitHub Marketplace is a manual process.
After a new release has been created, go to the release and click "Edit"
Review the release info, make sure the "publish ..." checkbox is checked
After clicking "Update the release" check that the Marketplace https://github.com/marketplace/actions/cypress-io has been updated.
See also Publishing actions in GitHub Marketplace.