From lisa-expo
Read a JIRA ticket's Validation Journey section, execute the steps using Playwright MCP browser tools across all defined viewports, capture screenshots at each marker, generate evidence templates, and post to JIRA + GitHub PR using the jira-evidence skill.
npx claudepluginhub codyswanngt/lisa --plugin lisa-expoThis skill uses the workspace's default tool permissions.
Read a JIRA ticket's Validation Journey, execute it via Playwright MCP browser tools, capture screenshots at every `[SCREENSHOT: name]` marker across all viewports, and post evidence to both JIRA and GitHub PR.
Generates design tokens/docs from CSS/Tailwind/styled-components codebases, audits visual consistency across 10 dimensions, detects AI slop in UI.
Records polished WebM UI demo videos of web apps using Playwright with cursor overlay, natural pacing, and three-phase scripting. Activates for demo, walkthrough, screen recording, or tutorial requests.
Delivers idiomatic Kotlin patterns for null safety, immutability, sealed classes, coroutines, Flows, extensions, DSL builders, and Gradle DSL. Use when writing, reviewing, refactoring, or designing Kotlin code.
Read a JIRA ticket's Validation Journey, execute it via Playwright MCP browser tools, capture screenshots at every [SCREENSHOT: name] marker across all viewports, and post evidence to both JIRA and GitHub PR.
$ARGUMENTS: <TICKET_ID> [PR_NUMBER]
TICKET_ID (required): JIRA ticket key (e.g., PROJ-123)PR_NUMBER (optional): GitHub PR number to update descriptionJIRA_API_TOKEN environment variable setjira-cli configured (~/.config/.jira/.config.yml)gh CLI authenticatedRun the parser script to extract the Validation Journey from the JIRA ticket description:
python3 .claude/skills/jira-journey/scripts/parse-plan.py <TICKET_ID>
The script outputs JSON to stdout:
{
"ticket": "PROJ-123",
"prerequisites": [
"Backend dev server running",
"Admin user with test credentials"
],
"steps": [
{"number": 1, "text": "Navigate to Players page", "screenshot": null},
{"number": 5, "text": "Open transfer modal", "screenshot": "confirm-step-disabled"}
],
"viewports": [
{"name": "Desktop", "width": 1512, "height": 768},
{"name": "Mobile", "width": 375, "height": 812}
],
"assertions": [
"Modal fills entire screen on mobile (no horizontal overflow)"
]
}
Read the JSON output and use it to drive the Playwright session.
Before starting the journey, verify each prerequisite:
browser_navigate to the app URL).env.localhost or .env.local)For each viewport defined in the journey:
browser_resize to set the viewport dimensionsscreenshot marker, use browser_take_screenshot to capture the screenshotScreenshots are named: {NN}-{screenshot-name}-{viewport-name}.png
NN: zero-padded sequential number (01, 02, 03...)screenshot-name: the value from [SCREENSHOT: name] in the JIRA stepviewport-name: lowercase viewport name from the Viewports tableExample: For a journey with 3 screenshot markers and 2 viewports:
evidence/
01-search-step-desktop.png
02-confirm-step-desktop.png
03-success-step-desktop.png
04-search-step-mobile.png
05-confirm-step-mobile.png
06-success-step-mobile.png
comment.txt
comment.md
Execute the full journey once per viewport. Between viewports:
browser_resizeThis ensures each screenshot is captured at the correct viewport dimensions with the correct application state.
After capturing all screenshots, run the template generator:
python3 .claude/skills/jira-journey/scripts/generate-templates.py \
<TICKET_ID> \
<PR_NUMBER> \
<BRANCH_NAME> \
./evidence
This generates evidence/comment.txt (JIRA wiki markup) and evidence/comment.md (GitHub markdown) with:
Use the jira-evidence skill to post everything:
bash .claude/skills/jira-evidence/scripts/post-evidence.sh <TICKET_ID> ./evidence <PR_NUMBER>
Confirm images render inline at both the JIRA ticket and GitHub PR.
The JIRA ticket description must contain a section with this structure:
h2. Validation Journey
h3. Prerequisites
- App running locally or on dev
- Authenticated as test user
- Required feature flags enabled
h3. Steps
1. Navigate to the relevant page
2. Perform the first action
3. Click on the element [SCREENSHOT: element-state]
4. Complete the flow
5. Verify the final state [SCREENSHOT: final-state]
h3. Viewports
||Name||Width||Height||
|Desktop|1512|768|
|Mobile|375|812|
h3. Assertions
- Visual assertion about expected behavior
- Another assertion about responsive layout
[SCREENSHOT: name] markers define where to capture. The name is used in the filename.Some modals close when the viewport changes. The viewport execution strategy (full journey per viewport) handles this — each viewport starts fresh.
If the app requires re-authentication after resize/navigation, include the auth steps in the journey.
If a step is conditional, capture the screenshot at the state described in the step text, not after the conditional action.