prose-qa 0.2.0 → 0.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (123) hide show
  1. package/dist/agent/bash.d.ts +1 -1
  2. package/dist/agent/bash.d.ts.map +1 -1
  3. package/dist/agent/bash.js +23 -4
  4. package/dist/agent/bash.js.map +1 -1
  5. package/dist/agent/bash.test.js +27 -3
  6. package/dist/agent/bash.test.js.map +1 -1
  7. package/dist/agent/prompt.d.ts.map +1 -1
  8. package/dist/agent/prompt.js +9 -1
  9. package/dist/agent/prompt.js.map +1 -1
  10. package/dist/agent/runner.d.ts.map +1 -1
  11. package/dist/agent/runner.js +80 -12
  12. package/dist/agent/runner.js.map +1 -1
  13. package/dist/agent/runner.test.d.ts +2 -0
  14. package/dist/agent/runner.test.d.ts.map +1 -0
  15. package/dist/agent/runner.test.js +83 -0
  16. package/dist/agent/runner.test.js.map +1 -0
  17. package/dist/agent/transcript-persist.d.ts +9 -0
  18. package/dist/agent/transcript-persist.d.ts.map +1 -0
  19. package/dist/agent/transcript-persist.js +6 -0
  20. package/dist/agent/transcript-persist.js.map +1 -0
  21. package/dist/agent/transcript-persist.test.d.ts +2 -0
  22. package/dist/agent/transcript-persist.test.d.ts.map +1 -0
  23. package/dist/agent/transcript-persist.test.js +56 -0
  24. package/dist/agent/transcript-persist.test.js.map +1 -0
  25. package/dist/agent/verdict.d.ts +8 -2
  26. package/dist/agent/verdict.d.ts.map +1 -1
  27. package/dist/agent/verdict.js +49 -0
  28. package/dist/agent/verdict.js.map +1 -1
  29. package/dist/agent/verdict.test.js +85 -1
  30. package/dist/agent/verdict.test.js.map +1 -1
  31. package/dist/cli/help.d.ts.map +1 -1
  32. package/dist/cli/help.js +53 -17
  33. package/dist/cli/help.js.map +1 -1
  34. package/dist/cli/help.test.js +1 -0
  35. package/dist/cli/help.test.js.map +1 -1
  36. package/dist/cli/index.js +18 -1
  37. package/dist/cli/index.js.map +1 -1
  38. package/dist/cli/install-browser.d.ts +3 -0
  39. package/dist/cli/install-browser.d.ts.map +1 -0
  40. package/dist/cli/install-browser.js +42 -0
  41. package/dist/cli/install-browser.js.map +1 -0
  42. package/dist/cli/install-browser.test.d.ts +2 -0
  43. package/dist/cli/install-browser.test.d.ts.map +1 -0
  44. package/dist/cli/install-browser.test.js +19 -0
  45. package/dist/cli/install-browser.test.js.map +1 -0
  46. package/dist/cli/run.d.ts.map +1 -1
  47. package/dist/cli/run.js +20 -15
  48. package/dist/cli/run.js.map +1 -1
  49. package/dist/config/lightpanda.d.ts +8 -0
  50. package/dist/config/lightpanda.d.ts.map +1 -1
  51. package/dist/config/lightpanda.js +41 -4
  52. package/dist/config/lightpanda.js.map +1 -1
  53. package/dist/config/lightpanda.test.js +30 -1
  54. package/dist/config/lightpanda.test.js.map +1 -1
  55. package/dist/config/load.d.ts.map +1 -1
  56. package/dist/config/load.js +14 -6
  57. package/dist/config/load.js.map +1 -1
  58. package/dist/config/load.test.js +29 -0
  59. package/dist/config/load.test.js.map +1 -1
  60. package/dist/mcp/server.d.ts.map +1 -1
  61. package/dist/mcp/server.js +2 -1
  62. package/dist/mcp/server.js.map +1 -1
  63. package/dist/redact/env-secrets.d.ts.map +1 -1
  64. package/dist/redact/env-secrets.js +1 -0
  65. package/dist/redact/env-secrets.js.map +1 -1
  66. package/dist/reporter/index.d.ts.map +1 -1
  67. package/dist/reporter/index.js +6 -2
  68. package/dist/reporter/index.js.map +1 -1
  69. package/dist/reporter/index.test.js +59 -1
  70. package/dist/reporter/index.test.js.map +1 -1
  71. package/dist/skills/loader.d.ts +8 -1
  72. package/dist/skills/loader.d.ts.map +1 -1
  73. package/dist/skills/loader.js +31 -5
  74. package/dist/skills/loader.js.map +1 -1
  75. package/dist/skills/loader.test.d.ts +2 -0
  76. package/dist/skills/loader.test.d.ts.map +1 -0
  77. package/dist/skills/loader.test.js +40 -0
  78. package/dist/skills/loader.test.js.map +1 -0
  79. package/dist/skills/on-demand.d.ts +57 -0
  80. package/dist/skills/on-demand.d.ts.map +1 -0
  81. package/dist/skills/on-demand.js +225 -0
  82. package/dist/skills/on-demand.js.map +1 -0
  83. package/dist/skills/on-demand.test.d.ts +2 -0
  84. package/dist/skills/on-demand.test.d.ts.map +1 -0
  85. package/dist/skills/on-demand.test.js +111 -0
  86. package/dist/skills/on-demand.test.js.map +1 -0
  87. package/dist/types/config.d.ts +14 -3
  88. package/dist/types/config.d.ts.map +1 -1
  89. package/dist/types/verdict.d.ts +21 -1
  90. package/dist/types/verdict.d.ts.map +1 -1
  91. package/dist/types/verdict.js +16 -0
  92. package/dist/types/verdict.js.map +1 -1
  93. package/dist/version.d.ts +3 -0
  94. package/dist/version.d.ts.map +1 -0
  95. package/dist/version.js +6 -0
  96. package/dist/version.js.map +1 -0
  97. package/package.json +6 -4
  98. package/pqa.config.ts +8 -3
  99. package/prompt/SYSTEM.md +2 -1
  100. package/scripts/install-lightpanda.mjs +161 -0
  101. package/scripts/sync-skills.mjs +110 -0
  102. package/skills/agent-browser/SKILL.md +0 -1960
  103. package/skills/agent-browser/bundled/agentcore/SKILL.md +115 -0
  104. package/skills/agent-browser/bundled/dogfood/SKILL.md +220 -0
  105. package/skills/agent-browser/bundled/dogfood/references/issue-taxonomy.md +109 -0
  106. package/skills/agent-browser/bundled/dogfood/templates/dogfood-report-template.md +53 -0
  107. package/skills/agent-browser/bundled/electron/SKILL.md +236 -0
  108. package/skills/agent-browser/bundled/slack/SKILL.md +285 -0
  109. package/skills/agent-browser/bundled/slack/references/slack-tasks.md +348 -0
  110. package/skills/agent-browser/bundled/slack/templates/slack-report-template.md +163 -0
  111. package/skills/agent-browser/bundled/vercel-sandbox/SKILL.md +280 -0
  112. package/skills/agent-browser/manifest.json +42 -0
  113. package/skills/agent-browser/references/authentication.md +303 -0
  114. package/skills/agent-browser/references/commands.md +398 -0
  115. package/skills/agent-browser/references/profiling.md +120 -0
  116. package/skills/agent-browser/references/proxy-support.md +194 -0
  117. package/skills/agent-browser/references/session-management.md +193 -0
  118. package/skills/agent-browser/references/snapshot-refs.md +219 -0
  119. package/skills/agent-browser/references/trust-boundaries.md +89 -0
  120. package/skills/agent-browser/references/video-recording.md +175 -0
  121. package/skills/agent-browser/templates/authenticated-session.sh +105 -0
  122. package/skills/agent-browser/templates/capture-workflow.sh +69 -0
  123. package/skills/agent-browser/templates/form-automation.sh +62 -0
