Files
halobestie-clone/mitra_app/.maestro/flows/ts-mitra-1-03-toggle_online_to_offline.yaml
Ramadhan Sjamsani fbc94daac7 Mitra Bestie §1–§3: shell + Undangan + popup + chat polish
Brings the mitra app to figma-bestie parity for Home (§1), Undangan
inbox with Curhat Baru + Perpanjang tabs (§2), and the incoming-popup
+ active-chat flow (§3). Home now lives inside a StatefulShellRoute
with BestieTabBar so Profil + Undangan + Home share one shell.

- Shell: features/shell/ (StatefulShellRoute, BestieTabBar, 3 branches)
- Undangan: features/undangan/ — Curhat Baru reads
  chatRequestProvider.pendingInvites; row Terima delegates accept to
  the notifier and ChatRequestOverlay owns nav (no double-push).
  Perpanjang tab stubbed (empty state) until backend exposes
  pendingExtensionsProvider.
- Profil: features/profile/ — Bestie-styled stub
- Home: refactored to body-only (shell owns chrome)
- Popup: chat_request_overlay + chat_request_notifier updated to
  serve the list rows, not just the modal
- Chat: mitra_chat_screen polish
- Theme: accentAmber tokens for the Perpanjang tab + halo_orb widget
  (loading spinner used by undangan list states)
- Login: replace broken GoRouterState location guard with
  _expectOtpPush flag — was stacking duplicate /otp pages on OTP
  resend (see project-otp-nav-bug-fixed-2026-05-21)

Maestro:
- 17 new flows under .maestro/flows/ts-mitra-{1,2,3}-* covering home
  online/offline variants, undangan empty/populated/tolak states,
  popup curhat-baru → accept → chat → ended banner, plus popup
  dismiss/expire/cancelled edge cases
- 4 new §A OTP flows (07/08/09/10) for invalid/mismatch/expired/cooldown
- Helper scripts: force_mitra_online/offline, force_pairing_timeout,
  force_session_expires_at, delete_mitra_status_row,
  customer_blast_now (js), customer_cancel_latest_blast
- Backend: POST /internal/_test/delete-mitra-status-row supports the
  "fresh mitra with no status row" test setup

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-21 11:14:30 +08:00

78 lines
2.3 KiB
YAML

# ts-mitra-1-03 — §1 Ganti Status toggles online ⇄ offline UI
# Spec ref: requirement/flow_mitra.mermaid.md §1
#
# Starts on /home in the online variant, taps "Ganti Status" → asserts the
# offline variant takes over, taps "Nyalain Status (Online)" → asserts the
# online variant returns. Screenshots at both states for the design review.
#
# Online toggle posts /api/mitra/status/online (offline → /offline). The
# status_notifier sets StatusLoadedData immediately on success so the UI
# flips within ~1 frame after the response.
appId: com.mybestie.mitra
env:
TEST_PHONE: "+628200000703"
MITRA_DISPLAY_NAME: "Maestro Toggle"
BACKEND_INTERNAL_URL: http://localhost:3001
---
- runScript:
file: ../scripts/seed_mitra.js
env:
TEST_PHONE: ${TEST_PHONE}
MITRA_DISPLAY_NAME: ${MITRA_DISPLAY_NAME}
IS_ACTIVE: "true"
BACKEND_INTERNAL_URL: ${BACKEND_INTERNAL_URL}
- runScript:
file: ../scripts/reset_phone.js
env:
TEST_PHONE: ${TEST_PHONE}
BACKEND_INTERNAL_URL: ${BACKEND_INTERNAL_URL}
- launchApp:
clearState: true
- extendedWaitUntil:
visible:
text: "(?s).*Halo Mitra Bestie.*"
timeout: 10000
- tapOn:
point: "50%, 53%"
- inputText: "8200000703"
- tapOn: "(?s).*kirim kode.*"
- extendedWaitUntil:
visible:
text: "(?s).*masukin 6 digit kode.*"
timeout: 10000
- runScript:
file: ../scripts/peek_otp.js
env:
TEST_PHONE: ${TEST_PHONE}
BACKEND_INTERNAL_URL: ${BACKEND_INTERNAL_URL}
- inputText: ${output.OTP}
# Online variant on first land.
- extendedWaitUntil:
visible:
text: "(?s).*Kamu lagi (ONLINE|OFFLINE).*"
timeout: 15000
- takeScreenshot: ts-mitra-1-03-online-before-toggle
# Tap Ganti Status → flip to offline.
- tapOn: "(?s).*(Ganti Status|Nyalain Status).*"
- extendedWaitUntil:
visible:
text: "(?s).*Kamu lagi OFFLINE.*"
timeout: 10000
- assertVisible:
text: "(?s).*Nyalain Status \\(Online\\).*"
- takeScreenshot: ts-mitra-1-03-offline-after-toggle
# Tap Nyalain Status → flip back to online.
- tapOn: "(?s).*Nyalain Status \\(Online\\).*"
- extendedWaitUntil:
visible:
text: "(?s).*Kamu lagi (ONLINE|OFFLINE).*"
timeout: 10000
- assertVisible:
text: "(?s).*(Ganti Status|Nyalain Status).*"
- takeScreenshot: ts-mitra-1-03-online-after-second-toggle