The Cypress rules run tests under the Cypress e2e testing framework with Bazel.
Add @bazel/cypress
and cypress
npm packages to your devDependencies
in package.json
.
npm install --save-dev @bazel/cypress cypress
or using yarn
yarn add -D @bazel/cypress cypress
Then, load and invoke cypress_repository
within your WORKSPACE
file.
# Assuming your external repository for node_modules is named @npm load("@npm//@bazel/cypress:index.bzl", "cypress_repository") # The name you pass here names the external repository you can load cypress_web_test from cypress_repository(name = "cypress")
On macOS, cypress_repository
generates an external repository containing files whose names contain spaces. In order to make these files compatible with bazel you will need to add the following flag to your .bazelrc
file:
# Required for cypress_repository on macOS build --experimental_inprocess_symlink_creation
At this point in time, cypress_repository
is incompatible with bazel sandboxing on Windows. This may change in the future, but for now using cypress on windows requires windows sandboxing be disabled (it is disabled by default)
This example assumes you've named your external repository for node_modules as npm
and for cypress as cypress
load("@cypress//:index.bzl", "cypress_web_test") load("@npm//@bazel/typescript:index.bzl", "ts_library") # You must create a cypress plugin in order to boot a server to serve your application. It can be written as a javascript file or in typescript using ts_library or ts_project. ts_library( name = "plugins_file", testonly = True, srcs = ["plugin.ts"], tsconfig = ":tsconfig.json", deps = [ "@npm//@types/node", "@npm//express", ], ) # You can write your cypress tests a javascript files or in typescript using ts_library or ts_project. ts_library( name = "hello_spec", testonly = True, srcs = ["hello.spec.ts"], tsconfig = ":tsconfig.json", deps = [ "@npm//cypress", ], ) cypress_web_test( # The name of your test target name = "test", srcs = [ # Load javascript test files directly as sources "world.spec.js", # Load ts_library tests as a target to srcs ":hello_spec", ], # A cypress config file is required config_file = "cypress.json", # Any runtime dependencies you need to boot your server or run your tests data = [], # Your cypress plugin used to configure cypress and boot your server plugins_file = ":plugins_file", )
USAGE
ATTRIBUTES
(Name, mandatory): A unique name for this repository.
(Label): bazel target of the cypress binary
Defaults to @npm//:node_modules/cypress/bin/cypress
(Boolean): If the repository rule should allow errors
Defaults to True
(Boolean): If stdout and stderr should be printed to the terminal
Defaults to True
(Dictionary: String -> String, mandatory): A dictionary from local repository name to global repository name. This allows controls over workspace dependency resolution for dependencies of this repository.For example, an entry "@foo": "@bar"
declares that, for any time this repository depends on @foo
(such as a dependency on @foo//some:target
, it should actually resolve that dependency within globally-declared @bar
(@bar//some:target
).