jamesgeorge007 / qawolf

🐺 Record browser tests with one command

Home Page:https://docs.qawolf.com

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

QA Wolf

Create browser tests 10x faster

Free and open source library to create Playwright/Jest browser tests and run them in CI

tweet npm version

πŸš€ Get Started | πŸ“– API | πŸ‘‹ Chat | πŸ—ΊοΈ Roadmap


🐺 What is QA Wolf?

QA Wolf is a Node.js library for creating browser tests. Run one command (npm init qawolf@latest or yarn create qawolf) to configure your project and set up CI.

  • Skip writing boilerplate: Your browser actions are converted to Playwright/Jest code.
  • Create stable tests: Your tests automatically wait for elements. Element selectors use test attributes when possible, and CSS/text otherwise.
  • Edit your tests: Edit your code as it is created and add steps to existing tests. Re-run your tests automatically with watch mode.
  • Run tests in CI: A workflow file for your CI provider is automatically created for you.
  • Debug with ease: Each test run includes a video and browser logs.

πŸ–₯️ Install

Documentation


Set up your project for browser tests:

cd /my/awesome/project
npm init qawolf@latest
# or yarn create qawolf

Configure your test directory and CI provider:

? rootDir: Directory to create tests in (.qawolf)

? Set up CI with GitHub Actions? (y/N)

This will install qawolf, jest and playwright as dev dependencies and create a CI workflow file to:

  • 🐎 Run tests in parallel
  • πŸ“Ή Record a video of each test
  • πŸ“„ Capture browser logs

🎨 Create a test

Documentation


npx qawolf create [url] [name]

πŸ’ͺ Convert your actions into Playwright code:

Action Status Example
Click βœ… page.click('#login')
Type βœ… page.fill('.username', 'spirit@qawolf.com')
Scroll βœ… qawolf.scroll(page, 'html', { x: 0, y: 200 })
Select βœ… page.selectOption('.ice_cream', 'chocolate')
Paste βœ… page.fill('password', 'pasted')
Reload βœ… page.reload()
Replace text βœ… page.fill('.username', 'username')
Go back βœ… page.goBack()
Use iframes βœ… (await page.waitForSelector("#storybook-preview-iframe")).contentFrame()
Use multiple tabs βœ… context.newPage()
Use a popup βœ… qawolf.waitForPage(context, 1)
Use a test attribute βœ… page.click("[data-qa='submit']")
Use a test attribute on an ancestor βœ… page.click("[data-qa='radio'] [value='cat']")
Drag and drop πŸ—ΊοΈ Coming soon
File upload πŸ—ΊοΈ Coming soon

As your test is created:

  • ✏️ Edit the code as you like
  • πŸ–₯️ Use the REPL to try out commands

βœ… Run your tests

Documentation


On Chromium:

npx qawolf test [name]

On Firefox:

npx qawolf test --firefox [name]

On Webkit:

npx qawolf test --webkit [name]

On all browsers:

npx qawolf test --all-browsers [name]

πŸ™‹ Get help

We want QA Wolf to work for you, so please reach out to get help!

If you have a feature request or feedback, please open an issue or chat with us.


πŸ“ License

QA Wolf is licensed under BSD-3-Clause.

About

🐺 Record browser tests with one command

https://docs.qawolf.com

License:BSD 3-Clause "New" or "Revised" License


Languages

Language:TypeScript 71.6%Language:JavaScript 11.8%Language:HTML 9.9%Language:CSS 6.8%Language:Shell 0.0%