Instruções para Puppeteer e TypeScript
Configurando seus testes com Puppeteer 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
puppeteerConfig()função, awrapPuppeteer()função e aPuppeteerControllerclasse de@axe-core/watcher/puppeteer:import { puppeteerConfig, wrapPuppeteerPage, PuppeteerController } from '@axe-core/watcher/puppeteer' -
Atualize o código de configuração do seu teste (normalmente em um
beforeoubeforeAllbloco) envolvendo qualquer código existente para criar umabrowserinstância com uma chamada parapuppeteerConfig(), enquanto obtém sua chave de API do ambiente (comoACCESSIBILITY_API_KEY):// Original code: browser = await puppeteer.launch({ // Your existing launch options... }) // Becomes: const ACCESSIBILITY_API_KEY = process.env.ACCESSIBILITY_API_KEY const PROJECT_ID = process.env.PROJECT_ID const browser = await puppeteer.launch( puppeteerConfig({ axe: { apiKey: ACCESSIBILITY_API_KEY, projectId: PROJECT_ID }, headless: false }) );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 de
PuppeteerControllere envolva seu PuppeteerbrowserContext:// Create a page instance, using your browser instance. let page = await browser.newPage() // Initialize the PuppeteerController by passing in the Puppeteer page. const controller = new PuppeteerController(page) // Use the new wrapped Puppeteer page instance. page = wrapPuppeteerPage(page, controller) -
Finalmente, certifique-se de que todos os resultados dos testes do axe Watcher sejam liberados. Para fazer isso, adicione o seguinte bloco de código ao seu código de finalização de teste (normalmente em um
afterEachbloco):afterEach(async () => { await controller.flush() });
