Skip to main content

Step Types

Prowl QA supports 19 step types. Most have both a shorthand form (concise, readable) and an explicit form (full control over selectors).

Navigate to a URL (relative to your target.url or absolute).

- navigate: "/"
- navigate: "/login"
- navigate: "https://example.com/page"

click

Click an element. Shorthand finds buttons by text, then falls back to any matching text.

# Finds by button role, then text
- click: "Sign In"
note

Shorthand click uses substring matching on button names. click: "Save" will match a button labeled "Save & New". For exact matching, use click: { selector: 'button:text-is("Save")' }.

fill

Fill an input field. Shorthand finds inputs by label or placeholder text.

# Finds by label, then placeholder
- fill:
"Email": "user@example.com"

type

Type into the currently focused element. Useful after clicking into a field.

- click: "Message"
- type: "Hello, I have a question."

press

Press a keyboard key on a specific element.

- press:
selector: "input[name='search']"
key: "Enter"

select / selectOption

Select a dropdown value. Shorthand finds by label, explicit uses a selector.

# Finds <select> by label, aria-label, or placeholder
- select:
"State": "FL"

assert

Mid-flow assertions. Fails the hunt immediately if the assertion fails.

- assert:
visible: "Welcome back"

- assert:
notVisible: "Error"

- assert:
urlIncludes: "/dashboard"

- assert:
urlEquals: "https://example.com/dashboard"

See the Assertions page for the full reference.

wait

Wait for text to appear on the page.

# Wait for text with default timeout
- wait: "Loading complete"
note

wait uses exact text matching (text="X"). It won't match substrings. For substring matching, use waitForSelector with text=X (without quotes).

waitForSelector

Wait for any Playwright selector to appear.

- waitForSelector:
selector: "[data-testid='results-table']"
timeout: 5000

waitForUrl

Wait for the URL to contain a substring.

- waitForUrl:
value: "/dashboard"
timeout: 10000

waitForNetworkIdle

Wait for all network requests to complete.

- waitForNetworkIdle:
timeout: 5000

onDialog

Handle browser-native dialogs (alert, confirm, prompt). Register the handler before the action that triggers the dialog.

- onDialog:
action: accept # or "dismiss"
- click: "Delete" # this triggers the confirm dialog

setInputFiles

Set files on <input type="file"> elements. Paths are relative to .prowlqa/.

# Single file
- setInputFiles:
selector: "[data-testid='avatar-upload']"
files: "fixtures/avatar.png"

# Multiple files
- setInputFiles:
selector: "[data-testid='attachments']"
files:
- "fixtures/doc1.pdf"
- "fixtures/doc2.pdf"

runHunt

Execute another hunt file inline. Enables reusable sub-flows like login.

# Run the hunt as-is
- runHunt: "login-flow"

Circular dependencies are detected automatically (A → B → A will error).

screenshot

Capture a screenshot at any point.

- screenshot:
name: "after-login"

hover

Hover over an element. Useful for triggering tooltips, dropdown menus, or hover states. Explicit-only — requires a selector.

- hover:
selector: "[data-testid='user-menu']"
- hover:
selector: "text=Profile"

scroll

Scroll the page by direction and optional pixel amount.

# Scroll down (default amount)
- scroll:
direction: "down"

# Scroll up by 300px
- scroll:
direction: "up"
amount: 300

scrollTo

Scroll to a specific element on the page. Explicit-only — requires a selector.

- scrollTo:
selector: "[data-testid='pricing-section']"
- scrollTo:
selector: "text=Footer"

Shorthand vs Explicit Quick Reference

ShorthandExplicit Equivalent
click: "Sign In"click: { selector: 'button:has-text("Sign In")' }
fill: { "Email": "val" }fill: { selector: 'input[placeholder="Email"]', value: "val" }
type: "text"fill: { selector: ':focus', value: "text" }
select: { "State": "FL" }selectOption: { selector: 'select[name="state"]', value: "FL" }
wait: "Welcome"waitForSelector: { selector: 'text="Welcome"' }
runHunt: "login"runHunt: { name: "login" }