Instruções para WebDriverJS e TypeScript
Configurando seus testes com WebDriverJS e TypeScript
-
No nível raiz da sua pasta de testes, instale o
@axe-core/watcherpacote e todas as suas dependências usandonpmou o seu gerenciador de pacotes preferido (por exemplo,yarnoupnpm).npm install --save-dev @axe-core/watcher -
No seu arquivo ou arquivos de teste, importe a função
webdriverConfig(), a funçãowrapWebdriver(), e a classeWebdriverControllerde@axe-core/watcher/webdriver:import { webdriverConfig, wrapWebdriver, WebdriverController } from '@axe-core/watcher/webdriver' -
Atualize o código de configuração do teste (tipicamente em um
beforeoubeforeAllbloco), especificando as opções do Chrome ao instanciar seubrowserinstância, fornecendo sua chave de API:// Original code: const browser = await new Builder() .forBrowser('chrome') .build() // Becomes: const ACCESSIBILITY_API_KEY = process.env.ACCESSIBILITY_API_KEY const PROJECT_ID = process.env.PROJECT_ID const browser = await new Builder() .forBrowser('chrome') .setChromeOptions( webdriverConfig({ axe: { apiKey: ACCESSIBILITY_API_KEY, projectId: PROJECT_ID } } ) .build()Certifique-se de definir
ACCESSIBILITY_API_KEYePROJECT_IDno seu ambiente como a sua chave de API pessoal (encontrada na sua conta do axe, na aba **API KEYS** ) e o seu ID de projeto (mostrado no topo destas instruções quando você criou seu projeto ou disponível na página de Projetos, escolhendo **Configurar projeto** em **Configurações**). -
Crie uma instância do
WebdriverController:const controller = new WebdriverController(browser) -
Envolva sua
browserinstância com a funçãowrapWebdriver():browser = wrapWebdriver(browser, controller) -
Finalmente, assegure-se de que todos os resultados dos testes do axe Watcher sejam processados. Para isso, adicione o seguinte bloco de código à sua rotina de desmontagem do teste (tipicamente em um bloco
afterEach):afterEach(async () => { await controller.flush() })