@@ -0,0 +1,175 @@
1
+ # Video Recording
2
+
3
+ Capture browser automation as video for debugging, documentation, or verification.
4
+
5
+ **Related**: [commands.md](commands.md) for full command reference, [SKILL.md](../SKILL.md) for quick start.
6
+
7
+ ## Contents
8
+
9
+ - [Basic Recording](#basic-recording)
10
+ - [Recording Commands](#recording-commands)
11
+ - [Use Cases](#use-cases)
12
+ - [Best Practices](#best-practices)
13
+ - [Output Format](#output-format)
14
+ - [Limitations](#limitations)
15
+
16
+ ## Basic Recording
17
+
18
+ ```bash
19
+ # Launch the browser, then start recording
20
+ agent-browser open https://example.com
21
+ agent-browser record start ./demo.webm
22
+
23
+ # Perform actions
24
+ agent-browser snapshot -i
25
+ agent-browser click @e1
26
+ agent-browser fill @e2 "test input"
27
+
28
+ # Stop and save
29
+ agent-browser record stop
30
+ ```
31
+
32
+ ## Recording Commands
33
+
34
+ ```bash
35
+ # Launch a session first
36
+ agent-browser open
37
+
38
+ # Start recording to file
39
+ agent-browser record start ./output.webm
40
+
41
+ # Stop current recording
42
+ agent-browser record stop
43
+
44
+ # Restart with new file (stops current + starts new)
45
+ agent-browser record restart ./take2.webm
46
+ ```
47
+
48
+ ## Use Cases
49
+
50
+ ### Debugging Failed Automation
51
+
52
+ ```bash
53
+ #!/bin/bash
54
+ # Record automation for debugging
55
+
56
+ # Run your automation
57
+ agent-browser open https://app.example.com
58
+ agent-browser record start ./debug-$(date +%Y%m%d-%H%M%S).webm
59
+ agent-browser snapshot -i
60
+ agent-browser click @e1 || {
61
+ echo "Click failed - check recording"
62
+ agent-browser record stop
63
+ exit 1
64
+ }
65
+
66
+ agent-browser record stop
67
+ ```
68
+
69
+ ### Documentation Generation
70
+
71
+ ```bash
72
+ #!/bin/bash
73
+ # Record workflow for documentation
74
+
75
+ agent-browser open https://app.example.com/login
76
+ agent-browser record start ./docs/how-to-login.webm
77
+ agent-browser wait 1000 # Pause for visibility
78
+
79
+ agent-browser snapshot -i
80
+ agent-browser fill @e1 "demo@example.com"
81
+ agent-browser wait 500
82
+
83
+ agent-browser fill @e2 "password"
84
+ agent-browser wait 500
85
+
86
+ agent-browser click @e3
87
+ agent-browser wait --load networkidle
88
+ agent-browser wait 1000 # Show result
89
+
90
+ agent-browser record stop
91
+ ```
92
+
93
+ ### CI/CD Test Evidence
94
+
95
+ ```bash
96
+ #!/bin/bash
97
+ # Record E2E test runs for CI artifacts
98
+
99
+ TEST_NAME="${1:-e2e-test}"
100
+ RECORDING_DIR="./test-recordings"
101
+ mkdir -p "$RECORDING_DIR"
102
+
103
+ agent-browser open
104
+ agent-browser record start "$RECORDING_DIR/$TEST_NAME-$(date +%s).webm"
105
+
106
+ # Run test
107
+ if run_e2e_test; then
108
+ echo "Test passed"
109
+ else
110
+ echo "Test failed - recording saved"
111
+ fi
112
+
113
+ agent-browser record stop
114
+ ```
115
+
116
+ ## Best Practices
117
+
118
+ ### 1. Add Pauses for Clarity
119
+
120
+ ```bash
121
+ # Slow down for human viewing
122
+ agent-browser click @e1
123
+ agent-browser wait 500 # Let viewer see result
124
+ ```
125
+
126
+ ### 2. Use Descriptive Filenames
127
+
128
+ ```bash
129
+ # Include context in filename
130
+ agent-browser record start ./recordings/login-flow-2024-01-15.webm
131
+ agent-browser record start ./recordings/checkout-test-run-42.webm
132
+ ```
133
+
134
+ ### 3. Handle Recording in Error Cases
135
+
136
+ ```bash
137
+ #!/bin/bash
138
+ set -e
139
+
140
+ cleanup() {
141
+ agent-browser record stop 2>/dev/null || true
142
+ agent-browser close 2>/dev/null || true
143
+ }
144
+ trap cleanup EXIT
145
+
146
+ agent-browser open
147
+ agent-browser record start ./automation.webm
148
+ # ... automation steps ...
149
+ ```
150
+
151
+ ### 4. Combine with Screenshots
152
+
153
+ ```bash
154
+ # Record video AND capture key frames
155
+ agent-browser open https://example.com
156
+ agent-browser record start ./flow.webm
157
+ agent-browser screenshot ./screenshots/step1-homepage.png
158
+
159
+ agent-browser click @e1
160
+ agent-browser screenshot ./screenshots/step2-after-click.png
161
+
162
+ agent-browser record stop
163
+ ```
164
+
165
+ ## Output Format
166
+
167
+ - Default format: WebM (VP8/VP9 codec)
168
+ - Compatible with all modern browsers and video players
169
+ - Compressed but high quality
170
+
171
+ ## Limitations
172
+
173
+ - Recording adds slight overhead to automation
174
+ - Large recordings can consume significant disk space
175
+ - Some headless environments may have codec limitations
@@ -0,0 +1,105 @@
1
+ #!/bin/bash
2
+ # Template: Authenticated Session Workflow
3
+ # Purpose: Login once, save state, reuse for subsequent runs
4
+ # Usage: ./authenticated-session.sh <login-url> [state-file]
5
+ #
6
+ # RECOMMENDED: Use the auth vault instead of this template:
7
+ # echo "<pass>" | agent-browser auth save myapp --url <login-url> --username <user> --password-stdin
8
+ # agent-browser auth login myapp
9
+ # The auth vault stores credentials securely and the LLM never sees passwords.
10
+ #
11
+ # Environment variables:
12
+ # APP_USERNAME - Login username/email
13
+ # APP_PASSWORD - Login password
14
+ #
15
+ # Two modes:
16
+ # 1. Discovery mode (default): Shows form structure so you can identify refs
17
+ # 2. Login mode: Performs actual login after you update the refs
18
+ #
19
+ # Setup steps:
20
+ # 1. Run once to see form structure (discovery mode)
21
+ # 2. Update refs in LOGIN FLOW section below
22
+ # 3. Set APP_USERNAME and APP_PASSWORD
23
+ # 4. Delete the DISCOVERY section
24
+
25
+ set -euo pipefail
26
+
27
+ LOGIN_URL="${1:?Usage: $0 <login-url> [state-file]}"
28
+ STATE_FILE="${2:-./auth-state.json}"
29
+
30
+ echo "Authentication workflow: $LOGIN_URL"
31
+
32
+ # ================================================================
33
+ # SAVED STATE: Skip login if valid saved state exists
34
+ # ================================================================
35
+ if [[ -f "$STATE_FILE" ]]; then
36
+ echo "Loading saved state from $STATE_FILE..."
37
+ if agent-browser --state "$STATE_FILE" open "$LOGIN_URL" 2>/dev/null; then
38
+ agent-browser wait --load networkidle
39
+
40
+ CURRENT_URL=$(agent-browser get url)
41
+ if [[ "$CURRENT_URL" != *"login"* ]] && [[ "$CURRENT_URL" != *"signin"* ]]; then
42
+ echo "Session restored successfully"
43
+ agent-browser snapshot -i
44
+ exit 0
45
+ fi
46
+ echo "Session expired, performing fresh login..."
47
+ agent-browser close 2>/dev/null || true
48
+ else
49
+ echo "Failed to load state, re-authenticating..."
50
+ fi
51
+ rm -f "$STATE_FILE"
52
+ fi
53
+
54
+ # ================================================================
55
+ # DISCOVERY MODE: Shows form structure (delete after setup)
56
+ # ================================================================
57
+ echo "Opening login page..."
58
+ agent-browser open "$LOGIN_URL"
59
+ agent-browser wait --load networkidle
60
+
61
+ echo ""
62
+ echo "Login form structure:"
63
+ echo "---"
64
+ agent-browser snapshot -i
65
+ echo "---"
66
+ echo ""
67
+ echo "Next steps:"
68
+ echo " 1. Note the refs: username=@e?, password=@e?, submit=@e?"
69
+ echo " 2. Update the LOGIN FLOW section below with your refs"
70
+ echo " 3. Set: export APP_USERNAME='...' APP_PASSWORD='...'"
71
+ echo " 4. Delete this DISCOVERY MODE section"
72
+ echo ""
73
+ agent-browser close
74
+ exit 0
75
+
76
+ # ================================================================
77
+ # LOGIN FLOW: Uncomment and customize after discovery
78
+ # ================================================================
79
+ # : "${APP_USERNAME:?Set APP_USERNAME environment variable}"
80
+ # : "${APP_PASSWORD:?Set APP_PASSWORD environment variable}"
81
+ #
82
+ # agent-browser open "$LOGIN_URL"
83
+ # agent-browser wait --load networkidle
84
+ # agent-browser snapshot -i
85
+ #
86
+ # # Fill credentials (update refs to match your form)
87
+ # agent-browser fill @e1 "$APP_USERNAME"
88
+ # agent-browser fill @e2 "$APP_PASSWORD"
89
+ # agent-browser click @e3
90
+ # agent-browser wait --load networkidle
91
+ #
92
+ # # Verify login succeeded
93
+ # FINAL_URL=$(agent-browser get url)
94
+ # if [[ "$FINAL_URL" == *"login"* ]] || [[ "$FINAL_URL" == *"signin"* ]]; then
95
+ # echo "Login failed - still on login page"
96
+ # agent-browser screenshot /tmp/login-failed.png
97
+ # agent-browser close
98
+ # exit 1
99
+ # fi
100
+ #
101
+ # # Save state for future runs
102
+ # echo "Saving state to $STATE_FILE"
103
+ # agent-browser state save "$STATE_FILE"
104
+ # echo "Login successful"
105
+ # agent-browser snapshot -i
@@ -0,0 +1,69 @@
1
+ #!/bin/bash
2
+ # Template: Content Capture Workflow
3
+ # Purpose: Extract content from web pages (text, screenshots, PDF)
4
+ # Usage: ./capture-workflow.sh <url> [output-dir]
5
+ #
6
+ # Outputs:
7
+ # - page-full.png: Full page screenshot
8
+ # - page-structure.txt: Page element structure with refs
9
+ # - page-text.txt: All text content
10
+ # - page.pdf: PDF version
11
+ #
12
+ # Optional: Load auth state for protected pages
13
+
14
+ set -euo pipefail
15
+
16
+ TARGET_URL="${1:?Usage: $0 <url> [output-dir]}"
17
+ OUTPUT_DIR="${2:-.}"
18
+
19
+ echo "Capturing: $TARGET_URL"
20
+ mkdir -p "$OUTPUT_DIR"
21
+
22
+ # Optional: Load authentication state
23
+ # if [[ -f "./auth-state.json" ]]; then
24
+ # echo "Loading authentication state..."
25
+ # agent-browser state load "./auth-state.json"
26
+ # fi
27
+
28
+ # Navigate to target
29
+ agent-browser open "$TARGET_URL"
30
+ agent-browser wait --load networkidle
31
+
32
+ # Get metadata
33
+ TITLE=$(agent-browser get title)
34
+ URL=$(agent-browser get url)
35
+ echo "Title: $TITLE"
36
+ echo "URL: $URL"
37
+
38
+ # Capture full page screenshot
39
+ agent-browser screenshot --full "$OUTPUT_DIR/page-full.png"
40
+ echo "Saved: $OUTPUT_DIR/page-full.png"
41
+
42
+ # Get page structure with refs
43
+ agent-browser snapshot -i > "$OUTPUT_DIR/page-structure.txt"
44
+ echo "Saved: $OUTPUT_DIR/page-structure.txt"
45
+
46
+ # Extract all text content
47
+ agent-browser get text body > "$OUTPUT_DIR/page-text.txt"
48
+ echo "Saved: $OUTPUT_DIR/page-text.txt"
49
+
50
+ # Save as PDF
51
+ agent-browser pdf "$OUTPUT_DIR/page.pdf"
52
+ echo "Saved: $OUTPUT_DIR/page.pdf"
53
+
54
+ # Optional: Extract specific elements using refs from structure
55
+ # agent-browser get text @e5 > "$OUTPUT_DIR/main-content.txt"
56
+
57
+ # Optional: Handle infinite scroll pages
58
+ # for i in {1..5}; do
59
+ # agent-browser scroll down 1000
60
+ # agent-browser wait 1000
61
+ # done
62
+ # agent-browser screenshot --full "$OUTPUT_DIR/page-scrolled.png"
63
+
64
+ # Cleanup
65
+ agent-browser close
66
+
67
+ echo ""
68
+ echo "Capture complete:"
69
+ ls -la "$OUTPUT_DIR"
@@ -0,0 +1,62 @@
1
+ #!/bin/bash
2
+ # Template: Form Automation Workflow
3
+ # Purpose: Fill and submit web forms with validation
4
+ # Usage: ./form-automation.sh <form-url>
5
+ #
6
+ # This template demonstrates the snapshot-interact-verify pattern:
7
+ # 1. Navigate to form
8
+ # 2. Snapshot to get element refs
9
+ # 3. Fill fields using refs
10
+ # 4. Submit and verify result
11
+ #
12
+ # Customize: Update the refs (@e1, @e2, etc.) based on your form's snapshot output
13
+
14
+ set -euo pipefail
15
+
16
+ FORM_URL="${1:?Usage: $0 <form-url>}"
17
+
18
+ echo "Form automation: $FORM_URL"
19
+
20
+ # Step 1: Navigate to form
21
+ agent-browser open "$FORM_URL"
22
+ agent-browser wait --load networkidle
23
+
24
+ # Step 2: Snapshot to discover form elements
25
+ echo ""
26
+ echo "Form structure:"
27
+ agent-browser snapshot -i
28
+
29
+ # Step 3: Fill form fields (customize these refs based on snapshot output)
30
+ #
31
+ # Common field types:
32
+ # agent-browser fill @e1 "John Doe" # Text input
33
+ # agent-browser fill @e2 "user@example.com" # Email input
34
+ # agent-browser fill @e3 "SecureP@ss123" # Password input
35
+ # agent-browser select @e4 "Option Value" # Dropdown
36
+ # agent-browser check @e5 # Checkbox
37
+ # agent-browser click @e6 # Radio button
38
+ # agent-browser fill @e7 "Multi-line text" # Textarea
39
+ # agent-browser upload @e8 /path/to/file.pdf # File upload
40
+ #
41
+ # Uncomment and modify:
42
+ # agent-browser fill @e1 "Test User"
43
+ # agent-browser fill @e2 "test@example.com"
44
+ # agent-browser click @e3 # Submit button
45
+
46
+ # Step 4: Wait for submission
47
+ # agent-browser wait --load networkidle
48
+ # agent-browser wait --url "**/success" # Or wait for redirect
49
+
50
+ # Step 5: Verify result
51
+ echo ""
52
+ echo "Result:"
53
+ agent-browser get url
54
+ agent-browser snapshot -i
55
+
56
+ # Optional: Capture evidence
57
+ agent-browser screenshot /tmp/form-result.png
58
+ echo "Screenshot saved: /tmp/form-result.png"
59
+
60
+ # Cleanup
61
+ agent-browser close
62
+ echo "Done"