- Port halo_tokens + halo_theme + HaloButton to mitra_app (rose palette, Bricolage display, Poppins body, JetBrainsMono). - Build S3a Input WhatsApp (figma-bestie BestieS3 first half) with +62 chip, leading-zero/62 normalization, allow '+' in input. - Build S3b OTP verification (6-digit, 60s resend timer, attempts hint, Focus(canRequestFocus:false) for maestro inputText compat) with full error branching (CODE_MISMATCH, OTP_EXPIRED, OTP_USED, ATTEMPTS_EXCEEDED, WRONG_FLOW, ACCOUNT_INACTIVE). - Add AccountInactive terminal screen for is_active=false mitras. - Typed MitraAuthError with Indonesian-first localized messages + retryAfterSeconds passthrough. - Rebuild home_screen.dart to match figma BestieHome (greeting + status card + Ganti Status CTA + Pengingat + 2-tile dark grid). - Backend: POST /internal/_test/seed-mitra (idempotent) and PATCH /internal/mitras/:id (display_name update). - Control center: inline Edit Nama on mitras row + expandable inline log table under clicked mitra (vs old below-table panel). - 5 maestro flows ts-mitra-A-01/03/04/05/06 covering invalid input, happy path, account inactive, phone-format normalization, and the back-to-S3a regression. All green. Plan + memory documented in: - requirement/phase4-mitra-prehome-plan.md - requirement/flow_mitra.md / flow_mitra.mermaid.md §A Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
137 lines
3.7 KiB
YAML
137 lines
3.7 KiB
YAML
# ts-mitra-A-05 — §A.1 phone-format normalization
|
|
# Spec ref: requirement/flow_mitra.mermaid.md §A.1
|
|
#
|
|
# Indonesian users type phone numbers in many shapes. The login screen's
|
|
# _subscriberDigits() in login_screen.dart must normalize ALL of these to
|
|
# the same +628200000501 (subscriber digits = 8200000501):
|
|
#
|
|
# 8200000501 — subscriber only
|
|
# 08200000501 — local format with leading 0
|
|
# 628200000501 — country code without +
|
|
# +628200000501 — full E.164
|
|
# 0628200000501 — typo combo with leading 0 before country code
|
|
#
|
|
# Strategy: seed ONE mitra at +628200000501. For each variant, do a fresh
|
|
# launchApp clearState, type the variant, tap "kirim kode", and assert the
|
|
# S3b screen shows the correctly normalized phone "+628200000501". A fresh
|
|
# launch per variant is more reliable than back-navigation across maestro
|
|
# / IME / keyboard state.
|
|
appId: com.mybestie.mitra
|
|
env:
|
|
TEST_PHONE: "+628200000501"
|
|
MITRA_DISPLAY_NAME: "Maestro Variants"
|
|
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}
|
|
|
|
# ── Variant 1: 8xxxxxxxxx (subscriber only, 10 digits) ──
|
|
- 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: "60%, 47%"
|
|
- inputText: "8200000501"
|
|
- tapOn: "(?s).*kirim kode.*"
|
|
- extendedWaitUntil:
|
|
visible:
|
|
text: "(?s).*\\+628200000501.*"
|
|
timeout: 10000
|
|
|
|
# ── Variant 2: 08xxxxxxxxx (local format with leading 0) ──
|
|
- 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: "60%, 47%"
|
|
- inputText: "08200000501"
|
|
- tapOn: "(?s).*kirim kode.*"
|
|
- extendedWaitUntil:
|
|
visible:
|
|
text: "(?s).*\\+628200000501.*"
|
|
timeout: 10000
|
|
|
|
# ── Variant 3: 628xxxxxxxxx (country code without +) ──
|
|
- 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: "60%, 47%"
|
|
- inputText: "628200000501"
|
|
- tapOn: "(?s).*kirim kode.*"
|
|
- extendedWaitUntil:
|
|
visible:
|
|
text: "(?s).*\\+628200000501.*"
|
|
timeout: 10000
|
|
|
|
# ── Variant 4: +628xxxxxxxxx (full E.164 with +) ──
|
|
- 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: "60%, 47%"
|
|
- inputText: "+628200000501"
|
|
- tapOn: "(?s).*kirim kode.*"
|
|
- extendedWaitUntil:
|
|
visible:
|
|
text: "(?s).*\\+628200000501.*"
|
|
timeout: 10000
|
|
|
|
# ── Variant 5: 0628xxxxxxxxx (typo combo) ──
|
|
- 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: "60%, 47%"
|
|
- inputText: "0628200000501"
|
|
- tapOn: "(?s).*kirim kode.*"
|
|
- extendedWaitUntil:
|
|
visible:
|
|
text: "(?s).*\\+628200000501.*"
|
|
timeout: 10000
|