Replace fixed sleeps with proper observable waits:
- wagmi settle: waitFor on '.connect-button--disconnected, .connect-button--connected'
which auto-retries until wagmi renders a terminal state
- panel animation: connector.waitFor already handles this
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
The deep link test's wallet connection was silently failing because
isVisible() returns immediately without waiting for the element to
appear. wagmi needs time to settle into 'disconnected' state after
provider injection. Now uses waitFor() which properly auto-retries,
plus adds a 2s delay matching the pattern used in test 01.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
The wallet provider no longer auto-connects via eth_accounts, so the
deep link test must explicitly connect the wallet before verifying
the swap widget renders its input and buy button.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
- Rename analytics test to accurately describe what it verifies
(collector infrastructure wiring, not app-level event firing)
- Add comment explaining why real CTA click cannot be used
(full-page navigation unloads context before events can be read)
- Remove wallet_connect if/else block that had no assertion
- Remove dead Step 5 comment block with no assertions
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
Replace three fixed-delay waitForTimeout calls with proper event-driven
alternatives per AGENTS.md Engineering Principle #1:
- navigateSPA to /app/stake: use waitForSelector('.stake-view, .login-wrapper')
to detect when the route has mounted (handles login redirect too)
- wallet auto-connect: use waitForFunction to poll __analytics_events for
wallet_connect, resolving as soon as the event fires
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
On mobile (isMobile:true), Playwright tap events don't reliably trigger
Vue @click handlers that set window.location.href — the desktop test
already verifies the CTA click→navigation flow. The mobile test's
purpose is verifying layout and rendering on mobile viewports, so
navigate directly to verify the pages render correctly.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
In CI (VITE_ENABLE_LOCAL_SWAP=true), the LocalSwapWidget renders a
"Connect your wallet" message when no wallet is connected. The previous
check looked for [data-testid="swap-amount-input"] which only appears
with an active wallet, causing the test to fall through to the Uniswap
link check (which also doesn't exist in local mode).
Fix: detect local swap mode via the .local-swap-widget container class
which is always rendered. Also add force:true for mobile CTA click.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
Playwright click() can race with waitForURL when the click triggers
window.location.href. Use Promise.all([waitForURL, click]) pattern
to ensure the URL listener is active before the click fires.
Also cap funnel test timeout to 3 minutes (these are navigation-only,
no blockchain transactions) to fail fast rather than hang.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
The landing page CTA used router.push('/app/get-krk') which was caught
by the catch-all route and redirected back to '/'. Since landing and
webapp are separate Vue apps behind Caddy, cross-app navigation needs
window.location.href to trigger a real browser request through the
reverse proxy.
Also simplify the analytics E2E test to avoid race conditions between
event capture and page unload during navigation.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
E2E spec covering the full conversion funnel: landing page CTA →
web-app get-krk page → Uniswap deep link verification → stake route.
Tests desktop (1280×720) and mobile (375×812) viewports, validates
Uniswap deep link structure (correct chain + token address), and
verifies analytics events fire at each funnel stage via injected
mock tracker.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>