1.1.2 β€’ Published 4 years ago

qauto v1.1.2

Weekly downloads
2
License
BSD-3-Clause
Repository
github
Last release
4 years ago

🐺 What is QA Wolf?

QA Wolf is a Node.js library for creating browser tests. Run one command (npx qawolf init) 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
# or yarn create qawolf

Configure your test directory and CI provider:

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

? Choose CI Provider (Use arrow keys)
  Azure DevOps
  Bitbucket Pipelines
  CircleCI
❯ GitHub Actions
  GitLab CI/CD
  Jenkins
  Skip CI setup

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:

ActionStatusExample
Clickβœ…page.click(selectors['0_submit'])
Typeβœ…page.type(selectors['0_username'], 'username')
Scrollβœ…qawolf.scroll(page, 'html', { x: 0, y: 200 })
Selectβœ…page.selectOption(selectors['0_ice_cream'], 'chocolate')
Replace textβœ…page.fill(selectors['0_username'], 'username')
Go backβœ…page.goBack()
Go forwardβœ…page.goForward()
Go toβœ…page.goTo(url)
Go toβœ…page.goTo(url)
Add jest stepβœ…it(name, async()=>{})
Pasteβœ…page.type(selectors['password'], 'pasted')
Use a test attributeβœ…page.click("[data-qa='submit']")
Use a test attribute on an ancestorβœ…page.click("[data-qa='radio'] [value='cat']")
Use multiple pages/tabsβœ…qawolf.waitForPage(page.context(), 1)
IframesπŸ—ΊοΈComing soon
Drag and dropπŸ—ΊοΈComing soon
File uploadπŸ—ΊοΈComing soon
Back buttonπŸ—ΊοΈ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.