O que você vai aprender
- Como instalar Cypress usando `npm`
- Como instalar Cypress fazendo download a partir do repositório
- Como versionar e rodar Cypress usando `package.json`
Cypress é uma aplicação desktop instalada no seu computador. A aplicação desktop suporta os seguintes sistemas operacionais:
- macOS 10.9 e superior (somente 64-bit)
- Linux Ubuntu 12.04 e superior, Fedora 21 e Debian 8 (somente 64-bit)
- Windows 7 e superior
Se você está utilizando npm
para instalar o Cypress, nós suportamos:
- Node.js 12 ou 14 e superior
Se você estiver usando Linux, você precisará das dependências necessárias instaladas no seu sistema.
Nós também temos uma versão oficial cypress/base em container docker com todas as dependências necessárias instaladas.
apt-get install libgtk2.0-0 libgtk-3-0 libgbm-dev libnotify-dev libgconf-2-4 libnss3 libxss1 libasound2 libxtst6 xauth xvfb
yum install -y xorg-x11-server-Xvfb gtk2-devel gtk3-devel libnotify-devel GConf2 nss libXScrnSaver alsa-lib
Imagens do Docker com todas as dependências necessárias instaladas estão disponíveis em cypress/base
Se você estiver executando seus projetos em containers, você vai querer Cypress no container com o processo Node.js.
ui:
image: cypress/base:latest
# se tiver como alvo uma versão node específica, use e.g.
# image: cypress/base:14
cypress/base
é um substituto para imagens base do docker para node.
Instale o Cypress usando npm
:
cd /caminho/do/projeto
npm install cypress --save-dev
Isto vai instalar o Cypress localmente como uma dependência de desenvolvimento em seu projeto.
Certifique-se que você já rodou
npm init
, ou tenha o diretórionode_modules
, ou o arquivopackage.json
no diretório raiz do seu projeto para garantir que o cypress seja instalado no diretório correto.
Note que o pacote npm do cypress é um wrapper que envolve o binário do Cypress. A versão do pacote npm determina qual versão do binário será baixado. A partir da versão 3.0, o binário é baixado como um diretório de cache global para ser utilizado entre os projetos.
Boa prática
A abordagem recomendada é de instalar o Cypress usando o
npm
, pois: - O Cypress é versionado como qualquer outra dependência. - Isto simplifica rodar o Cypress na Integração Contínua.
Instalando o cypress usando o yarn
:
cd /caminho/do/projeto
yarn add cypress --dev
Se você não estiver utilizando Node ou npm no seu projeto, ou você quer tentar usar o Cypress rapidamente, você sempre poderá realizar o download do Cypress diretamente de nossa CDN.
A gravação de execuções para o Dashboard não é possível através do download direto. Este download tem somente a intenção de ser uma forma simples de experimentar com o Cypress. Para gravar os testes no Dashboard, você precisará instalar o Cypress como uma depedência npm.
O download direto sempre trará a última versão disponível. Sua plataforma será identificada automaticamente.
Você pode descompactar manualmente e clicar duas vezes. O Cypress será executado sem precisar instalar nenhuma dependência.
Download direto para versões antigas
É possível baixar uma versão antiga do nosso CDN adicionando o sufixo ao URL com a versão desejada (ex. https://download.cypress.io/desktop/6.8.0).
Por favor leia nossa documentação sobre Integração Contínua para ajudar na instalação do Cypress na CI (Integração Contínua). Quando estiver rodando linux você precisará instalar algumas dependências de sistema ou você pode usar a nossa imagem docker que possui tudo que você precisa.
Se você usou npm
para instalação, o Cypress foi instalado
no diretório ./node_modules
, com seus binários executáveis accessíveis
em ./node_modules/.bin
.
Agora você pode abrir o Cypress do seu projeto principal de uma das seguintes formas:
A forma longa com o caminho completo
./node_modules/.bin/cypress open
Ou com o atalho usando npm bin
$(npm bin)/cypress open
Ou usando o npx
Obs.: o npx é incluido no npm > v5.2, ou pode ser instalado separadamente.
npx cypress open
Após um momento, o Cypress Test Runner será aberto.
O Cypress Test Runner tenta encontrar todos os navegadores compatíveis na máquina do usuário. O campo de seleção suspenso para selecionar um navegador diferente pode ser encontrado no topo lateral direito do Test Runner.
Leia Abrindo navegadores para mais informações sobre como o Cypress controla um navegador real durante os testes de ponta-a-ponta.
Suporte entre navegadores
O Cypress atualmente suporta o Firefox e navegadores da família Chrome (incluindo Edge e Electron). Para executar testes de maneira otimizada nesses navegadores na integração contínua, confira as estratégias demonstradas no guia de teste entre navegadores.
Embora não haja nada de errado em escrever o caminho completo para o
executável do Cypress a cada momento, é muito mais fácil e claro adicionar
os comandos do Cypress ao campo de scripts em seu arquivo package.json
.
{
"scripts": {
"cypress:open": "cypress open"
}
}
Agora você pode chamar o comando a partir da raiz do projeto, dessa forma:
npm run cypress:open
… e o Cypress irá abrir direto para você.
Instalando Cypress pela npm
você também pode acessar vários comandos CLI.
A partir da versão 0.20.0, o Cypress também é um node_module
totalmente
preparado que você pode exigir em seus scripts do Node.
Você pode ler mais sobre CLI aqui.
Nome | Descrição |
---|---|
CYPRESS_INSTALL_BINARY |
Destino do binário Cypress baixado e instalado |
CYPRESS_DOWNLOAD_MIRROR |
Baixa o binário Cypress através de um servidor espelho |
CYPRESS_CACHE_FOLDER |
Altera o caminho do cache binário do Cypress |
CYPRESS_RUN_BINARY |
Caminho do binário do Cypress em tempo de execução |
use CYPRESS_INSTALL_BINARY=0 |
|
use CYPRESS_INSTALL_BINARY |
Usando a variável de ambiente CYPRESS_INSTALL_BINARY
, você pode controlar
como o Cypress é instalado. Para sobrescrever o que foi instalado,
você seta CYPRESS_INSTALL_BINARY
junto com o comando npm install
.
Isso é útil se você deseja:
- Instalar uma versão diferente do pacote npm padrão.
CYPRESS_INSTALL_BINARY=2.0.1 npm install cypress@2.0.3
Especificar uma URL externa (para contornar um firewall corporativo).
CYPRESS_INSTALL_BINARY=https://company.domain.com/cypress.zip npm install cypress
Especificar um arquivo para instalar localmente ao invés de usar pela internet.
CYPRESS_INSTALL_BINARY=/local/path/to/cypress.zip npm install cypress
Em todos os casos, o fato do binário ter sido instalado a partir de um local
personalizado não é salvo no arquivo package.json
. Cada instalação repetida
precisa usar a mesma variável de ambiente para instalar o mesmo binário.
Você também pode forçar o Cypress a pular a instalação da aplicação binária
definindo CYPRESS_INSTALL_BINARY = 0
. Isso pode ser útil se você quiser
evitar que o Cypress baixe o binário do Cypress no momento da instalação
do npm install
.
CYPRESS_INSTALL_BINARY=0 npm install
Agora o Cypress irá pular as etapas de instalação já que o módulo npm
está instalado.
A partir da versão 3.0, o Cypress baixa o seu binário correspondente para o cache do sistema global, para que o binário possa ser compartilhado entre projetos. Por padrão, as pastas de cache globais são:
- MacOS: ~/Library/Caches/Cypress
- Linux: ~/.cache/Cypress
- Windows: /AppData/Local/Cypress/Cache
Para sobrescrever a pasta de cache padrão, defina a variável
de ambiente CYPRESS_CACHE_FOLDER
.
CYPRESS_CACHE_FOLDER=~/Desktop/cypress_cache npm install
CYPRESS_CACHE_FOLDER=~/Desktop/cypress_cache npm run test
Cypress substituirá automaticamente o ~
pelo diretório inicial do usuário.
Portanto, você pode passar CYPRESS_CACHE_FOLDER
como uma string de arquivos
de configuração CI, por exemplo:
environment:
CYPRESS_CACHE_FOLDER: '~/.cache/Cypress'
Veja mais a seção Integração Contínua - Caching na documentação.
CYPRESS_CACHE_FOLDER
precisará existir toda vez que o Cypress for aberto. Para garantir isso, considere exportar essa variável de ambiente. Por exemplo, em um.bash_profile
(MacOS, Linux), ou usandoRegEdit
(Windows).
Setando a variável de ambiente CYPRESS_RUN_BINARY
sobrescreverá onde o módulo
npm procura pelo binário do Cypress.
CYPRESS_RUN_BINARY
deve ser um caminho para o executável binário
já descompactado. Os comandos Cypress abertos, executados e verificados
iniciarão o binário fornecido.
CYPRESS_RUN_BINARY=~/Downloads/Cypress.app/Contents/MacOS/Cypress cypress run
CYPRESS_RUN_BINARY=~/Downloads/Cypress/Cypress cypress run
CYPRESS_RUN_BINARY=~/Downloads/Cypress/Cypress.exe cypress run
Recomendamos não exportar a variável de ambiente
CYPRESS_RUN_BINARY
, uma vez que afetará todos os módulos Cypress instalados em seu sistema de arquivos.
Se você deseja baixar uma versão específica do Cypress para uma determinada plataforma (Sistema Operacional), pode obtê-la em nosso CDN.
O URL do servidor de download é https://download.cypress.io
.
Atualmente, temos os seguintes downloads disponíveis:
- Windows 64-bit (?platform=win32&arch=x64)
- Windows 32-bit (?platform=win32&arch=ia32, available since Cypress 3.3.0)
- Linux 64-bit (?platform=linux)
- macOS 64-bit (?platform=darwin)
Aqui estão os URLs de download disponíveis:
Veja https://download.cypress.io/desktop.json para todas plataformas disponíveis.
Método | URL | Descrição |
---|---|---|
GET | /desktop | Baixe o Cypress na versão mais recente (plataforma detectada automaticamente) |
GET | /desktop.json | Retorna JSON contendo os destinos CDN mais recentes disponíveis |
GET | /desktop?platform=p&arch=a | Baixe o Cypress para uma plataforma e / ou arquitetura específica |
GET | /desktop/:version | Baixa o Cypress com uma versão especificada |
GET | /desktop/:version?platform=p&arch=a | Baixa o Cypress com uma versão e plataforma e/ou arquitetura especificadas |
Exemplo de download do Cypress 3.0.0 para Windows de 64-bits:
https://download.cypress.io/desktop/3.0.0?platform=win32&arch=x64
Se você escolher espelhar todo o site de download do Cypress, pode especificar
CYPRESS_DOWNLOAD_MIRROR
para definir a URL do servidor de download a partir
de https://download.cypress.io para seu próprio espelhamento.
Por exemplo:
CYPRESS_DOWNLOAD_MIRROR="https://www.example.com" cypress install
O Cypress tentará fazer o download de um binário com este formato: https://www.example.com/desktop/:version?platform=p
Quando uma exceção é lançada em relação ao Cypress, enviamos os dados da exceção para https://api.cypress.io. Só usamos essas informações para ajudar a desenvolver um produto melhor.
Se você quiser cancelar o envio de quaisquer dados de exceção para o Cypress,
você pode fazer isso definindo CYPRESS_CRASH_REPORTS = 0
em suas variáveis
de ambiente do sistema.
Para cancelar o envio de dados de exceção no Linux ou macOS, execute o seguinte comando em um terminal antes de instalar o Cypress:
export CYPRESS_CRASH_REPORTS=0
Para tornar essas mudanças permanentes, você pode adicionar este comando ao
~/.profile (~/.zsh_profile, ~/.bash_profile, etc.)
do seu shell para
executá-los em cada login.
Para cancelar o envio de dados de exceção no Windows, execute o seguinte comando no prompt de comando antes de instalar o Cypress:
set CYPRESS_CRASH_REPORTS=0
Para realizar a mesma coisa no Powershell:
$env:CYPRESS_CRASH_REPORTS = "0"
Para salvar a variável CYPRESS_CRASH_REPORTS
para uso em todos os
novos shells, use setx
:
setx CYPRESS_CRASH_REPORTS 0
Se você deseja instalar uma versão de pré-lançamento do Test Runner para testar uma funcionalidade que ainda não foi lançada, veja como:
-
Abra a lista de commits para desenvolver no repo Cypress:
https://github.com/cypress-io/cypress/commits/develop -
Encontre o commit o qual você gostaria de instalar a versão de pré-lançamento.
Clique no ícone de comentário (destacado em vermelho abaixo): -
Você deve ver vários comentários do usuário cypress-bot com instruções para instalar
os pré-lançamentos do Cypress. Escolha aquele que corresponde ao seu sistema operacional e
arquitetura de CPU, e siga as instruções para instalar o pré-lançamento.
Notas sobre pré-lançamentos:
-
Os pré-lançamentos do Cypress só estão disponíveis por cerca de um mês após serem construídos. Não confie que estes estejam disponíveis há mais de um mês.
-
Se você já tem um pré-lançamento ou lançamento oficial instalado para uma versão específica do Cypress, pode ser necessário rodar
cypress cache clear
antes que o Cypress instale um pré-lançamento. Isso também se aplica à instalação de um lançamento oficial sobre um pré-lançamento - se você tiver um pré-lançamento do Cypress vX.Y.Z instalado, o lançamento oficial do Cypress vX.Y.Z não será instalado até você limpar o cache do Cypress.