Skip to content

Latest commit

 

History

History
202 lines (159 loc) · 11.3 KB

DEPLOY.md

File metadata and controls

202 lines (159 loc) · 11.3 KB

Deployment

Anyone can build the binary and NPM package, but you can only deploy the Cypress application and publish the NPM module cypress if you are a member of the cypress NPM organization.

ℹ️ See the publishing section for how to build, test and publish a new official version of the binary and cypress NPM package.

Set next version on CIs

We build the NPM package and binary on all major platforms (Linux, Mac, Windows) on different CI providers. In order to set the version while building we have to set the environment variable with the new version on each CI provider before starting the build.

Use script command yarn set-next-ci-version to do this.

Building

Building the NPM package

⚠️ Note: The steps in this section are automated in CI, and you should not generally need to do them yourself.

Building a new NPM package is very quick.

  • Increment the version in the root package.json
  • yarn build --scope cypress

The steps above:

  • Build the cypress NPM package
  • Transpile the code into ES5 to be compatible with the common Node versions
  • Put the result into the cli/build folder.

You could publish from there, but first you need to build and upload the binary with the same version; this guarantees that when users do npm i cypress@<x.y.z> they can download the binary with the same version x.y.z from Cypress's CDN service.

Building the binary

⚠️ Note: The steps in this section are automated in CI, and you should not generally need to do them yourself.

First, you need to build, zip and upload the application binary to the Cypress server.

You can use a single command to do all tasks at once:

yarn binary-deploy

Or you can specify each command separately:

yarn binary-build
yarn binary-zip
yarn binary-upload

You can pass options to each command to avoid answering questions, for example

yarn binary-deploy --platform darwin --version 0.20.0
yarn binary-upload --platform darwin --version 0.20.0 --zip cypress.zip

If something goes wrong, see the debug messages using the DEBUG=cypress:binary ... environment variable.

Because we had many problems reliably zipping the built binary, for now we need to build both the Mac and Linux binary from Mac (Linux binary is built using a Docker container), then zip it from Mac, then upload it.

Building Linux binary in Docker

If you are using a Mac you can build the linux binary if you have docker installed.

yarn binary-build-linux

Publishing

Before Publishing a New Version

In order to publish a new cypress package to the NPM registry, we must build and test it across multiple platforms and test projects. This makes publishing directly into the NPM registry impossible. Instead, we have CI set up to do the following on every commit to develop:

  1. Build the NPM package with the new target version baked in.
  2. Build the Linux/Mac binaries on CircleCI and build Windows on AppVeyor.
  3. Upload the binaries and the new NPM package to cdn.cypress.io under the "beta" folder.
  4. Launch the test projects like cypress-test-node-versions and cypress-test-example-repos using the newly-uploaded package & binary instead of installing from the NPM registry. That installation looks like this:
    export CYPRESS_INSTALL_BINARY=https://cdn.../binary/<new version>/<commit hash>/cypress.zip
    npm i https://cdn.../npm/<new version>/<commit hash>/cypress.tgz

Multiple test projects are launched for each target operating system and the results are reported back to GitHub using status checks so that you can see if a change has broken real-world usage of Cypress. You can see the progress of the test projects by opening the status checks on GitHub:

Screenshot of status checks

Once the develop branch for all test projects are reliably passing with the new changes, publishing can proceed.

Steps to Publish a New Version

In the following instructions, "X.Y.Z" is used to denote the version of Cypress being published.

  1. Make sure that if there is a new cypress-example-kitchensink version, the corresponding dependency in packages/example has been updated to that new version.

  2. Make sure that you have the correct environment variables set up before proceeding.

    • You'll need Cypress AWS access keys in aws_credentials_json, which looks like this:
      aws_credentials_json={"bucket":"cdn.cypress.io","folder":"desktop","key":"...","secret":"..."}
      
    • You'll need a GitHub token, a CircleCI token, and a cypress-io account-specific AppVeyor token in ci_json:
      ci_json={"githubToken":"...","circleToken":"...","appVeyorToken":"..."}
      
    • Tip: Use as-a to manage environment variables for different situations.
  3. Use the move-binaries script to move the binaries for <commit sha> from beta to the desktop folder for <new target version>

    yarn move-binaries --sha <commit sha> --version <new target version>
  4. Publish the new NPM package under the dev tag. The unique link to the package file cypress.tgz is the one already tested above. You can publish to the NPM registry straight from the URL:

    yarn publish https://cdn.../npm/X.Y.Z/<long sha>/cypress.tgz --tag dev
  5. Double-check that the new version has been published under the dev tag using npm info cypress or available-versions. Example output:

    dist-tags:
    dev: 3.4.0     latest: 3.3.2
  6. Test [email protected] again to make sure everything is working. You can trigger test projects from the command line (if you have the appropriate permissions)

    node scripts/test-other-projects.js --npm [email protected] --binary X.Y.Z
    
  7. Test the new version of Cypress against the Cypress dashboard repo.

  8. Update and publish the changelog and any release-specific documentation changes in cypress-documentation.

  9. Make the new NPM version the "latest" version by updating the dist-tag latest to point to the new version:

    yarn dist-tag add [email protected]
  10. Run binary-release to update the download server's manifest, set the next CI version, and create an empty version commit:

    yarn run binary-release --version X.Y.Z --commit
  11. If needed, push out any updated changes to the links manifest to on.cypress.io.

  12. If needed, deploy the updated cypress-example-kitchensink to example.cypress.io by following these instructions under "Deployment".

  13. Update the releases in ZenHub:

    • Close the current release in ZenHub.
    • Create a new patch release (and a new minor release, if this is a minor release) in ZenHub, and schedule them both to be completed 2 weeks from the current date.
    • Move all issues that are still open from the current release to the appropriate future release.
  14. Bump version in package.json and commit it to develop using a commit message like release X.Y.Z [skip ci]

  15. Tag this commit with vX.Y.Z and push that tag up.

  16. Merge develop into master and push that branch up.

  17. Inside of cypress-io/release-automations:

    • Publish GitHub release to cypress-io/cypress/releases using package set-releases:
      cd set-releases && npm run release-log -- --version X.Y.Z
    • Add a comment to each GH issue that has been resolved with the new published version using package issues-in-release:
      cd issues-in-release && npm run do:comment -- --release X.Y.Z
  18. Publish a new docker image in cypress-docker-images under included for the new cypress version.

  19. Decide on the next version that we will work on. For example, if we have just released 3.7.0 we probably will work on 3.7.1 next. Set it on CI machines.

  20. Try updating as many example projects to the new version. You probably want to update by using Renovate dependency issue like cypress-example-todomvc "Update Dependencies (Renovate Bot). Try updating at least the following projects:

  21. Check if any test or example repositories have a branch for testing the features or fixes from the newly published version x.y.z. The branch should also be named x.y.z. Check all cypress-test-* and cypress-example-* repositories, and if there is a branch named x.y.z, merge it into master.

    Test Repos

    Example Repos

Take a break, you deserve it! 😎