{
  "summary": {
    "run_id": "scheduled-20260430T200246",
    "started_at": "2026-04-30T20:02:48.709Z",
    "finished_at": "2026-04-30T20:18:09.674Z",
    "total": 469,
    "passed": 394,
    "failed": 65,
    "skipped": 0,
    "not_exec": 10,
    "flaky": 0,
    "results": [
      {
        "id": "FE-ACT-001",
        "status": "PASS",
        "duration_ms": 2.626749000000018
      },
      {
        "id": "FE-ACT-002",
        "status": "PASS",
        "duration_ms": 0.40428399999996145
      },
      {
        "id": "FE-ACT-003",
        "status": "PASS",
        "duration_ms": 0.34544400000004316
      },
      {
        "id": "FE-ACT-004",
        "status": "PASS",
        "duration_ms": 0.32468599999992875
      },
      {
        "id": "FE-ACT-005",
        "status": "PASS",
        "duration_ms": 0.3366070000001855
      },
      {
        "id": "FE-ACT-006",
        "status": "PASS",
        "duration_ms": 0.43905900000004294
      },
      {
        "id": "FE-ACT-007",
        "status": "PASS",
        "duration_ms": 0.6378090000000611
      },
      {
        "id": "FE-ACT-008",
        "status": "PASS",
        "duration_ms": 0.28792700000008153
      },
      {
        "id": "FE-ACT-009",
        "status": "PASS",
        "duration_ms": 0.5589230000000498
      },
      {
        "id": "FE-ACT-010",
        "status": "PASS",
        "duration_ms": 1480.628887
      },
      {
        "id": "FE-ACT-011",
        "status": "PASS",
        "duration_ms": 0.5042109999999411
      },
      {
        "id": "FE-ADM-001",
        "status": "FAIL",
        "duration_ms": 61000.018701,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 7m24s\",\"retry_after_seconds\":444,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-ADM-003",
        "status": "FAIL",
        "duration_ms": 60380.52343000001,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 6m24s\",\"retry_after_seconds\":384,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-ADM-004",
        "status": "FAIL",
        "duration_ms": 60364.031010000006,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 5m23s\",\"retry_after_seconds\":323,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-ADM-005",
        "status": "FAIL",
        "duration_ms": 60288.692396,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 4m23s\",\"retry_after_seconds\":263,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-ADM-006",
        "status": "FAIL",
        "duration_ms": 60213.78867799998,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 3m23s\",\"retry_after_seconds\":203,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-ADM-007",
        "status": "FAIL",
        "duration_ms": 60235.870748999994,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 2m23s\",\"retry_after_seconds\":143,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-ADM-008",
        "status": "FAIL",
        "duration_ms": 60157.96798800002,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 1m22s\",\"retry_after_seconds\":82,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-ADM-012",
        "status": "FAIL",
        "duration_ms": 60276.583132,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 22s\",\"retry_after_seconds\":22,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-ADM-013",
        "status": "PASS",
        "duration_ms": 30552.667992000002
      },
      {
        "id": "FE-ADM-014",
        "status": "PASS",
        "duration_ms": 6300.679562999983
      },
      {
        "id": "FE-ADM-015",
        "status": "PASS",
        "duration_ms": 5238.653027000022
      },
      {
        "id": "FE-ADM-016",
        "status": "PASS",
        "duration_ms": 4084.9416829999536
      },
      {
        "id": "FE-ADM-002",
        "status": "PASS",
        "duration_ms": 11.581730000092648
      },
      {
        "id": "FE-ADM-017",
        "status": "PASS",
        "duration_ms": 5671.428245999967
      },
      {
        "id": "FE-ADM-018",
        "status": "PASS",
        "duration_ms": 0.5390050000278279
      },
      {
        "id": "FE-ADM-PLAN-001",
        "status": "PASS",
        "duration_ms": 4475.666896000039
      },
      {
        "id": "FE-ADM-PLAN-002",
        "status": "PASS",
        "duration_ms": 2.102792000048794
      },
      {
        "id": "FE-ADM-PLAN-003",
        "status": "PASS",
        "duration_ms": 0.5977150000398979
      },
      {
        "id": "FE-ADM-PLAN-004",
        "status": "PASS",
        "duration_ms": 0.2902720000129193
      },
      {
        "id": "FE-ADM-PLAN-005",
        "status": "PASS",
        "duration_ms": 0.23355500004254282
      },
      {
        "id": "FE-ADM-PLAN-006",
        "status": "PASS",
        "duration_ms": 0.2412890000268817
      },
      {
        "id": "FE-ADM-ADDON-001",
        "status": "PASS",
        "duration_ms": 3547.4889060000423
      },
      {
        "id": "FE-ADM-ADDON-002",
        "status": "PASS",
        "duration_ms": 0.7550380000611767
      },
      {
        "id": "FE-ADM-ADDON-003",
        "status": "PASS",
        "duration_ms": 0.25779999990481883
      },
      {
        "id": "FE-ADM-ADDON-004",
        "status": "PASS",
        "duration_ms": 0.22266600001603365
      },
      {
        "id": "FE-ADM-ADDON-005",
        "status": "PASS",
        "duration_ms": 0.20551299990620464
      },
      {
        "id": "FE-ADM-PROMO-001",
        "status": "PASS",
        "duration_ms": 3519.4236060000258
      },
      {
        "id": "FE-ADM-PROMO-002",
        "status": "PASS",
        "duration_ms": 0.4804149999981746
      },
      {
        "id": "FE-ADM-PROMO-003",
        "status": "PASS",
        "duration_ms": 0.20685499999672174
      },
      {
        "id": "FE-ADM-PROMO-004",
        "status": "PASS",
        "duration_ms": 0.19156800000928342
      },
      {
        "id": "FE-ADM-PROMO-005",
        "status": "PASS",
        "duration_ms": 0.21804599999450147
      },
      {
        "id": "FE-AI-001",
        "status": "FAIL",
        "duration_ms": 62326.845113,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 8m29s\",\"retry_after_seconds\":509,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-AI-002",
        "status": "PASS",
        "duration_ms": 5.593544000003021
      },
      {
        "id": "FE-AI-003",
        "status": "PASS",
        "duration_ms": 0.5091269999975339
      },
      {
        "id": "FE-AI-004",
        "status": "PASS",
        "duration_ms": 0.6197430000029271
      },
      {
        "id": "FE-AI-005",
        "status": "PASS",
        "duration_ms": 0.5440820000003441
      },
      {
        "id": "FE-AI-006",
        "status": "PASS",
        "duration_ms": 0.4138410000014119
      },
      {
        "id": "FE-AI-007",
        "status": "PASS",
        "duration_ms": 0.3289420000000973
      },
      {
        "id": "FE-AI-008",
        "status": "PASS",
        "duration_ms": 0.7060629999978119
      },
      {
        "id": "FE-AI-009",
        "status": "PASS",
        "duration_ms": 0.3002679999990505
      },
      {
        "id": "FE-AI-010",
        "status": "PASS",
        "duration_ms": 4.630313000001479
      },
      {
        "id": "FE-AI-011",
        "status": "PASS",
        "duration_ms": 1.0270700000037323
      },
      {
        "id": "FE-AI-012",
        "status": "PASS",
        "duration_ms": 1083.5894150000022
      },
      {
        "id": "FE-AI-013",
        "status": "PASS",
        "duration_ms": 0.3334099999992759
      },
      {
        "id": "FE-AI-014",
        "status": "PASS",
        "duration_ms": 0.41507199999614386
      },
      {
        "id": "FE-AI-015",
        "status": "PASS",
        "duration_ms": 0.3578750000015134
      },
      {
        "id": "FE-AI-016",
        "status": "PASS",
        "duration_ms": 0.3514740000027814
      },
      {
        "id": "FE-AI-017",
        "status": "PASS",
        "duration_ms": 538.5058159999971
      },
      {
        "id": "FE-AI-018",
        "status": "PASS",
        "duration_ms": 0.3994830000010552
      },
      {
        "id": "FE-AI-019",
        "status": "PASS",
        "duration_ms": 7.533061000001908
      },
      {
        "id": "FE-AI-020",
        "status": "PASS",
        "duration_ms": 272.918565999993
      },
      {
        "id": "FE-AUTH-021",
        "status": "NOT_EXEC",
        "duration_ms": 0
      },
      {
        "id": "FE-AUTH-022",
        "status": "NOT_EXEC",
        "duration_ms": 0
      },
      {
        "id": "FE-AUTH-023",
        "status": "NOT_EXEC",
        "duration_ms": 0
      },
      {
        "id": "FE-AUTH-001",
        "status": "PASS",
        "duration_ms": 2065.6520750000004
      },
      {
        "id": "FE-AUTH-002",
        "status": "PASS",
        "duration_ms": 3386.997386
      },
      {
        "id": "FE-AUTH-003",
        "status": "PASS",
        "duration_ms": 293.52299700000003
      },
      {
        "id": "FE-AUTH-004",
        "status": "PASS",
        "duration_ms": 232.22619200000008
      },
      {
        "id": "FE-AUTH-005",
        "status": "PASS",
        "duration_ms": 2590.625336000001
      },
      {
        "id": "FE-AUTH-006",
        "status": "PASS",
        "duration_ms": 1880.7082730000002
      },
      {
        "id": "FE-AUTH-007",
        "status": "PASS",
        "duration_ms": 3499.423852
      },
      {
        "id": "FE-AUTH-008",
        "status": "PASS",
        "duration_ms": 302.5789189999996
      },
      {
        "id": "FE-AUTH-009",
        "status": "PASS",
        "duration_ms": 127.8990679999988
      },
      {
        "id": "FE-AUTH-010",
        "status": "PASS",
        "duration_ms": 73.82850000000326
      },
      {
        "id": "FE-AUTH-011",
        "status": "PASS",
        "duration_ms": 196.17588199999955
      },
      {
        "id": "FE-AUTH-012",
        "status": "PASS",
        "duration_ms": 34440.544030000005
      },
      {
        "id": "FE-AUTH-013",
        "status": "FAIL",
        "duration_ms": 60465.845379000006,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 12m40s\",\"retry_after_seconds\":760,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-AUTH-014",
        "status": "PASS",
        "duration_ms": 1475.1288889999996
      },
      {
        "id": "FE-AUTH-015",
        "status": "PASS",
        "duration_ms": 377.4656859999959
      },
      {
        "id": "FE-AUTH-016",
        "status": "PASS",
        "duration_ms": 7741.903676000002
      },
      {
        "id": "FE-AUTH-017",
        "status": "FAIL",
        "duration_ms": 60542.16321499999,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 11m30s\",\"retry_after_seconds\":690,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-AUTH-018",
        "status": "FAIL",
        "duration_ms": 60335.49166500001,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 10m30s\",\"retry_after_seconds\":630,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-AUTH-019",
        "status": "PASS",
        "duration_ms": 2991.42762100001
      },
      {
        "id": "FE-AUTH-020",
        "status": "PASS",
        "duration_ms": 926.6695680000121
      },
      {
        "id": "FE-REG-001",
        "status": "PASS",
        "duration_ms": 3279.7896729999998
      },
      {
        "id": "FE-REG-002",
        "status": "PASS",
        "duration_ms": 3462.686635
      },
      {
        "id": "FE-REG-003",
        "status": "PASS",
        "duration_ms": 6742.789409999999
      },
      {
        "id": "FE-REG-004",
        "status": "PASS",
        "duration_ms": 4041.0479629999973
      },
      {
        "id": "FE-REG-005",
        "status": "PASS",
        "duration_ms": 586.6560019999997
      },
      {
        "id": "FE-REG-006",
        "status": "PASS",
        "duration_ms": 22986.715948999998
      },
      {
        "id": "FE-REG-007",
        "status": "PASS",
        "duration_ms": 1070.5377950000038
      },
      {
        "id": "FE-REG-008",
        "status": "PASS",
        "duration_ms": 877.7024180000008
      },
      {
        "id": "FE-REG-009",
        "status": "PASS",
        "duration_ms": 679.1563139999998
      },
      {
        "id": "FE-REG-010",
        "status": "PASS",
        "duration_ms": 2836.508482999998
      },
      {
        "id": "FE-REG-011",
        "status": "PASS",
        "duration_ms": 1908.8574509999962
      },
      {
        "id": "FE-REG-012",
        "status": "PASS",
        "duration_ms": 1313.6668900000004
      },
      {
        "id": "FE-REG-013",
        "status": "PASS",
        "duration_ms": 1351.010804999998
      },
      {
        "id": "FE-REG-014",
        "status": "NOT_EXEC",
        "duration_ms": 0
      },
      {
        "id": "FE-REG-015",
        "status": "NOT_EXEC",
        "duration_ms": 0
      },
      {
        "id": "FE-REG-016",
        "status": "NOT_EXEC",
        "duration_ms": 0
      },
      {
        "id": "FE-REG-017",
        "status": "NOT_EXEC",
        "duration_ms": 0
      },
      {
        "id": "FE-REG-018",
        "status": "NOT_EXEC",
        "duration_ms": 0
      },
      {
        "id": "FE-REG-019",
        "status": "NOT_EXEC",
        "duration_ms": 0
      },
      {
        "id": "FE-REG-020",
        "status": "NOT_EXEC",
        "duration_ms": 0
      },
      {
        "id": "FE-REG-021",
        "status": "PASS",
        "duration_ms": 2818.5267719999974
      },
      {
        "id": "FE-REG-022",
        "status": "PASS",
        "duration_ms": 3165.561297
      },
      {
        "id": "FE-REG-023",
        "status": "FAIL",
        "duration_ms": 60375.44581499999,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 12m32s\",\"retry_after_seconds\":752,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-REG-024",
        "status": "PASS",
        "duration_ms": 651.6317950000084
      },
      {
        "id": "FE-SETUP-001",
        "status": "FAIL",
        "duration_ms": 60636.045085,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 9m24s\",\"retry_after_seconds\":564,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-SETUP-002",
        "status": "PASS",
        "duration_ms": 1263.595727
      },
      {
        "id": "FE-SETUP-003",
        "status": "FAIL",
        "duration_ms": 60251.26559,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 8m22s\",\"retry_after_seconds\":502,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-SETUP-004",
        "status": "FAIL",
        "duration_ms": 60262.03805000002,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 7m22s\",\"retry_after_seconds\":442,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-SETUP-005",
        "status": "FAIL",
        "duration_ms": 60190.154981,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 6m22s\",\"retry_after_seconds\":382,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-SETUP-006",
        "status": "PASS",
        "duration_ms": 210.21885100001236
      },
      {
        "id": "FE-SETUP-007",
        "status": "FAIL",
        "duration_ms": 60206.446135999984,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 5m21s\",\"retry_after_seconds\":321,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-CAMP-021",
        "status": "FAIL",
        "duration_ms": 60479.970801999996,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 1m23s\",\"retry_after_seconds\":83,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-CAMP-022",
        "status": "FAIL",
        "duration_ms": 60220.017405000006,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 23s\",\"retry_after_seconds\":23,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-CAMP-023",
        "status": "PASS",
        "duration_ms": 28545.580736999997
      },
      {
        "id": "FE-CAMP-024",
        "status": "PASS",
        "duration_ms": 1806.1382459999877
      },
      {
        "id": "FE-CAMP-001",
        "status": "PASS",
        "duration_ms": 5385.435432
      },
      {
        "id": "FE-CAMP-002",
        "status": "PASS",
        "duration_ms": 10292.843008000002
      },
      {
        "id": "FE-CAMP-003",
        "status": "PASS",
        "duration_ms": 5062.352674000002
      },
      {
        "id": "FE-CAMP-004",
        "status": "PASS",
        "duration_ms": 5587.2640809999975
      },
      {
        "id": "FE-CAMP-005",
        "status": "PASS",
        "duration_ms": 6987.417512
      },
      {
        "id": "FE-CAMP-006",
        "status": "PASS",
        "duration_ms": 5146.428855999999
      },
      {
        "id": "FE-CAMP-007",
        "status": "PASS",
        "duration_ms": 7174.679565999999
      },
      {
        "id": "FE-CAMP-008",
        "status": "FAIL",
        "duration_ms": 60789.685940999996,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 12m39s\",\"retry_after_seconds\":759,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-CAMP-009",
        "status": "FAIL",
        "duration_ms": 60475.107203999985,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 11m39s\",\"retry_after_seconds\":699,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-CAMP-010",
        "status": "FAIL",
        "duration_ms": 60348.82918600002,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 10m38s\",\"retry_after_seconds\":638,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-CAMP-011",
        "status": "FAIL",
        "duration_ms": 60598.28164,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 9m38s\",\"retry_after_seconds\":578,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-CAMP-012",
        "status": "FAIL",
        "duration_ms": 60380.72113099997,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 8m38s\",\"retry_after_seconds\":518,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-CAMP-013",
        "status": "FAIL",
        "duration_ms": 60644.34879700001,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 7m37s\",\"retry_after_seconds\":457,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-CAMP-014",
        "status": "FAIL",
        "duration_ms": 60466.317313999985,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 6m36s\",\"retry_after_seconds\":396,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-CAMP-015",
        "status": "PASS",
        "duration_ms": 1.1971989999874495
      },
      {
        "id": "FE-CAMP-016",
        "status": "FAIL",
        "duration_ms": 60183.04475999996,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 5m36s\",\"retry_after_seconds\":336,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-CAMP-017",
        "status": "FAIL",
        "duration_ms": 60262.53760899999,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 4m36s\",\"retry_after_seconds\":276,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-CAMP-018",
        "status": "FAIL",
        "duration_ms": 60421.457528000115,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 3m36s\",\"retry_after_seconds\":216,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-CAMP-019",
        "status": "FAIL",
        "duration_ms": 60262.62550800003,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 2m35s\",\"retry_after_seconds\":155,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-CAMP-020",
        "status": "FAIL",
        "duration_ms": 60630.21257900004,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 1m35s\",\"retry_after_seconds\":95,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-DEAL-SEARCH-001",
        "status": "FAIL",
        "duration_ms": 60650.826134999996,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 55s\",\"retry_after_seconds\":55,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-DEAL-SEARCH-002",
        "status": "PASS",
        "duration_ms": 66101.149988
      },
      {
        "id": "FE-DEAL-SEARCH-003",
        "status": "PASS",
        "duration_ms": 8127.9877010000055
      },
      {
        "id": "FE-DEAL-SEARCH-004",
        "status": "PASS",
        "duration_ms": 6039.713879000017
      },
      {
        "id": "FE-DEAL-SEARCH-005",
        "status": "PASS",
        "duration_ms": 0.6552520000259392
      },
      {
        "id": "FE-DEAL-SEARCH-006",
        "status": "PASS",
        "duration_ms": 5319.6276620000135
      },
      {
        "id": "FE-CRED-001",
        "status": "PASS",
        "duration_ms": 1426.871456
      },
      {
        "id": "FE-CRED-002",
        "status": "PASS",
        "duration_ms": 0.8787989999996171
      },
      {
        "id": "FE-CRED-003",
        "status": "PASS",
        "duration_ms": 0.31526800000028743
      },
      {
        "id": "FE-CRED-004",
        "status": "PASS",
        "duration_ms": 1.4463470000000598
      },
      {
        "id": "FE-CRED-005",
        "status": "PASS",
        "duration_ms": 0.32368399999995745
      },
      {
        "id": "FE-CRED-006",
        "status": "PASS",
        "duration_ms": 0.38779299999987416
      },
      {
        "id": "FE-CRED-007",
        "status": "PASS",
        "duration_ms": 0.3251270000000659
      },
      {
        "id": "FE-CRED-008",
        "status": "PASS",
        "duration_ms": 0.2753339999999298
      },
      {
        "id": "FE-CRED-009",
        "status": "PASS",
        "duration_ms": 0.40693899999996574
      },
      {
        "id": "FE-CRED-010",
        "status": "PASS",
        "duration_ms": 0.4243419999997968
      },
      {
        "id": "FE-CRM-001",
        "status": "PASS",
        "duration_ms": 1476.3875360000002
      },
      {
        "id": "FE-CRM-002",
        "status": "PASS",
        "duration_ms": 1.0802549999998519
      },
      {
        "id": "FE-CRM-003",
        "status": "PASS",
        "duration_ms": 0.43145499999991443
      },
      {
        "id": "FE-CRM-004",
        "status": "PASS",
        "duration_ms": 0.3803290000000743
      },
      {
        "id": "FE-CRM-005",
        "status": "PASS",
        "duration_ms": 0.6154179999998632
      },
      {
        "id": "FE-CRM-006",
        "status": "PASS",
        "duration_ms": 0.46015899999974863
      },
      {
        "id": "FE-CRM-007",
        "status": "PASS",
        "duration_ms": 0.2786710000000312
      },
      {
        "id": "FE-CRM-008",
        "status": "PASS",
        "duration_ms": 0.40463499999987107
      },
      {
        "id": "FE-CRM-009",
        "status": "PASS",
        "duration_ms": 0.33260100000006787
      },
      {
        "id": "FE-CRM-010",
        "status": "PASS",
        "duration_ms": 1038.311424
      },
      {
        "id": "FE-CSV-011",
        "status": "PASS",
        "duration_ms": 224.53527199999962
      },
      {
        "id": "FE-CSV-012",
        "status": "PASS",
        "duration_ms": 0.4719300000001567
      },
      {
        "id": "FE-CSV-013",
        "status": "PASS",
        "duration_ms": 0.3890459999997802
      },
      {
        "id": "FE-CSV-014",
        "status": "PASS",
        "duration_ms": 0.2171640000001389
      },
      {
        "id": "FE-CSV-001",
        "status": "PASS",
        "duration_ms": 1344.9649670000001
      },
      {
        "id": "FE-CSV-002",
        "status": "PASS",
        "duration_ms": 0.8169940000002498
      },
      {
        "id": "FE-CSV-003",
        "status": "PASS",
        "duration_ms": 0.38703099999975166
      },
      {
        "id": "FE-CSV-004",
        "status": "PASS",
        "duration_ms": 0.2996889999999439
      },
      {
        "id": "FE-CSV-005",
        "status": "PASS",
        "duration_ms": 0.3206070000001091
      },
      {
        "id": "FE-CSV-006",
        "status": "PASS",
        "duration_ms": 0.3417970000000423
      },
      {
        "id": "FE-CSV-007",
        "status": "PASS",
        "duration_ms": 0.30040100000042
      },
      {
        "id": "FE-CSV-008",
        "status": "PASS",
        "duration_ms": 0.30684100000007675
      },
      {
        "id": "FE-CSV-009",
        "status": "PASS",
        "duration_ms": 0.35549200000014025
      },
      {
        "id": "FE-CSV-010",
        "status": "PASS",
        "duration_ms": 0.45069999999986976
      },
      {
        "id": "FE-DEAL-001",
        "status": "PASS",
        "duration_ms": 206.0062109999999
      },
      {
        "id": "FE-DEAL-002",
        "status": "PASS",
        "duration_ms": 0.4835419999999431
      },
      {
        "id": "FE-DEAL-003",
        "status": "PASS",
        "duration_ms": 0.2428220000001602
      },
      {
        "id": "FE-DEAL-004",
        "status": "PASS",
        "duration_ms": 0.3283919999998943
      },
      {
        "id": "FE-DEAL-005",
        "status": "PASS",
        "duration_ms": 0.17807199999992918
      },
      {
        "id": "FE-DEAL-006",
        "status": "PASS",
        "duration_ms": 0.39209200000004785
      },
      {
        "id": "FE-DEAL-007",
        "status": "PASS",
        "duration_ms": 0.2875050000000101
      },
      {
        "id": "FE-DEAL-008",
        "status": "PASS",
        "duration_ms": 0.19602600000007442
      },
      {
        "id": "FE-DEAL-009",
        "status": "PASS",
        "duration_ms": 0.6589690000000701
      },
      {
        "id": "FE-DEAL-010",
        "status": "PASS",
        "duration_ms": 0.41127700000015466
      },
      {
        "id": "FE-DEAL-011",
        "status": "PASS",
        "duration_ms": 0.5747819999999138
      },
      {
        "id": "FE-DEAL-012",
        "status": "PASS",
        "duration_ms": 0.3048389999999017
      },
      {
        "id": "FE-DEAL-013",
        "status": "PASS",
        "duration_ms": 39.79036999999994
      },
      {
        "id": "FE-DEAL-014",
        "status": "PASS",
        "duration_ms": 27.51808099999994
      },
      {
        "id": "FE-DEAL-015",
        "status": "PASS",
        "duration_ms": 0.31425500000000284
      },
      {
        "id": "FE-DEAL-016",
        "status": "PASS",
        "duration_ms": 0.24508700000001227
      },
      {
        "id": "FE-DEAL-017",
        "status": "PASS",
        "duration_ms": 0.2044419999999718
      },
      {
        "id": "UNKNOWN-b2wlnx",
        "status": "PASS",
        "duration_ms": 4.927089000000024
      },
      {
        "id": "UNKNOWN-zz34hd",
        "status": "PASS",
        "duration_ms": 0.823113999999805
      },
      {
        "id": "UNKNOWN-edwx7v",
        "status": "PASS",
        "duration_ms": 0.4013079999999718
      },
      {
        "id": "UNKNOWN-ajjk5k",
        "status": "PASS",
        "duration_ms": 0.4860670000000482
      },
      {
        "id": "UNKNOWN-ed0hsi",
        "status": "PASS",
        "duration_ms": 0.28963100000009945
      },
      {
        "id": "UNKNOWN-l4jn99",
        "status": "PASS",
        "duration_ms": 0.3322299999999814
      },
      {
        "id": "UNKNOWN-aqpa78",
        "status": "PASS",
        "duration_ms": 0.2981560000000627
      },
      {
        "id": "UNKNOWN-t23sxs",
        "status": "PASS",
        "duration_ms": 0.28617400000007365
      },
      {
        "id": "UNKNOWN-zc3ok9",
        "status": "PASS",
        "duration_ms": 0.24945600000000923
      },
      {
        "id": "UNKNOWN-ockfmf",
        "status": "PASS",
        "duration_ms": 0.24489800000014839
      },
      {
        "id": "FE-EMAIL-IN-012",
        "status": "PASS",
        "duration_ms": 364.4732530000001
      },
      {
        "id": "FE-EMAIL-IN-013",
        "status": "PASS",
        "duration_ms": 51.0346599999998
      },
      {
        "id": "FE-EMAIL-IN-014",
        "status": "PASS",
        "duration_ms": 0.35116500000003725
      },
      {
        "id": "FE-EMAIL-IN-001",
        "status": "PASS",
        "duration_ms": 2.0244860000000244
      },
      {
        "id": "FE-EMAIL-IN-002",
        "status": "PASS",
        "duration_ms": 0.3411670000000413
      },
      {
        "id": "FE-EMAIL-IN-003",
        "status": "PASS",
        "duration_ms": 0.39627999999993335
      },
      {
        "id": "FE-EMAIL-IN-004",
        "status": "PASS",
        "duration_ms": 0.37606099999993603
      },
      {
        "id": "FE-EMAIL-IN-005",
        "status": "PASS",
        "duration_ms": 0.3742780000000039
      },
      {
        "id": "FE-EMAIL-IN-006",
        "status": "PASS",
        "duration_ms": 0.4747259999999187
      },
      {
        "id": "FE-EMAIL-IN-007",
        "status": "PASS",
        "duration_ms": 0.3660330000000158
      },
      {
        "id": "FE-EMAIL-IN-008",
        "status": "PASS",
        "duration_ms": 139.1825570000001
      },
      {
        "id": "FE-EMAIL-IN-009",
        "status": "PASS",
        "duration_ms": 0.3770329999999831
      },
      {
        "id": "FE-EMAIL-IN-010",
        "status": "PASS",
        "duration_ms": 0.2850619999999253
      },
      {
        "id": "FE-EMAIL-IN-011",
        "status": "PASS",
        "duration_ms": 0.27162700000008044
      },
      {
        "id": "FE-EMAIL-OUT-013",
        "status": "FAIL",
        "duration_ms": 60648.690976,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 30s\",\"retry_after_seconds\":30,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-EMAIL-OUT-014",
        "status": "PASS",
        "duration_ms": 35245.018824
      },
      {
        "id": "FE-EMAIL-OUT-015",
        "status": "FAIL",
        "duration_ms": 1076.7788419999997,
        "error": "expected [ 400, 422 ] to include 404"
      },
      {
        "id": "FE-EMAIL-OUT-001",
        "status": "FAIL",
        "duration_ms": 60475.317268,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 2m34s\",\"retry_after_seconds\":154,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-EMAIL-OUT-002",
        "status": "FAIL",
        "duration_ms": 60263.743407,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 1m34s\",\"retry_after_seconds\":94,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-EMAIL-OUT-003",
        "status": "PASS",
        "duration_ms": 1.9934270000085235
      },
      {
        "id": "FE-EMAIL-OUT-004",
        "status": "FAIL",
        "duration_ms": 60243.041488999996,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 34s\",\"retry_after_seconds\":34,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-EMAIL-OUT-005",
        "status": "PASS",
        "duration_ms": 1.0522119999805
      },
      {
        "id": "FE-EMAIL-OUT-006",
        "status": "PASS",
        "duration_ms": 0.4882099999813363
      },
      {
        "id": "FE-EMAIL-OUT-007",
        "status": "PASS",
        "duration_ms": 45004.38435799998
      },
      {
        "id": "FE-EMAIL-OUT-008",
        "status": "PASS",
        "duration_ms": 0.640804999973625
      },
      {
        "id": "FE-EMAIL-OUT-009",
        "status": "PASS",
        "duration_ms": 2.260256000008667
      },
      {
        "id": "FE-EMAIL-OUT-010",
        "status": "PASS",
        "duration_ms": 37223.134055
      },
      {
        "id": "FE-EMAIL-OUT-011",
        "status": "PASS",
        "duration_ms": 0.6540210000239313
      },
      {
        "id": "FE-EMAIL-OUT-012",
        "status": "PASS",
        "duration_ms": 0.45281500002602115
      },
      {
        "id": "FE-EMAIL-001",
        "status": "FAIL",
        "duration_ms": 60816.92083,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 11m28s\",\"retry_after_seconds\":688,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-EMAIL-002",
        "status": "FAIL",
        "duration_ms": 60259.824957,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 10m28s\",\"retry_after_seconds\":628,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-EMAIL-003",
        "status": "FAIL",
        "duration_ms": 60512.045796000006,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 9m28s\",\"retry_after_seconds\":568,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-EMAIL-004",
        "status": "FAIL",
        "duration_ms": 60538.52111200002,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 8m27s\",\"retry_after_seconds\":507,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-EMAIL-005",
        "status": "FAIL",
        "duration_ms": 60409.842064000026,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 7m27s\",\"retry_after_seconds\":447,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-EMAIL-006",
        "status": "FAIL",
        "duration_ms": 60230.25345399999,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 6m26s\",\"retry_after_seconds\":386,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-EMAIL-007",
        "status": "FAIL",
        "duration_ms": 60254.88623300003,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 5m26s\",\"retry_after_seconds\":326,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-EMAIL-008",
        "status": "FAIL",
        "duration_ms": 60242.93591399997,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 4m26s\",\"retry_after_seconds\":266,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-EMAIL-009",
        "status": "PASS",
        "duration_ms": 5.29166799999075
      },
      {
        "id": "FE-EMAIL-010",
        "status": "FAIL",
        "duration_ms": 60384.16254500003,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 3m26s\",\"retry_after_seconds\":206,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-EMAIL-011",
        "status": "FAIL",
        "duration_ms": 60449.18166599993,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 2m25s\",\"retry_after_seconds\":145,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-EMAIL-012",
        "status": "PASS",
        "duration_ms": 1.8397600000025705
      },
      {
        "id": "FE-LAY-001",
        "status": "PASS",
        "duration_ms": 7337.153349999999
      },
      {
        "id": "FE-LAY-002",
        "status": "FAIL",
        "duration_ms": 60970.225809999996,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 12m35s\",\"retry_after_seconds\":755,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-LAY-003",
        "status": "FAIL",
        "duration_ms": 60323.573896999995,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 11m34s\",\"retry_after_seconds\":694,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-LAY-004",
        "status": "PASS",
        "duration_ms": 1.3154619999986608
      },
      {
        "id": "FE-LAY-005",
        "status": "PASS",
        "duration_ms": 0.8500580000109039
      },
      {
        "id": "FE-LAY-006",
        "status": "PASS",
        "duration_ms": 0.4112840000016149
      },
      {
        "id": "FE-LAY-007",
        "status": "PASS",
        "duration_ms": 0.4503160000022035
      },
      {
        "id": "FE-LAY-008",
        "status": "PASS",
        "duration_ms": 0.3816990000050282
      },
      {
        "id": "FE-CROSS-001",
        "status": "FAIL",
        "duration_ms": 60519.607868999985,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 10m34s\",\"retry_after_seconds\":634,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-CROSS-002",
        "status": "PASS",
        "duration_ms": 1.2920319999975618
      },
      {
        "id": "FE-CROSS-003",
        "status": "FAIL",
        "duration_ms": 60327.80797599998,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 9m33s\",\"retry_after_seconds\":573,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-CROSS-004",
        "status": "PASS",
        "duration_ms": 0.6156550000014249
      },
      {
        "id": "FE-CROSS-005",
        "status": "PASS",
        "duration_ms": 0.2841279999993276
      },
      {
        "id": "FE-CROSS-006",
        "status": "PASS",
        "duration_ms": 0.27090400000452064
      },
      {
        "id": "FE-CROSS-007",
        "status": "PASS",
        "duration_ms": 0.197225999989314
      },
      {
        "id": "FE-CROSS-008",
        "status": "PASS",
        "duration_ms": 0.2131249999802094
      },
      {
        "id": "FE-CROSS-009",
        "status": "PASS",
        "duration_ms": 0.21501899999566376
      },
      {
        "id": "FE-CROSS-010",
        "status": "PASS",
        "duration_ms": 0.18457300000591204
      },
      {
        "id": "FE-NOTIF-001",
        "status": "PASS",
        "duration_ms": 7274.516728999999
      },
      {
        "id": "FE-NOTIF-002",
        "status": "PASS",
        "duration_ms": 4.42992200000117
      },
      {
        "id": "FE-NOTIF-003",
        "status": "PASS",
        "duration_ms": 0.3954169999997248
      },
      {
        "id": "FE-NOTIF-004",
        "status": "PASS",
        "duration_ms": 0.37560000000121363
      },
      {
        "id": "FE-NOTIF-005",
        "status": "PASS",
        "duration_ms": 0.2802620000002207
      },
      {
        "id": "FE-NOTIF-006",
        "status": "PASS",
        "duration_ms": 0.3451340000010532
      },
      {
        "id": "FE-NOTIF-007",
        "status": "PASS",
        "duration_ms": 0.28413000000000466
      },
      {
        "id": "FE-NOTIF-008",
        "status": "PASS",
        "duration_ms": 0.2558370000006107
      },
      {
        "id": "FE-HELP-001",
        "status": "PASS",
        "duration_ms": 5838.1986959999995
      },
      {
        "id": "FE-HELP-002",
        "status": "PASS",
        "duration_ms": 2.8557959999998275
      },
      {
        "id": "FE-HELP-003",
        "status": "PASS",
        "duration_ms": 0.28485100000034436
      },
      {
        "id": "FE-HELP-004",
        "status": "PASS",
        "duration_ms": 0.192218000000139
      },
      {
        "id": "FE-HELP-005",
        "status": "PASS",
        "duration_ms": 5180.290661999999
      },
      {
        "id": "FE-HELP-006",
        "status": "PASS",
        "duration_ms": 4.132236000001285
      },
      {
        "id": "FE-HELP-007",
        "status": "PASS",
        "duration_ms": 5.028258000002097
      },
      {
        "id": "FE-HELP-008",
        "status": "PASS",
        "duration_ms": 0.5269029999981285
      },
      {
        "id": "FE-PERF-001",
        "status": "PASS",
        "duration_ms": 2639.2551129999997
      },
      {
        "id": "FE-PERF-002",
        "status": "PASS",
        "duration_ms": 1547.8565719999997
      },
      {
        "id": "FE-PERF-003",
        "status": "PASS",
        "duration_ms": 1732.6433340000003
      },
      {
        "id": "FE-PERF-004",
        "status": "FAIL",
        "duration_ms": 60844.559303,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 12m39s\",\"retry_after_seconds\":759,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-PERF-005",
        "status": "FAIL",
        "duration_ms": 60386.75578800001,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 11m39s\",\"retry_after_seconds\":699,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-PERF-006",
        "status": "FAIL",
        "duration_ms": 60391.41356800002,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 10m39s\",\"retry_after_seconds\":639,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-PERF-007",
        "status": "FAIL",
        "duration_ms": 60579.92923399998,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 9m38s\",\"retry_after_seconds\":578,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-PERF-008",
        "status": "FAIL",
        "duration_ms": 60221.89686400001,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 8m38s\",\"retry_after_seconds\":518,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-PERF-009",
        "status": "FAIL",
        "duration_ms": 60269.653857,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 7m37s\",\"retry_after_seconds\":457,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-PERF-010",
        "status": "FAIL",
        "duration_ms": 60260.69227700005,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 6m37s\",\"retry_after_seconds\":397,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-PERF-011",
        "status": "FAIL",
        "duration_ms": 60360.122221999976,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 5m37s\",\"retry_after_seconds\":337,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-PERF-012",
        "status": "PASS",
        "duration_ms": 2.2849150000256486
      },
      {
        "id": "FE-PERF-013",
        "status": "FAIL",
        "duration_ms": 60189.84730600001,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 4m37s\",\"retry_after_seconds\":277,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-PERF-014",
        "status": "PASS",
        "duration_ms": 0.8680369999492541
      },
      {
        "id": "FE-PERF-015",
        "status": "FAIL",
        "duration_ms": 60176.76189299999,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 3m36s\",\"retry_after_seconds\":216,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-SEAT-001",
        "status": "PASS",
        "duration_ms": 5784.4334
      },
      {
        "id": "FE-SEAT-002",
        "status": "PASS",
        "duration_ms": 9.412285000000338
      },
      {
        "id": "FE-SEAT-003",
        "status": "PASS",
        "duration_ms": 3.6819900000000416
      },
      {
        "id": "FE-SEAT-004",
        "status": "PASS",
        "duration_ms": 3711.540736
      },
      {
        "id": "FE-SEAT-005",
        "status": "PASS",
        "duration_ms": 0.40560199999890756
      },
      {
        "id": "FE-SEAT-006",
        "status": "PASS",
        "duration_ms": 0.5649970000013127
      },
      {
        "id": "FE-SEAT-007",
        "status": "PASS",
        "duration_ms": 0.16492599999946833
      },
      {
        "id": "FE-SEAT-008",
        "status": "PASS",
        "duration_ms": 0.49691100000018196
      },
      {
        "id": "FE-SEAT-009",
        "status": "PASS",
        "duration_ms": 3367.772441000001
      },
      {
        "id": "FE-AH-001",
        "status": "PASS",
        "duration_ms": 0.40453900000102294
      },
      {
        "id": "FE-AH-002",
        "status": "PASS",
        "duration_ms": 0.19844799999918905
      },
      {
        "id": "FE-AH-003",
        "status": "PASS",
        "duration_ms": 1.4711049999987154
      },
      {
        "id": "FE-AH-004",
        "status": "PASS",
        "duration_ms": 0.5987679999998363
      },
      {
        "id": "FE-SIG-001",
        "status": "PASS",
        "duration_ms": 0.30725900000106776
      },
      {
        "id": "FE-SIG-002",
        "status": "PASS",
        "duration_ms": 0.2668940000003204
      },
      {
        "id": "FE-SIG-003",
        "status": "PASS",
        "duration_ms": 0.18630599999960396
      },
      {
        "id": "FE-SIG-004",
        "status": "PASS",
        "duration_ms": 0.2456449999990582
      },
      {
        "id": "FE-SIG-005",
        "status": "PASS",
        "duration_ms": 0.17607700000007753
      },
      {
        "id": "FE-MISC-001",
        "status": "PASS",
        "duration_ms": 0.23972499999945285
      },
      {
        "id": "FE-MISC-002",
        "status": "PASS",
        "duration_ms": 13.311117999999624
      },
      {
        "id": "FE-MISC-003",
        "status": "PASS",
        "duration_ms": 1.0654340000000957
      },
      {
        "id": "FE-MISC-004",
        "status": "PASS",
        "duration_ms": 1.9559430000008433
      },
      {
        "id": "FE-MISC-005",
        "status": "PASS",
        "duration_ms": 0.5220770000014454
      },
      {
        "id": "FE-MISC-006",
        "status": "PASS",
        "duration_ms": 2342.350280999999
      },
      {
        "id": "FE-MISC-007",
        "status": "PASS",
        "duration_ms": 0.4864420000012615
      },
      {
        "id": "FE-MISC-008",
        "status": "PASS",
        "duration_ms": 0.2588290000021516
      },
      {
        "id": "FE-MISC-009",
        "status": "PASS",
        "duration_ms": 4.0230330000013055
      },
      {
        "id": "FE-MISC-010",
        "status": "PASS",
        "duration_ms": 0.28608900000108406
      },
      {
        "id": "FE-PUR-001",
        "status": "PASS",
        "duration_ms": 7070.2099670000025
      },
      {
        "id": "FE-PUR-002",
        "status": "PASS",
        "duration_ms": 0.5727020000012999
      },
      {
        "id": "FE-PUR-003",
        "status": "PASS",
        "duration_ms": 0.3329860000012559
      },
      {
        "id": "FE-PUR-004",
        "status": "PASS",
        "duration_ms": 0.2823129999997036
      },
      {
        "id": "FE-PUR-005",
        "status": "PASS",
        "duration_ms": 4564.984461
      },
      {
        "id": "FE-PUR-006",
        "status": "PASS",
        "duration_ms": 0.44913200000155484
      },
      {
        "id": "FE-PUR-007",
        "status": "PASS",
        "duration_ms": 0.23158900000271387
      },
      {
        "id": "FE-PUR-008",
        "status": "PASS",
        "duration_ms": 0.9094059999988531
      },
      {
        "id": "FE-SEC-001",
        "status": "PASS",
        "duration_ms": 198.39901199999986
      },
      {
        "id": "FE-SEC-002",
        "status": "PASS",
        "duration_ms": 14.73526199999992
      },
      {
        "id": "FE-SEC-003",
        "status": "PASS",
        "duration_ms": 5.204643000000033
      },
      {
        "id": "FE-SEC-004",
        "status": "PASS",
        "duration_ms": 0.619513999999981
      },
      {
        "id": "FE-SEC-005",
        "status": "PASS",
        "duration_ms": 0.47014500000000226
      },
      {
        "id": "FE-SEC-006",
        "status": "PASS",
        "duration_ms": 2.545671000000084
      },
      {
        "id": "FE-SEC-007",
        "status": "PASS",
        "duration_ms": 7959.203888
      },
      {
        "id": "FE-SEC-008",
        "status": "PASS",
        "duration_ms": 0.3537190000006376
      },
      {
        "id": "FE-SEC-009",
        "status": "PASS",
        "duration_ms": 0.32441499999913503
      },
      {
        "id": "FE-SEC-010",
        "status": "PASS",
        "duration_ms": 0.2588209999994433
      },
      {
        "id": "FE-SEC-011",
        "status": "PASS",
        "duration_ms": 8.306801999999152
      },
      {
        "id": "FE-SEC-012",
        "status": "PASS",
        "duration_ms": 0.5374110000011569
      },
      {
        "id": "FE-SEC-013",
        "status": "PASS",
        "duration_ms": 0.2837890000009793
      },
      {
        "id": "FE-SEC-014",
        "status": "PASS",
        "duration_ms": 591.7594130000016
      },
      {
        "id": "FE-SEC-015",
        "status": "PASS",
        "duration_ms": 0.5332730000009178
      },
      {
        "id": "FE-ROLE-001",
        "status": "PASS",
        "duration_ms": 1606.8324570000004
      },
      {
        "id": "FE-ROLE-002",
        "status": "PASS",
        "duration_ms": 6004.191034000001
      },
      {
        "id": "FE-ROLE-003",
        "status": "PASS",
        "duration_ms": 0.5342950000012934
      },
      {
        "id": "FE-ROLE-004",
        "status": "PASS",
        "duration_ms": 0.2625980000011623
      },
      {
        "id": "FE-ROLE-005",
        "status": "PASS",
        "duration_ms": 0.3445919999976468
      },
      {
        "id": "FE-ROLE-006",
        "status": "PASS",
        "duration_ms": 1.1157590000002529
      },
      {
        "id": "UNKNOWN-0bjw5h",
        "status": "PASS",
        "duration_ms": 159.663546
      },
      {
        "id": "UNKNOWN-u0ut0h",
        "status": "PASS",
        "duration_ms": 62.29520200000002
      },
      {
        "id": "UNKNOWN-h7jzr9",
        "status": "PASS",
        "duration_ms": 170.03902699999992
      },
      {
        "id": "FE-SET-G-016",
        "status": "FAIL",
        "duration_ms": 60546.792885,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 4m0s\",\"retry_after_seconds\":240,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-SET-G-017",
        "status": "FAIL",
        "duration_ms": 60235.205350000004,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 3m0s\",\"retry_after_seconds\":180,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-SET-G-018",
        "status": "FAIL",
        "duration_ms": 60169.11558500001,
        "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 2m0s\",\"retry_after_seconds\":120,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
      },
      {
        "id": "FE-SET-G-001",
        "status": "PASS",
        "duration_ms": 5607.559928000001
      },
      {
        "id": "FE-SET-G-002",
        "status": "PASS",
        "duration_ms": 11202.534482
      },
      {
        "id": "FE-SET-G-003",
        "status": "PASS",
        "duration_ms": 0.7577230000024429
      },
      {
        "id": "FE-SET-G-004",
        "status": "PASS",
        "duration_ms": 0.5616900000022724
      },
      {
        "id": "FE-SET-G-005",
        "status": "PASS",
        "duration_ms": 0.33360800000082236
      },
      {
        "id": "FE-SET-G-006",
        "status": "PASS",
        "duration_ms": 3123.5159490000005
      },
      {
        "id": "FE-SET-G-007",
        "status": "PASS",
        "duration_ms": 1.083137000001443
      },
      {
        "id": "FE-SET-G-008",
        "status": "PASS",
        "duration_ms": 0.29025799999726587
      },
      {
        "id": "FE-SET-G-009",
        "status": "PASS",
        "duration_ms": 0.5906849999992119
      },
      {
        "id": "FE-SET-G-010",
        "status": "PASS",
        "duration_ms": 0.3717290000022331
      },
      {
        "id": "FE-SET-G-011",
        "status": "PASS",
        "duration_ms": 0.309252999999444
      },
      {
        "id": "FE-SET-G-012",
        "status": "PASS",
        "duration_ms": 0.24670699999842327
      },
      {
        "id": "FE-SET-G-013",
        "status": "PASS",
        "duration_ms": 0.24501500000042142
      },
      {
        "id": "FE-SET-G-014",
        "status": "PASS",
        "duration_ms": 0.3134910000007949
      },
      {
        "id": "FE-SET-G-015",
        "status": "PASS",
        "duration_ms": 0.32719599999836646
      },
      {
        "id": "FE-SET-S-001",
        "status": "PASS",
        "duration_ms": 4857.113355000001
      },
      {
        "id": "FE-SET-S-002",
        "status": "PASS",
        "duration_ms": 0.8582189999979164
      },
      {
        "id": "FE-SET-S-003",
        "status": "PASS",
        "duration_ms": 0.2631080000028305
      },
      {
        "id": "FE-SET-S-004",
        "status": "PASS",
        "duration_ms": 0.1743830000013986
      },
      {
        "id": "FE-SET-S-005",
        "status": "PASS",
        "duration_ms": 0.5408319999987725
      },
      {
        "id": "FE-SET-S-006",
        "status": "PASS",
        "duration_ms": 0.3066689999977825
      },
      {
        "id": "FE-SET-S-007",
        "status": "PASS",
        "duration_ms": 0.19455099999686354
      },
      {
        "id": "FE-SET-M-001",
        "status": "PASS",
        "duration_ms": 5671.680326000005
      },
      {
        "id": "FE-SET-M-002",
        "status": "PASS",
        "duration_ms": 0.4577770000032615
      },
      {
        "id": "FE-SET-M-003",
        "status": "PASS",
        "duration_ms": 0.2719539999961853
      },
      {
        "id": "FE-SET-M-004",
        "status": "PASS",
        "duration_ms": 1.0995379999949364
      },
      {
        "id": "FE-SET-M-005",
        "status": "PASS",
        "duration_ms": 0.2132259999998496
      },
      {
        "id": "FE-SET-M-006",
        "status": "PASS",
        "duration_ms": 0.23416400000132853
      },
      {
        "id": "FE-USER-001",
        "status": "PASS",
        "duration_ms": 7255.632390999999
      },
      {
        "id": "FE-USER-002",
        "status": "PASS",
        "duration_ms": 6261.8386859999955
      },
      {
        "id": "FE-USER-003",
        "status": "PASS",
        "duration_ms": 2.3322320000006584
      },
      {
        "id": "FE-USER-004",
        "status": "PASS",
        "duration_ms": 0.47252700000535697
      },
      {
        "id": "FE-USER-005",
        "status": "PASS",
        "duration_ms": 0.2880540000041947
      },
      {
        "id": "FE-USER-006",
        "status": "PASS",
        "duration_ms": 0.22087000000465196
      },
      {
        "id": "FE-PHONE-001",
        "status": "PASS",
        "duration_ms": 6952.255784999999
      },
      {
        "id": "FE-PHONE-002",
        "status": "PASS",
        "duration_ms": 9110.763769000001
      },
      {
        "id": "FE-PHONE-003",
        "status": "PASS",
        "duration_ms": 5377.278464999999
      },
      {
        "id": "FE-PHONE-004",
        "status": "PASS",
        "duration_ms": 4230.933731999998
      },
      {
        "id": "FE-PHONE-005",
        "status": "PASS",
        "duration_ms": 0.5274329999992915
      },
      {
        "id": "FE-PHONE-006",
        "status": "PASS",
        "duration_ms": 0.5481619999991381
      },
      {
        "id": "FE-PHONE-007",
        "status": "PASS",
        "duration_ms": 1.318437999998423
      },
      {
        "id": "FE-PHONE-008",
        "status": "PASS",
        "duration_ms": 0.2914230000023963
      },
      {
        "id": "FE-PHONE-009",
        "status": "PASS",
        "duration_ms": 0.3795170000012149
      },
      {
        "id": "FE-SMS-TOKY-001",
        "status": "PASS",
        "duration_ms": 4.1964620000001105
      },
      {
        "id": "FE-SMS-TOKY-002",
        "status": "PASS",
        "duration_ms": 1.2128399999999147
      },
      {
        "id": "FE-SMS-TOKY-003",
        "status": "PASS",
        "duration_ms": 0.36877700000013647
      },
      {
        "id": "FE-SMS-TOKY-004",
        "status": "PASS",
        "duration_ms": 0.29415900000003603
      },
      {
        "id": "FE-SMS-TOKY-005",
        "status": "PASS",
        "duration_ms": 0.19439200000010715
      },
      {
        "id": "FE-SMS-TOKY-006",
        "status": "PASS",
        "duration_ms": 0.6843860000001314
      },
      {
        "id": "FE-SMS-TOKY-007",
        "status": "PASS",
        "duration_ms": 0.5485529999998562
      },
      {
        "id": "FE-SMS-TOKY-008",
        "status": "PASS",
        "duration_ms": 0.30174200000010387
      },
      {
        "id": "FE-SMS-TOKY-009",
        "status": "PASS",
        "duration_ms": 0.4379159999998592
      },
      {
        "id": "FE-SMS-TOKY-010",
        "status": "PASS",
        "duration_ms": 175.57484799999997
      },
      {
        "id": "FE-SMS-TOKY-011",
        "status": "PASS",
        "duration_ms": 0.36011099999996077
      },
      {
        "id": "FE-SMS-TOKY-012",
        "status": "PASS",
        "duration_ms": 0.641365000000178
      },
      {
        "id": "FE-SMS-TOKY-013",
        "status": "PASS",
        "duration_ms": 0.2604149999999663
      },
      {
        "id": "FE-SMS-TOKY-014",
        "status": "PASS",
        "duration_ms": 0.3404440000001614
      },
      {
        "id": "FE-SMS-TOKY-015",
        "status": "PASS",
        "duration_ms": 0.275574000000006
      },
      {
        "id": "FE-SMS-TOKY-016",
        "status": "PASS",
        "duration_ms": 0.7820389999999406
      },
      {
        "id": "FE-SMS-TOKY-017",
        "status": "PASS",
        "duration_ms": 0.3443019999999706
      },
      {
        "id": "FE-SMS-TOKY-018",
        "status": "PASS",
        "duration_ms": 0.22473999999988337
      },
      {
        "id": "FE-SMS-TOKY-019",
        "status": "PASS",
        "duration_ms": 0.23730199999999968
      },
      {
        "id": "FE-SMS-TOKY-020",
        "status": "PASS",
        "duration_ms": 0.340012999999999
      },
      {
        "id": "FE-SMS-TW-001",
        "status": "PASS",
        "duration_ms": 2.56910199999993
      },
      {
        "id": "FE-SMS-TW-002",
        "status": "PASS",
        "duration_ms": 1.9339570000001913
      },
      {
        "id": "FE-SMS-TW-003",
        "status": "PASS",
        "duration_ms": 2.6089059999999336
      },
      {
        "id": "FE-SMS-TW-004",
        "status": "PASS",
        "duration_ms": 1.313579000000118
      },
      {
        "id": "FE-SMS-TW-005",
        "status": "PASS",
        "duration_ms": 0.6638880000000427
      },
      {
        "id": "FE-SMS-TW-006",
        "status": "PASS",
        "duration_ms": 0.45949800000016694
      },
      {
        "id": "FE-SMS-TW-007",
        "status": "PASS",
        "duration_ms": 0.4966660000000047
      },
      {
        "id": "FE-SMS-TW-008",
        "status": "PASS",
        "duration_ms": 0.2875659999999698
      },
      {
        "id": "FE-SMS-TW-009",
        "status": "PASS",
        "duration_ms": 3.6623400000000856
      },
      {
        "id": "FE-SMS-TW-010",
        "status": "PASS",
        "duration_ms": 0.8160609999999906
      },
      {
        "id": "FE-SMS-TW-011",
        "status": "PASS",
        "duration_ms": 225.98704700000008
      },
      {
        "id": "FE-SMS-TW-012",
        "status": "PASS",
        "duration_ms": 0.30472899999995207
      },
      {
        "id": "FE-ACT-VM-001",
        "status": "PASS",
        "duration_ms": 2887.3687149999996
      },
      {
        "id": "FE-ACT-VM-002",
        "status": "PASS",
        "duration_ms": 2.145195000000058
      },
      {
        "id": "FE-ACT-VM-003",
        "status": "PASS",
        "duration_ms": 0.6138380000002144
      },
      {
        "id": "FE-ACT-VM-004",
        "status": "PASS",
        "duration_ms": 0.343656999999439
      },
      {
        "id": "FE-ACT-VM-005",
        "status": "PASS",
        "duration_ms": 0.35897599999952945
      },
      {
        "id": "FE-ACT-VM-006",
        "status": "PASS",
        "duration_ms": 0.628935000000638
      },
      {
        "id": "FE-ACT-VM-007",
        "status": "PASS",
        "duration_ms": 0.3651060000001962
      },
      {
        "id": "FE-ACT-AIC-001",
        "status": "PASS",
        "duration_ms": 1185.4655590000002
      },
      {
        "id": "FE-ACT-AIC-002",
        "status": "PASS",
        "duration_ms": 1.2703950000004625
      },
      {
        "id": "FE-ACT-AIC-003",
        "status": "PASS",
        "duration_ms": 0.3585349999993923
      },
      {
        "id": "FE-ACT-AIC-004",
        "status": "PASS",
        "duration_ms": 0.2670850000004066
      },
      {
        "id": "FE-ACT-AIC-005",
        "status": "PASS",
        "duration_ms": 0.20865799999955925
      },
      {
        "id": "FE-ACT-BBS-001",
        "status": "PASS",
        "duration_ms": 1574.219099
      },
      {
        "id": "FE-ACT-BBS-002",
        "status": "PASS",
        "duration_ms": 0.3721800000002986
      },
      {
        "id": "FE-ACT-BBS-003",
        "status": "PASS",
        "duration_ms": 0.23295099999995728
      },
      {
        "id": "FE-ACT-PD-001",
        "status": "PASS",
        "duration_ms": 1778.7934990000012
      },
      {
        "id": "FE-ACT-PD-002",
        "status": "PASS",
        "duration_ms": 0.3071190000009665
      },
      {
        "id": "FE-ACT-PD-003",
        "status": "PASS",
        "duration_ms": 0.4022560000012163
      },
      {
        "id": "FE-ACT-PD-004",
        "status": "PASS",
        "duration_ms": 0.14849499999945692
      },
      {
        "id": "FE-ACT-PD-005",
        "status": "PASS",
        "duration_ms": 0.18601499999931548
      },
      {
        "id": "UNKNOWN-ant6ek",
        "status": "PASS",
        "duration_ms": 1135.4203870000001
      },
      {
        "id": "UNKNOWN-aajcx3",
        "status": "PASS",
        "duration_ms": 0.4400160000004689
      },
      {
        "id": "UNKNOWN-s1om1c",
        "status": "PASS",
        "duration_ms": 2.925130999999965
      },
      {
        "id": "UNKNOWN-5qo0tk",
        "status": "PASS",
        "duration_ms": 3.3086719999992056
      },
      {
        "id": "FE-ACT-SF-001",
        "status": "PASS",
        "duration_ms": 1659.4734649999991
      },
      {
        "id": "FE-ACT-SF-002",
        "status": "PASS",
        "duration_ms": 2.2451709999986633
      },
      {
        "id": "FE-ACT-SF-003",
        "status": "PASS",
        "duration_ms": 1.3771109999997861
      },
      {
        "id": "FE-ACT-SF-004",
        "status": "PASS",
        "duration_ms": 0.21347700000114855
      },
      {
        "id": "FE-VM-001",
        "status": "PASS",
        "duration_ms": 5228.453064
      },
      {
        "id": "FE-VM-002",
        "status": "PASS",
        "duration_ms": 1.062300999999934
      },
      {
        "id": "FE-VM-003",
        "status": "PASS",
        "duration_ms": 0.5551359999999477
      },
      {
        "id": "FE-VM-004",
        "status": "PASS",
        "duration_ms": 0.5500650000003589
      },
      {
        "id": "FE-VM-005",
        "status": "PASS",
        "duration_ms": 0.603345000000445
      },
      {
        "id": "FE-VM-006",
        "status": "PASS",
        "duration_ms": 0.5097799999994095
      }
    ]
  },
  "results": [
    {
      "id": "FE-ACT-001",
      "description": "Outbound SMS produces 'SMS Sent' activity (smoke)",
      "status": "PASS",
      "duration_ms": 2.626749000000018,
      "file_path": "/app/runner/tests/activity/fe-activity.test.ts",
      "test_path": "tests/activity/fe-activity.test.ts > Activity feed (FE-ACT) > FE-ACT-001 — Outbound SMS produces 'SMS Sent' activity (smoke)"
    },
    {
      "id": "FE-ACT-002",
      "description": "Inbound SMS produces 'SMS Received' activity (smoke)",
      "status": "PASS",
      "duration_ms": 0.40428399999996145,
      "file_path": "/app/runner/tests/activity/fe-activity.test.ts",
      "test_path": "tests/activity/fe-activity.test.ts > Activity feed (FE-ACT) > FE-ACT-002 — Inbound SMS produces 'SMS Received' activity (smoke)"
    },
    {
      "id": "FE-ACT-003",
      "description": "Email sent produces 'Email Sent' activity (smoke)",
      "status": "PASS",
      "duration_ms": 0.34544400000004316,
      "file_path": "/app/runner/tests/activity/fe-activity.test.ts",
      "test_path": "tests/activity/fe-activity.test.ts > Activity feed (FE-ACT) > FE-ACT-003 — Email sent produces 'Email Sent' activity (smoke)"
    },
    {
      "id": "FE-ACT-004",
      "description": "Email received produces 'Email Received' activity (smoke)",
      "status": "PASS",
      "duration_ms": 0.32468599999992875,
      "file_path": "/app/runner/tests/activity/fe-activity.test.ts",
      "test_path": "tests/activity/fe-activity.test.ts > Activity feed (FE-ACT) > FE-ACT-004 — Email received produces 'Email Received' activity (smoke)"
    },
    {
      "id": "FE-ACT-005",
      "description": "A2P brand approved produces activity (smoke)",
      "status": "PASS",
      "duration_ms": 0.3366070000001855,
      "file_path": "/app/runner/tests/activity/fe-activity.test.ts",
      "test_path": "tests/activity/fe-activity.test.ts > Activity feed (FE-ACT) > FE-ACT-005 — A2P brand approved produces activity (smoke)"
    },
    {
      "id": "FE-ACT-006",
      "description": "Phone purchase produces 'Phone Number Purchased' (smoke)",
      "status": "PASS",
      "duration_ms": 0.43905900000004294,
      "file_path": "/app/runner/tests/activity/fe-activity.test.ts",
      "test_path": "tests/activity/fe-activity.test.ts > Activity feed (FE-ACT) > FE-ACT-006 — Phone purchase produces 'Phone Number Purchased' (smoke)"
    },
    {
      "id": "FE-ACT-007",
      "description": "Toky import produces 'Phone Number Imported' (smoke)",
      "status": "PASS",
      "duration_ms": 0.6378090000000611,
      "file_path": "/app/runner/tests/activity/fe-activity.test.ts",
      "test_path": "tests/activity/fe-activity.test.ts > Activity feed (FE-ACT) > FE-ACT-007 — Toky import produces 'Phone Number Imported' (smoke)"
    },
    {
      "id": "FE-ACT-008",
      "description": "Deal-loss negative-sentiment activity (smoke)",
      "status": "PASS",
      "duration_ms": 0.28792700000008153,
      "file_path": "/app/runner/tests/activity/fe-activity.test.ts",
      "test_path": "tests/activity/fe-activity.test.ts > Activity feed (FE-ACT) > FE-ACT-008 — Deal-loss negative-sentiment activity (smoke)"
    },
    {
      "id": "FE-ACT-009",
      "description": "Stage processing failure activity (smoke)",
      "status": "PASS",
      "duration_ms": 0.5589230000000498,
      "file_path": "/app/runner/tests/activity/fe-activity.test.ts",
      "test_path": "tests/activity/fe-activity.test.ts > Activity feed (FE-ACT) > FE-ACT-009 — Stage processing failure activity (smoke)"
    },
    {
      "id": "FE-ACT-010",
      "description": "Activities mark-read endpoints respond",
      "status": "PASS",
      "duration_ms": 1480.628887,
      "file_path": "/app/runner/tests/activity/fe-activity.test.ts",
      "test_path": "tests/activity/fe-activity.test.ts > Activity feed (FE-ACT) > FE-ACT-010 — Activities mark-read endpoints respond"
    },
    {
      "id": "FE-ACT-011",
      "description": "Activity feed scoped to current account_id (smoke)",
      "status": "PASS",
      "duration_ms": 0.5042109999999411,
      "file_path": "/app/runner/tests/activity/fe-activity.test.ts",
      "test_path": "tests/activity/fe-activity.test.ts > Activity feed (FE-ACT) > FE-ACT-011 — Activity feed scoped to current account_id (smoke)"
    },
    {
      "id": "FE-ADM-001",
      "description": "/admin/dashboard renders without crashing",
      "status": "FAIL",
      "duration_ms": 61000.018701,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin (FE-ADM) > FE-ADM-001 — /admin/dashboard renders without crashing",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 7m24s\",\"retry_after_seconds\":444,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-ADM-003",
      "description": "/admin/billing renders without crashing",
      "status": "FAIL",
      "duration_ms": 60380.52343000001,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin (FE-ADM) > FE-ADM-003 — /admin/billing renders without crashing",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 6m24s\",\"retry_after_seconds\":384,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-ADM-004",
      "description": "/admin/billing/clients renders without crashing",
      "status": "FAIL",
      "duration_ms": 60364.031010000006,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin (FE-ADM) > FE-ADM-004 — /admin/billing/clients renders without crashing",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 5m23s\",\"retry_after_seconds\":323,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-ADM-005",
      "description": "/admin/billing/payments renders without crashing",
      "status": "FAIL",
      "duration_ms": 60288.692396,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin (FE-ADM) > FE-ADM-005 — /admin/billing/payments renders without crashing",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 4m23s\",\"retry_after_seconds\":263,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-ADM-006",
      "description": "/admin/campaigns renders without crashing",
      "status": "FAIL",
      "duration_ms": 60213.78867799998,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin (FE-ADM) > FE-ADM-006 — /admin/campaigns renders without crashing",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 3m23s\",\"retry_after_seconds\":203,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-ADM-007",
      "description": "/admin/campaigns/analytics renders without crashing",
      "status": "FAIL",
      "duration_ms": 60235.870748999994,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin (FE-ADM) > FE-ADM-007 — /admin/campaigns/analytics renders without crashing",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 2m23s\",\"retry_after_seconds\":143,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-ADM-008",
      "description": "/admin/campaigns/templates renders without crashing",
      "status": "FAIL",
      "duration_ms": 60157.96798800002,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin (FE-ADM) > FE-ADM-008 — /admin/campaigns/templates renders without crashing",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 1m22s\",\"retry_after_seconds\":82,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-ADM-012",
      "description": "/admin/pricing/plans renders without crashing",
      "status": "FAIL",
      "duration_ms": 60276.583132,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin (FE-ADM) > FE-ADM-012 — /admin/pricing/plans renders without crashing",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 22s\",\"retry_after_seconds\":22,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-ADM-013",
      "description": "/admin/pricing/plans/create renders without crashing",
      "status": "PASS",
      "duration_ms": 30552.667992000002,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin (FE-ADM) > FE-ADM-013 — /admin/pricing/plans/create renders without crashing"
    },
    {
      "id": "FE-ADM-014",
      "description": "/admin/pricing/promo-codes renders without crashing",
      "status": "PASS",
      "duration_ms": 6300.679562999983,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin (FE-ADM) > FE-ADM-014 — /admin/pricing/promo-codes renders without crashing"
    },
    {
      "id": "FE-ADM-015",
      "description": "/admin/pricing/addons renders without crashing",
      "status": "PASS",
      "duration_ms": 5238.653027000022,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin (FE-ADM) > FE-ADM-015 — /admin/pricing/addons renders without crashing"
    },
    {
      "id": "FE-ADM-016",
      "description": "/admin/user-settings renders without crashing",
      "status": "PASS",
      "duration_ms": 4084.9416829999536,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin (FE-ADM) > FE-ADM-016 — /admin/user-settings renders without crashing"
    },
    {
      "id": "FE-ADM-002",
      "description": "Sidebar shows Billing/Dashboard/Pricing/Campaigns (smoke)",
      "status": "PASS",
      "duration_ms": 11.581730000092648,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin (FE-ADM) > FE-ADM-002 — Sidebar shows Billing/Dashboard/Pricing/Campaigns (smoke)"
    },
    {
      "id": "FE-ADM-017",
      "description": "MEMBER role hits /admin/dashboard → 403 or redirect",
      "status": "PASS",
      "duration_ms": 5671.428245999967,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin (FE-ADM) > FE-ADM-017 — MEMBER role hits /admin/dashboard → 403 or redirect"
    },
    {
      "id": "FE-ADM-018",
      "description": "/admin/* on prod hostname → redirected (skip on staging)",
      "status": "PASS",
      "duration_ms": 0.5390050000278279,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin (FE-ADM) > FE-ADM-018 — /admin/* on prod hostname → redirected (skip on staging)"
    },
    {
      "id": "FE-ADM-PLAN-001",
      "description": "Plans list renders",
      "status": "PASS",
      "duration_ms": 4475.666896000039,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin — Plans CRUD (FE-ADM-PLAN) > FE-ADM-PLAN-001 — Plans list renders"
    },
    {
      "id": "FE-ADM-PLAN-002",
      "description": "Create form validates required fields (smoke)",
      "status": "PASS",
      "duration_ms": 2.102792000048794,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin — Plans CRUD (FE-ADM-PLAN) > FE-ADM-PLAN-002 — Create form validates required fields (smoke)"
    },
    {
      "id": "FE-ADM-PLAN-003",
      "description": "POST /v1/admin/plans creates plan (smoke)",
      "status": "PASS",
      "duration_ms": 0.5977150000398979,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin — Plans CRUD (FE-ADM-PLAN) > FE-ADM-PLAN-003 — POST /v1/admin/plans creates plan (smoke)"
    },
    {
      "id": "FE-ADM-PLAN-004",
      "description": "PUT updates plan, public endpoint reflects (smoke)",
      "status": "PASS",
      "duration_ms": 0.2902720000129193,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin — Plans CRUD (FE-ADM-PLAN) > FE-ADM-PLAN-004 — PUT updates plan, public endpoint reflects (smoke)"
    },
    {
      "id": "FE-ADM-PLAN-005",
      "description": "Delete with active subs → friendly block (smoke)",
      "status": "PASS",
      "duration_ms": 0.23355500004254282,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin — Plans CRUD (FE-ADM-PLAN) > FE-ADM-PLAN-005 — Delete with active subs → friendly block (smoke)"
    },
    {
      "id": "FE-ADM-PLAN-006",
      "description": "Delete unused plan succeeds (smoke)",
      "status": "PASS",
      "duration_ms": 0.2412890000268817,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin — Plans CRUD (FE-ADM-PLAN) > FE-ADM-PLAN-006 — Delete unused plan succeeds (smoke)"
    },
    {
      "id": "FE-ADM-ADDON-001",
      "description": "Add-ons list renders",
      "status": "PASS",
      "duration_ms": 3547.4889060000423,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin — Add-ons CRUD (FE-ADM-ADDON) > FE-ADM-ADDON-001 — Add-ons list renders"
    },
    {
      "id": "FE-ADM-ADDON-002",
      "description": "Create requires name/price/scope (smoke)",
      "status": "PASS",
      "duration_ms": 0.7550380000611767,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin — Add-ons CRUD (FE-ADM-ADDON) > FE-ADM-ADDON-002 — Create requires name/price/scope (smoke)"
    },
    {
      "id": "FE-ADM-ADDON-003",
      "description": "Created add-on appears in public list (smoke)",
      "status": "PASS",
      "duration_ms": 0.25779999990481883,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin — Add-ons CRUD (FE-ADM-ADDON) > FE-ADM-ADDON-003 — Created add-on appears in public list (smoke)"
    },
    {
      "id": "FE-ADM-ADDON-004",
      "description": "Update price reflects on /settings/manage-plans (smoke)",
      "status": "PASS",
      "duration_ms": 0.22266600001603365,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin — Add-ons CRUD (FE-ADM-ADDON) > FE-ADM-ADDON-004 — Update price reflects on /settings/manage-plans (smoke)"
    },
    {
      "id": "FE-ADM-ADDON-005",
      "description": "Delete blocked when subs active (smoke)",
      "status": "PASS",
      "duration_ms": 0.20551299990620464,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin — Add-ons CRUD (FE-ADM-ADDON) > FE-ADM-ADDON-005 — Delete blocked when subs active (smoke)"
    },
    {
      "id": "FE-ADM-PROMO-001",
      "description": "Promo list shows discount/expiry/usage",
      "status": "PASS",
      "duration_ms": 3519.4236060000258,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin — Promo codes CRUD (FE-ADM-PROMO) > FE-ADM-PROMO-001 — Promo list shows discount/expiry/usage"
    },
    {
      "id": "FE-ADM-PROMO-002",
      "description": "Create 100% code applies on signup (smoke)",
      "status": "PASS",
      "duration_ms": 0.4804149999981746,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin — Promo codes CRUD (FE-ADM-PROMO) > FE-ADM-PROMO-002 — Create 100% code applies on signup (smoke)"
    },
    {
      "id": "FE-ADM-PROMO-003",
      "description": "Past-expiry code returns expired (smoke)",
      "status": "PASS",
      "duration_ms": 0.20685499999672174,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin — Promo codes CRUD (FE-ADM-PROMO) > FE-ADM-PROMO-003 — Past-expiry code returns expired (smoke)"
    },
    {
      "id": "FE-ADM-PROMO-004",
      "description": "Usage cap enforced (smoke)",
      "status": "PASS",
      "duration_ms": 0.19156800000928342,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin — Promo codes CRUD (FE-ADM-PROMO) > FE-ADM-PROMO-004 — Usage cap enforced (smoke)"
    },
    {
      "id": "FE-ADM-PROMO-005",
      "description": "Delete cleanly removes (smoke)",
      "status": "PASS",
      "duration_ms": 0.21804599999450147,
      "file_path": "/app/runner/tests/admin/fe-admin.test.ts",
      "test_path": "tests/admin/fe-admin.test.ts > Admin — Promo codes CRUD (FE-ADM-PROMO) > FE-ADM-PROMO-005 — Delete cleanly removes (smoke)"
    },
    {
      "id": "FE-AI-001",
      "description": "/automation-campaign/[id] shows AI personalization toggle",
      "status": "FAIL",
      "duration_ms": 62326.845113,
      "file_path": "/app/runner/tests/ai/fe-ai.test.ts",
      "test_path": "tests/ai/fe-ai.test.ts > AI personalization (FE-AI) > FE-AI-001 — /automation-campaign/[id] shows AI personalization toggle",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 8m29s\",\"retry_after_seconds\":509,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-AI-002",
      "description": "Toggle ON opens cost modal + persists (smoke)",
      "status": "PASS",
      "duration_ms": 5.593544000003021,
      "file_path": "/app/runner/tests/ai/fe-ai.test.ts",
      "test_path": "tests/ai/fe-ai.test.ts > AI personalization (FE-AI) > FE-AI-002 — Toggle ON opens cost modal + persists (smoke)"
    },
    {
      "id": "FE-AI-003",
      "description": "Toggle OFF flips back, banner disappears (smoke)",
      "status": "PASS",
      "duration_ms": 0.5091269999975339,
      "file_path": "/app/runner/tests/ai/fe-ai.test.ts",
      "test_path": "tests/ai/fe-ai.test.ts > AI personalization (FE-AI) > FE-AI-003 — Toggle OFF flips back, banner disappears (smoke)"
    },
    {
      "id": "FE-AI-004",
      "description": "Test-Email button disabled when AI flag OFF (smoke)",
      "status": "PASS",
      "duration_ms": 0.6197430000029271,
      "file_path": "/app/runner/tests/ai/fe-ai.test.ts",
      "test_path": "tests/ai/fe-ai.test.ts > AI personalization (FE-AI) > FE-AI-004 — Test-Email button disabled when AI flag OFF (smoke)"
    },
    {
      "id": "FE-AI-005",
      "description": "Personalised stage email differs from template (smoke)",
      "status": "PASS",
      "duration_ms": 0.5440820000003441,
      "file_path": "/app/runner/tests/ai/fe-ai.test.ts",
      "test_path": "tests/ai/fe-ai.test.ts > AI personalization (FE-AI) > FE-AI-005 — Personalised stage email differs from template (smoke)"
    },
    {
      "id": "FE-AI-006",
      "description": "AI flag OFF sends literal template (smoke)",
      "status": "PASS",
      "duration_ms": 0.4138410000014119,
      "file_path": "/app/runner/tests/ai/fe-ai.test.ts",
      "test_path": "tests/ai/fe-ai.test.ts > AI personalization (FE-AI) > FE-AI-006 — AI flag OFF sends literal template (smoke)"
    },
    {
      "id": "FE-AI-007",
      "description": "AI ON + empty goal → fallback to template (smoke)",
      "status": "PASS",
      "duration_ms": 0.3289420000000973,
      "file_path": "/app/runner/tests/ai/fe-ai.test.ts",
      "test_path": "tests/ai/fe-ai.test.ts > AI personalization (FE-AI) > FE-AI-007 — AI ON + empty goal → fallback to template (smoke)"
    },
    {
      "id": "FE-AI-008",
      "description": "AI ON + empty offering → fallback (smoke)",
      "status": "PASS",
      "duration_ms": 0.7060629999978119,
      "file_path": "/app/runner/tests/ai/fe-ai.test.ts",
      "test_path": "tests/ai/fe-ai.test.ts > AI personalization (FE-AI) > FE-AI-008 — AI ON + empty offering → fallback (smoke)"
    },
    {
      "id": "FE-AI-009",
      "description": "Stage SMS with AI ON personalises body (smoke)",
      "status": "PASS",
      "duration_ms": 0.3002679999990505,
      "file_path": "/app/runner/tests/ai/fe-ai.test.ts",
      "test_path": "tests/ai/fe-ai.test.ts > AI personalization (FE-AI) > FE-AI-009 — Stage SMS with AI ON personalises body (smoke)"
    },
    {
      "id": "FE-AI-010",
      "description": "AI runs before merge-tag rendering (smoke)",
      "status": "PASS",
      "duration_ms": 4.630313000001479,
      "file_path": "/app/runner/tests/ai/fe-ai.test.ts",
      "test_path": "tests/ai/fe-ai.test.ts > AI personalization (FE-AI) > FE-AI-010 — AI runs before merge-tag rendering (smoke)"
    },
    {
      "id": "FE-AI-011",
      "description": "generate_ai_variants switch hidden in prod (smoke)",
      "status": "PASS",
      "duration_ms": 1.0270700000037323,
      "file_path": "/app/runner/tests/ai/fe-ai.test.ts",
      "test_path": "tests/ai/fe-ai.test.ts > AI personalization (FE-AI) > FE-AI-011 — generate_ai_variants switch hidden in prod (smoke)"
    },
    {
      "id": "FE-AI-012",
      "description": "ai-agent /health endpoint reports OpenAI connectivity",
      "status": "PASS",
      "duration_ms": 1083.5894150000022,
      "file_path": "/app/runner/tests/ai/fe-ai.test.ts",
      "test_path": "tests/ai/fe-ai.test.ts > AI personalization (FE-AI) > FE-AI-012 — ai-agent /health endpoint reports OpenAI connectivity"
    },
    {
      "id": "FE-AI-013",
      "description": "Inbound sentiment runs regardless of AI flag (smoke)",
      "status": "PASS",
      "duration_ms": 0.3334099999992759,
      "file_path": "/app/runner/tests/ai/fe-ai.test.ts",
      "test_path": "tests/ai/fe-ai.test.ts > AI personalization (FE-AI) > FE-AI-013 — Inbound sentiment runs regardless of AI flag (smoke)"
    },
    {
      "id": "FE-AI-014",
      "description": "Heuristic infers NEGATIVE on 'unsubscribe' fast (smoke)",
      "status": "PASS",
      "duration_ms": 0.41507199999614386,
      "file_path": "/app/runner/tests/ai/fe-ai.test.ts",
      "test_path": "tests/ai/fe-ai.test.ts > AI personalization (FE-AI) > FE-AI-014 — Heuristic infers NEGATIVE on 'unsubscribe' fast (smoke)"
    },
    {
      "id": "FE-AI-015",
      "description": "Heuristic falls through to OpenAI (smoke)",
      "status": "PASS",
      "duration_ms": 0.3578750000015134,
      "file_path": "/app/runner/tests/ai/fe-ai.test.ts",
      "test_path": "tests/ai/fe-ai.test.ts > AI personalization (FE-AI) > FE-AI-015 — Heuristic falls through to OpenAI (smoke)"
    },
    {
      "id": "FE-AI-016",
      "description": "OpenAI failure retries 5 times → sentiment NONE (smoke)",
      "status": "PASS",
      "duration_ms": 0.3514740000027814,
      "file_path": "/app/runner/tests/ai/fe-ai.test.ts",
      "test_path": "tests/ai/fe-ai.test.ts > AI personalization (FE-AI) > FE-AI-016 — OpenAI failure retries 5 times → sentiment NONE (smoke)"
    },
    {
      "id": "FE-AI-017",
      "description": "sentiment-webhook from public internet must require auth",
      "status": "PASS",
      "duration_ms": 538.5058159999971,
      "file_path": "/app/runner/tests/ai/fe-ai.test.ts",
      "test_path": "tests/ai/fe-ai.test.ts > AI personalization (FE-AI) > FE-AI-017 — sentiment-webhook from public internet must require auth"
    },
    {
      "id": "FE-AI-018",
      "description": "Credit balance drops by AI rate after personalised send (smoke)",
      "status": "PASS",
      "duration_ms": 0.3994830000010552,
      "file_path": "/app/runner/tests/ai/fe-ai.test.ts",
      "test_path": "tests/ai/fe-ai.test.ts > AI personalization (FE-AI) > FE-AI-018 — Credit balance drops by AI rate after personalised send (smoke)"
    },
    {
      "id": "FE-AI-019",
      "description": "Toky + AI charges AI credits, not phone (smoke)",
      "status": "PASS",
      "duration_ms": 7.533061000001908,
      "file_path": "/app/runner/tests/ai/fe-ai.test.ts",
      "test_path": "tests/ai/fe-ai.test.ts > AI personalization (FE-AI) > FE-AI-019 — Toky + AI charges AI credits, not phone (smoke)"
    },
    {
      "id": "FE-AI-020",
      "description": "cleanup-old-prompts endpoint exists at both legacy and /v1 paths",
      "status": "PASS",
      "duration_ms": 272.918565999993,
      "file_path": "/app/runner/tests/ai/fe-ai.test.ts",
      "test_path": "tests/ai/fe-ai.test.ts > AI personalization (FE-AI) > FE-AI-020 — cleanup-old-prompts endpoint exists at both legacy and /v1 paths"
    },
    {
      "id": "FE-AUTH-021",
      "description": "rapid wrong-password attempts on a unique email return 429 within budget",
      "status": "NOT_EXEC",
      "duration_ms": 0,
      "file_path": "/app/runner/tests/auth/fe-auth-ratelimit.test.ts",
      "test_path": "tests/auth/fe-auth-ratelimit.test.ts > BFF Login Rate Limiter (FE-AUTH) [soak-only] > FE-AUTH-021 — rapid wrong-password attempts on a unique email return 429 within budget"
    },
    {
      "id": "FE-AUTH-022",
      "description": "429 response carries a friendly message + retry hint, no internals leaked",
      "status": "NOT_EXEC",
      "duration_ms": 0,
      "file_path": "/app/runner/tests/auth/fe-auth-ratelimit.test.ts",
      "test_path": "tests/auth/fe-auth-ratelimit.test.ts > BFF Login Rate Limiter (FE-AUTH) [soak-only] > FE-AUTH-022 — 429 response carries a friendly message + retry hint, no internals leaked"
    },
    {
      "id": "FE-AUTH-023",
      "description": "rate limit is scoped per-email (different fakes don't share budget)",
      "status": "NOT_EXEC",
      "duration_ms": 0,
      "file_path": "/app/runner/tests/auth/fe-auth-ratelimit.test.ts",
      "test_path": "tests/auth/fe-auth-ratelimit.test.ts > BFF Login Rate Limiter (FE-AUTH) [soak-only] > FE-AUTH-023 — rate limit is scoped per-email (different fakes don't share budget)"
    },
    {
      "id": "FE-AUTH-001",
      "description": "/login page renders with email + password + Forgot Password + Login + Register link",
      "status": "PASS",
      "duration_ms": 2065.6520750000004,
      "file_path": "/app/runner/tests/auth/fe-auth.test.ts",
      "test_path": "tests/auth/fe-auth.test.ts > Authentication (FE-AUTH) > FE-AUTH-001 — /login page renders with email + password + Forgot Password + Login + Register link"
    },
    {
      "id": "FE-AUTH-002",
      "description": "Login with valid credentials → redirect to /automation-campaign",
      "status": "PASS",
      "duration_ms": 3386.997386,
      "file_path": "/app/runner/tests/auth/fe-auth.test.ts",
      "test_path": "tests/auth/fe-auth.test.ts > Authentication (FE-AUTH) > FE-AUTH-002 — Login with valid credentials → redirect to /automation-campaign"
    },
    {
      "id": "FE-AUTH-003",
      "description": "Login with wrong password → friendly error, no stack trace",
      "status": "PASS",
      "duration_ms": 293.52299700000003,
      "file_path": "/app/runner/tests/auth/fe-auth.test.ts",
      "test_path": "tests/auth/fe-auth.test.ts > Authentication (FE-AUTH) > FE-AUTH-003 — Login with wrong password → friendly error, no stack trace"
    },
    {
      "id": "FE-AUTH-004",
      "description": "Login with non-existent email → generic friendly error (no enumeration)",
      "status": "PASS",
      "duration_ms": 232.22619200000008,
      "file_path": "/app/runner/tests/auth/fe-auth.test.ts",
      "test_path": "tests/auth/fe-auth.test.ts > Authentication (FE-AUTH) > FE-AUTH-004 — Login with non-existent email → generic friendly error (no enumeration)"
    },
    {
      "id": "FE-AUTH-005",
      "description": "Login with empty fields → form validation errors",
      "status": "PASS",
      "duration_ms": 2590.625336000001,
      "file_path": "/app/runner/tests/auth/fe-auth.test.ts",
      "test_path": "tests/auth/fe-auth.test.ts > Authentication (FE-AUTH) > FE-AUTH-005 — Login with empty fields → form validation errors"
    },
    {
      "id": "FE-AUTH-006",
      "description": "Eye icon on password field toggles show/hide",
      "status": "PASS",
      "duration_ms": 1880.7082730000002,
      "file_path": "/app/runner/tests/auth/fe-auth.test.ts",
      "test_path": "tests/auth/fe-auth.test.ts > Authentication (FE-AUTH) > FE-AUTH-006 — Eye icon on password field toggles show/hide"
    },
    {
      "id": "FE-AUTH-007",
      "description": "Forgot Password link → /forgot-password page renders",
      "status": "PASS",
      "duration_ms": 3499.423852,
      "file_path": "/app/runner/tests/auth/fe-auth.test.ts",
      "test_path": "tests/auth/fe-auth.test.ts > Authentication (FE-AUTH) > FE-AUTH-007 — Forgot Password link → /forgot-password page renders"
    },
    {
      "id": "FE-AUTH-008",
      "description": "Submit forgot password form with valid email → success message",
      "status": "PASS",
      "duration_ms": 302.5789189999996,
      "file_path": "/app/runner/tests/auth/fe-auth.test.ts",
      "test_path": "tests/auth/fe-auth.test.ts > Authentication (FE-AUTH) > FE-AUTH-008 — Submit forgot password form with valid email → success message"
    },
    {
      "id": "FE-AUTH-009",
      "description": "Submit forgot password with non-existent email → generic success (anti-enumeration)",
      "status": "PASS",
      "duration_ms": 127.8990679999988,
      "file_path": "/app/runner/tests/auth/fe-auth.test.ts",
      "test_path": "tests/auth/fe-auth.test.ts > Authentication (FE-AUTH) > FE-AUTH-009 — Submit forgot password with non-existent email → generic success (anti-enumeration)"
    },
    {
      "id": "FE-AUTH-010",
      "description": "/auth-reset-password?token=invalid → friendly invalid token error",
      "status": "PASS",
      "duration_ms": 73.82850000000326,
      "file_path": "/app/runner/tests/auth/fe-auth.test.ts",
      "test_path": "tests/auth/fe-auth.test.ts > Authentication (FE-AUTH) > FE-AUTH-010 — /auth-reset-password?token=invalid → friendly invalid token error"
    },
    {
      "id": "FE-AUTH-011",
      "description": "/auth-reset-password validates min length and match",
      "status": "PASS",
      "duration_ms": 196.17588199999955,
      "file_path": "/app/runner/tests/auth/fe-auth.test.ts",
      "test_path": "tests/auth/fe-auth.test.ts > Authentication (FE-AUTH) > FE-AUTH-011 — /auth-reset-password validates min length and match"
    },
    {
      "id": "FE-AUTH-012",
      "description": "Sign Out clears cookies and redirects to /login",
      "status": "PASS",
      "duration_ms": 34440.544030000005,
      "file_path": "/app/runner/tests/auth/fe-auth.test.ts",
      "test_path": "tests/auth/fe-auth.test.ts > Authentication (FE-AUTH) > FE-AUTH-012 — Sign Out clears cookies and redirects to /login"
    },
    {
      "id": "FE-AUTH-013",
      "description": "Hard refresh of authenticated page → session restores, no console errors",
      "status": "FAIL",
      "duration_ms": 60465.845379000006,
      "file_path": "/app/runner/tests/auth/fe-auth.test.ts",
      "test_path": "tests/auth/fe-auth.test.ts > Authentication (FE-AUTH) > FE-AUTH-013 — Hard refresh of authenticated page → session restores, no console errors",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 12m40s\",\"retry_after_seconds\":760,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-AUTH-014",
      "description": "Direct nav to authenticated route while logged out → redirects to /login with ?redirect=",
      "status": "PASS",
      "duration_ms": 1475.1288889999996,
      "file_path": "/app/runner/tests/auth/fe-auth.test.ts",
      "test_path": "tests/auth/fe-auth.test.ts > Authentication (FE-AUTH) > FE-AUTH-014 — Direct nav to authenticated route while logged out → redirects to /login with ?redirect="
    },
    {
      "id": "FE-AUTH-015",
      "description": "JWT expires mid-session → next API call triggers refresh; refresh fail → logout",
      "status": "PASS",
      "duration_ms": 377.4656859999959,
      "file_path": "/app/runner/tests/auth/fe-auth.test.ts",
      "test_path": "tests/auth/fe-auth.test.ts > Authentication (FE-AUTH) > FE-AUTH-015 — JWT expires mid-session → next API call triggers refresh; refresh fail → logout"
    },
    {
      "id": "FE-AUTH-016",
      "description": "Login on staging hits staging BFF, NOT prod (FE-BUG-002 regression)",
      "status": "PASS",
      "duration_ms": 7741.903676000002,
      "file_path": "/app/runner/tests/auth/fe-auth.test.ts",
      "test_path": "tests/auth/fe-auth.test.ts > Authentication (FE-AUTH) > FE-AUTH-016 — Login on staging hits staging BFF, NOT prod (FE-BUG-002 regression)"
    },
    {
      "id": "FE-AUTH-017",
      "description": "BFF auth cookies have HttpOnly + Secure + SameSite flags",
      "status": "FAIL",
      "duration_ms": 60542.16321499999,
      "file_path": "/app/runner/tests/auth/fe-auth.test.ts",
      "test_path": "tests/auth/fe-auth.test.ts > Authentication (FE-AUTH) > FE-AUTH-017 — BFF auth cookies have HttpOnly + Secure + SameSite flags",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 11m30s\",\"retry_after_seconds\":690,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-AUTH-018",
      "description": "Open redirect — ?redirect=https://evil.com after login → blocked",
      "status": "FAIL",
      "duration_ms": 60335.49166500001,
      "file_path": "/app/runner/tests/auth/fe-auth.test.ts",
      "test_path": "tests/auth/fe-auth.test.ts > Authentication (FE-AUTH) > FE-AUTH-018 — Open redirect — ?redirect=https://evil.com after login → blocked",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 10m30s\",\"retry_after_seconds\":630,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-AUTH-019",
      "description": "Login button shows loading spinner while authenticating",
      "status": "PASS",
      "duration_ms": 2991.42762100001,
      "file_path": "/app/runner/tests/auth/fe-auth.test.ts",
      "test_path": "tests/auth/fe-auth.test.ts > Authentication (FE-AUTH) > FE-AUTH-019 — Login button shows loading spinner while authenticating"
    },
    {
      "id": "FE-AUTH-020",
      "description": "Rate limiting on /login — rapid wrong-password attempts trigger 429",
      "status": "PASS",
      "duration_ms": 926.6695680000121,
      "file_path": "/app/runner/tests/auth/fe-auth.test.ts",
      "test_path": "tests/auth/fe-auth.test.ts > Authentication (FE-AUTH) > FE-AUTH-020 — Rate limiting on /login — rapid wrong-password attempts trigger 429"
    },
    {
      "id": "FE-REG-001",
      "description": "/signup step 1 renders register form (name, email, password, phone)",
      "status": "PASS",
      "duration_ms": 3279.7896729999998,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-001 — /signup step 1 renders register form (name, email, password, phone)"
    },
    {
      "id": "FE-REG-002",
      "description": "Submit empty form → field validation errors",
      "status": "PASS",
      "duration_ms": 3462.686635,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-002 — Submit empty form → field validation errors"
    },
    {
      "id": "FE-REG-003",
      "description": "Submit with invalid email format → validation error",
      "status": "PASS",
      "duration_ms": 6742.789409999999,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-003 — Submit with invalid email format → validation error"
    },
    {
      "id": "FE-REG-004",
      "description": "Submit with weak password → strength meter + rejection",
      "status": "PASS",
      "duration_ms": 4041.0479629999973,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-004 — Submit with weak password → strength meter + rejection"
    },
    {
      "id": "FE-REG-005",
      "description": "Submit with duplicate email → friendly 'email already registered'",
      "status": "PASS",
      "duration_ms": 586.6560019999997,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-005 — Submit with duplicate email → friendly 'email already registered'"
    },
    {
      "id": "FE-REG-006",
      "description": "Submit valid form → advances to step 2 (Select Plan)",
      "status": "PASS",
      "duration_ms": 22986.715948999998,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-006 — Submit valid form → advances to step 2 (Select Plan)"
    },
    {
      "id": "FE-REG-007",
      "description": "Step 2 shows Pulse Free + Pulse Pro side-by-side",
      "status": "PASS",
      "duration_ms": 1070.5377950000038,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-007 — Step 2 shows Pulse Free + Pulse Pro side-by-side"
    },
    {
      "id": "FE-REG-008",
      "description": "Toggle Monthly / Annually switches plan prices",
      "status": "PASS",
      "duration_ms": 877.7024180000008,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-008 — Toggle Monthly / Annually switches plan prices"
    },
    {
      "id": "FE-REG-009",
      "description": "Click Free Plan → advances to step 4 (Order Information), skipping step 3",
      "status": "PASS",
      "duration_ms": 679.1563139999998,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-009 — Click Free Plan → advances to step 4 (Order Information), skipping step 3"
    },
    {
      "id": "FE-REG-010",
      "description": "Click Pulse Pro → advances to step 3 (Add-ons)",
      "status": "PASS",
      "duration_ms": 2836.508482999998,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-010 — Click Pulse Pro → advances to step 3 (Add-ons)"
    },
    {
      "id": "FE-REG-011",
      "description": "Step 4 (Free Plan) — Total Due $0.00, 'Continue' button (NOT 'Continue to Payment')",
      "status": "PASS",
      "duration_ms": 1908.8574509999962,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-011 — Step 4 (Free Plan) — Total Due $0.00, 'Continue' button (NOT 'Continue to Payment')"
    },
    {
      "id": "FE-REG-012",
      "description": "Step 4 (Free Plan) — promo code field hidden (FE-BUG-001 fix)",
      "status": "PASS",
      "duration_ms": 1313.6668900000004,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-012 — Step 4 (Free Plan) — promo code field hidden (FE-BUG-001 fix)"
    },
    {
      "id": "FE-REG-013",
      "description": "Step 4 (Free Plan) — clicking Continue skips payment form",
      "status": "PASS",
      "duration_ms": 1351.010804999998,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-013 — Step 4 (Free Plan) — clicking Continue skips payment form"
    },
    {
      "id": "FE-REG-014",
      "description": "Step 4 (Paid plan) — Payment Information form shows card fields @paid",
      "status": "NOT_EXEC",
      "duration_ms": 0,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-014 — Step 4 (Paid plan) — Payment Information form shows card fields @paid"
    },
    {
      "id": "FE-REG-015",
      "description": "Step 4 — apply promo code BETAOFFER → 100% discount → label changes @paid",
      "status": "NOT_EXEC",
      "duration_ms": 0,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-015 — Step 4 — apply promo code BETAOFFER → 100% discount → label changes @paid"
    },
    {
      "id": "FE-REG-016",
      "description": "Step 4 — invalid promo code → friendly error @paid",
      "status": "NOT_EXEC",
      "duration_ms": 0,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-016 — Step 4 — invalid promo code → friendly error @paid"
    },
    {
      "id": "FE-REG-017",
      "description": "Step 4 — expired promo code → friendly error @paid",
      "status": "NOT_EXEC",
      "duration_ms": 0,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-017 — Step 4 — expired promo code → friendly error @paid"
    },
    {
      "id": "FE-REG-018",
      "description": "Step 4 — payment form rejects invalid card number @paid",
      "status": "NOT_EXEC",
      "duration_ms": 0,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-018 — Step 4 — payment form rejects invalid card number @paid"
    },
    {
      "id": "FE-REG-019",
      "description": "Step 4 — payment form rejects expired card @paid",
      "status": "NOT_EXEC",
      "duration_ms": 0,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-019 — Step 4 — payment form rejects expired card @paid"
    },
    {
      "id": "FE-REG-020",
      "description": "Step 4 — payment form requires all billing address fields @paid",
      "status": "NOT_EXEC",
      "duration_ms": 0,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-020 — Step 4 — payment form requires all billing address fields @paid"
    },
    {
      "id": "FE-REG-021",
      "description": "Browser back button mid-wizard preserves form state",
      "status": "PASS",
      "duration_ms": 2818.5267719999974,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-021 — Browser back button mid-wizard preserves form state"
    },
    {
      "id": "FE-REG-022",
      "description": "Direct nav to ?step=4 without completing 1-3 → redirects",
      "status": "PASS",
      "duration_ms": 3165.561297,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-022 — Direct nav to ?step=4 without completing 1-3 → redirects"
    },
    {
      "id": "FE-REG-023",
      "description": "Already-authenticated user navigating to /signup → redirects to dashboard",
      "status": "FAIL",
      "duration_ms": 60375.44581499999,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-023 — Already-authenticated user navigating to /signup → redirects to dashboard",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 12m32s\",\"retry_after_seconds\":752,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-REG-024",
      "description": "Wizard step indicator updates correctly per step",
      "status": "PASS",
      "duration_ms": 651.6317950000084,
      "file_path": "/app/runner/tests/auth/fe-reg.test.ts",
      "test_path": "tests/auth/fe-reg.test.ts > Registration wizard (FE-REG) > FE-REG-024 — Wizard step indicator updates correctly per step"
    },
    {
      "id": "FE-SETUP-001",
      "description": "/setup page renders for newly-signed-up users",
      "status": "FAIL",
      "duration_ms": 60636.045085,
      "file_path": "/app/runner/tests/auth/fe-setup.test.ts",
      "test_path": "tests/auth/fe-setup.test.ts > Onboarding / Setup (FE-SETUP) > FE-SETUP-001 — /setup page renders for newly-signed-up users",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 9m24s\",\"retry_after_seconds\":564,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-SETUP-002",
      "description": "Setup wizard captures business profile info (form renders)",
      "status": "PASS",
      "duration_ms": 1263.595727,
      "file_path": "/app/runner/tests/auth/fe-setup.test.ts",
      "test_path": "tests/auth/fe-setup.test.ts > Onboarding / Setup (FE-SETUP) > FE-SETUP-002 — Setup wizard captures business profile info (form renders)"
    },
    {
      "id": "FE-SETUP-003",
      "description": "Skip onboarding via 'Skip for now' → dashboard with welcome modal (skip CTA exists)",
      "status": "FAIL",
      "duration_ms": 60251.26559,
      "file_path": "/app/runner/tests/auth/fe-setup.test.ts",
      "test_path": "tests/auth/fe-setup.test.ts > Onboarding / Setup (FE-SETUP) > FE-SETUP-003 — Skip onboarding via 'Skip for now' → dashboard with welcome modal (skip CTA exists)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 8m22s\",\"retry_after_seconds\":502,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-SETUP-004",
      "description": "/getting-started shows checklist with at least one step",
      "status": "FAIL",
      "duration_ms": 60262.03805000002,
      "file_path": "/app/runner/tests/auth/fe-setup.test.ts",
      "test_path": "tests/auth/fe-setup.test.ts > Onboarding / Setup (FE-SETUP) > FE-SETUP-004 — /getting-started shows checklist with at least one step",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 7m22s\",\"retry_after_seconds\":442,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-SETUP-005",
      "description": "Welcome greeting renders user's first name",
      "status": "FAIL",
      "duration_ms": 60190.154981,
      "file_path": "/app/runner/tests/auth/fe-setup.test.ts",
      "test_path": "tests/auth/fe-setup.test.ts > Onboarding / Setup (FE-SETUP) > FE-SETUP-005 — Welcome greeting renders user's first name",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 6m22s\",\"retry_after_seconds\":382,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-SETUP-006",
      "description": "setup_finished flag persists in DB for the test admin",
      "status": "PASS",
      "duration_ms": 210.21885100001236,
      "file_path": "/app/runner/tests/auth/fe-setup.test.ts",
      "test_path": "tests/auth/fe-setup.test.ts > Onboarding / Setup (FE-SETUP) > FE-SETUP-006 — setup_finished flag persists in DB for the test admin"
    },
    {
      "id": "FE-SETUP-007",
      "description": "/getting-started accessible even when setup_finished is true (onboarding route exception)",
      "status": "FAIL",
      "duration_ms": 60206.446135999984,
      "file_path": "/app/runner/tests/auth/fe-setup.test.ts",
      "test_path": "tests/auth/fe-setup.test.ts > Onboarding / Setup (FE-SETUP) > FE-SETUP-007 — /getting-started accessible even when setup_finished is true (onboarding route exception)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 5m21s\",\"retry_after_seconds\":321,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-CAMP-021",
      "description": "Deals search page renders with filter components",
      "status": "FAIL",
      "duration_ms": 60479.970801999996,
      "file_path": "/app/runner/tests/campaign/fe-camp-deals-search.test.ts",
      "test_path": "tests/campaign/fe-camp-deals-search.test.ts > Campaign Deals Search filters (FE-CAMP) > FE-CAMP-021 — Deals search page renders with filter components",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 1m23s\",\"retry_after_seconds\":83,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-CAMP-022",
      "description": "Search filter updates URL params when typed + submitted",
      "status": "FAIL",
      "duration_ms": 60220.017405000006,
      "file_path": "/app/runner/tests/campaign/fe-camp-deals-search.test.ts",
      "test_path": "tests/campaign/fe-camp-deals-search.test.ts > Campaign Deals Search filters (FE-CAMP) > FE-CAMP-022 — Search filter updates URL params when typed + submitted",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 23s\",\"retry_after_seconds\":23,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-CAMP-023",
      "description": "Status filter (when present) updates URL state",
      "status": "PASS",
      "duration_ms": 28545.580736999997,
      "file_path": "/app/runner/tests/campaign/fe-camp-deals-search.test.ts",
      "test_path": "tests/campaign/fe-camp-deals-search.test.ts > Campaign Deals Search filters (FE-CAMP) > FE-CAMP-023 — Status filter (when present) updates URL state"
    },
    {
      "id": "FE-CAMP-024",
      "description": "Pagination controls (when present) navigate without crash",
      "status": "PASS",
      "duration_ms": 1806.1382459999877,
      "file_path": "/app/runner/tests/campaign/fe-camp-deals-search.test.ts",
      "test_path": "tests/campaign/fe-camp-deals-search.test.ts > Campaign Deals Search filters (FE-CAMP) > FE-CAMP-024 — Pagination controls (when present) navigate without crash"
    },
    {
      "id": "FE-CAMP-001",
      "description": "/automation-campaign lists campaigns or shows empty state",
      "status": "PASS",
      "duration_ms": 5385.435432,
      "file_path": "/app/runner/tests/campaign/fe-camp.test.ts",
      "test_path": "tests/campaign/fe-camp.test.ts > Campaign Builder (FE-CAMP) > FE-CAMP-001 — /automation-campaign lists campaigns or shows empty state"
    },
    {
      "id": "FE-CAMP-002",
      "description": "Tabs Active / Inactive / All switch correctly",
      "status": "PASS",
      "duration_ms": 10292.843008000002,
      "file_path": "/app/runner/tests/campaign/fe-camp.test.ts",
      "test_path": "tests/campaign/fe-camp.test.ts > Campaign Builder (FE-CAMP) > FE-CAMP-002 — Tabs Active / Inactive / All switch correctly"
    },
    {
      "id": "FE-CAMP-003",
      "description": "Search Campaigns input filters list",
      "status": "PASS",
      "duration_ms": 5062.352674000002,
      "file_path": "/app/runner/tests/campaign/fe-camp.test.ts",
      "test_path": "tests/campaign/fe-camp.test.ts > Campaign Builder (FE-CAMP) > FE-CAMP-003 — Search Campaigns input filters list"
    },
    {
      "id": "FE-CAMP-004",
      "description": "Pagination Next/Prev (where present) is sane",
      "status": "PASS",
      "duration_ms": 5587.2640809999975,
      "file_path": "/app/runner/tests/campaign/fe-camp.test.ts",
      "test_path": "tests/campaign/fe-camp.test.ts > Campaign Builder (FE-CAMP) > FE-CAMP-004 — Pagination Next/Prev (where present) is sane"
    },
    {
      "id": "FE-CAMP-005",
      "description": "PULSE / SWARM tabs at top (SWARM dev-only on staging)",
      "status": "PASS",
      "duration_ms": 6987.417512,
      "file_path": "/app/runner/tests/campaign/fe-camp.test.ts",
      "test_path": "tests/campaign/fe-camp.test.ts > Campaign Builder (FE-CAMP) > FE-CAMP-005 — PULSE / SWARM tabs at top (SWARM dev-only on staging)"
    },
    {
      "id": "FE-CAMP-006",
      "description": "/automation-campaign/create renders builder",
      "status": "PASS",
      "duration_ms": 5146.428855999999,
      "file_path": "/app/runner/tests/campaign/fe-camp.test.ts",
      "test_path": "tests/campaign/fe-camp.test.ts > Campaign Builder (FE-CAMP) > FE-CAMP-006 — /automation-campaign/create renders builder"
    },
    {
      "id": "FE-CAMP-007",
      "description": "Builder header shows 'Untitled' (FE-BUG-08 fix — not literal 'undefined')",
      "status": "PASS",
      "duration_ms": 7174.679565999999,
      "file_path": "/app/runner/tests/campaign/fe-camp.test.ts",
      "test_path": "tests/campaign/fe-camp.test.ts > Campaign Builder (FE-CAMP) > FE-CAMP-007 — Builder header shows 'Untitled' (FE-BUG-08 fix — not literal 'undefined')"
    },
    {
      "id": "FE-CAMP-008",
      "description": "Builder canvas shows 'Add Stage +' button",
      "status": "FAIL",
      "duration_ms": 60789.685940999996,
      "file_path": "/app/runner/tests/campaign/fe-camp.test.ts",
      "test_path": "tests/campaign/fe-camp.test.ts > Campaign Builder (FE-CAMP) > FE-CAMP-008 — Builder canvas shows 'Add Stage +' button",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 12m39s\",\"retry_after_seconds\":759,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-CAMP-009",
      "description": "Click Add Stage opens stage type modal",
      "status": "FAIL",
      "duration_ms": 60475.107203999985,
      "file_path": "/app/runner/tests/campaign/fe-camp.test.ts",
      "test_path": "tests/campaign/fe-camp.test.ts > Campaign Builder (FE-CAMP) > FE-CAMP-009 — Click Add Stage opens stage type modal",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 11m39s\",\"retry_after_seconds\":699,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-CAMP-010",
      "description": "Stage settings modal validates required fields (sanity check)",
      "status": "FAIL",
      "duration_ms": 60348.82918600002,
      "file_path": "/app/runner/tests/campaign/fe-camp.test.ts",
      "test_path": "tests/campaign/fe-camp.test.ts > Campaign Builder (FE-CAMP) > FE-CAMP-010 — Stage settings modal validates required fields (sanity check)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 10m38s\",\"retry_after_seconds\":638,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-CAMP-011",
      "description": "Builder name area exists (route smoke)",
      "status": "FAIL",
      "duration_ms": 60598.28164,
      "file_path": "/app/runner/tests/campaign/fe-camp.test.ts",
      "test_path": "tests/campaign/fe-camp.test.ts > Campaign Builder (FE-CAMP) > FE-CAMP-011 — Builder name area exists (route smoke)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 9m38s\",\"retry_after_seconds\":578,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-CAMP-012",
      "description": "Save Campaign with no stages → friendly error or warning",
      "status": "FAIL",
      "duration_ms": 60380.72113099997,
      "file_path": "/app/runner/tests/campaign/fe-camp.test.ts",
      "test_path": "tests/campaign/fe-camp.test.ts > Campaign Builder (FE-CAMP) > FE-CAMP-012 — Save Campaign with no stages → friendly error or warning",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 8m38s\",\"retry_after_seconds\":518,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-CAMP-013",
      "description": "Active toggle persists after save (visual presence)",
      "status": "FAIL",
      "duration_ms": 60644.34879700001,
      "file_path": "/app/runner/tests/campaign/fe-camp.test.ts",
      "test_path": "tests/campaign/fe-camp.test.ts > Campaign Builder (FE-CAMP) > FE-CAMP-013 — Active toggle persists after save (visual presence)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 7m37s\",\"retry_after_seconds\":457,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-CAMP-014",
      "description": "Click 'Import campaign from CRM' opens import modal",
      "status": "FAIL",
      "duration_ms": 60466.317313999985,
      "file_path": "/app/runner/tests/campaign/fe-camp.test.ts",
      "test_path": "tests/campaign/fe-camp.test.ts > Campaign Builder (FE-CAMP) > FE-CAMP-014 — Click 'Import campaign from CRM' opens import modal",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 6m36s\",\"retry_after_seconds\":396,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-CAMP-015",
      "description": "Import campaign validates CRM connection state (smoke)",
      "status": "PASS",
      "duration_ms": 1.1971989999874495,
      "file_path": "/app/runner/tests/campaign/fe-camp.test.ts",
      "test_path": "tests/campaign/fe-camp.test.ts > Campaign Builder (FE-CAMP) > FE-CAMP-015 — Import campaign validates CRM connection state (smoke)"
    },
    {
      "id": "FE-CAMP-016",
      "description": "/automation-campaign/[id] for non-existent ID → 404 or friendly error",
      "status": "FAIL",
      "duration_ms": 60183.04475999996,
      "file_path": "/app/runner/tests/campaign/fe-camp.test.ts",
      "test_path": "tests/campaign/fe-camp.test.ts > Campaign Builder (FE-CAMP) > FE-CAMP-016 — /automation-campaign/[id] for non-existent ID → 404 or friendly error",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 5m36s\",\"retry_after_seconds\":336,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-CAMP-017",
      "description": "/automation-campaign/[id]/deals lists campaign deals",
      "status": "FAIL",
      "duration_ms": 60262.53760899999,
      "file_path": "/app/runner/tests/campaign/fe-camp.test.ts",
      "test_path": "tests/campaign/fe-camp.test.ts > Campaign Builder (FE-CAMP) > FE-CAMP-017 — /automation-campaign/[id]/deals lists campaign deals",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 4m36s\",\"retry_after_seconds\":276,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-CAMP-018",
      "description": "Deals table renders without crashing (smoke)",
      "status": "FAIL",
      "duration_ms": 60421.457528000115,
      "file_path": "/app/runner/tests/campaign/fe-camp.test.ts",
      "test_path": "tests/campaign/fe-camp.test.ts > Campaign Builder (FE-CAMP) > FE-CAMP-018 — Deals table renders without crashing (smoke)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 3m36s\",\"retry_after_seconds\":216,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-CAMP-019",
      "description": "Pull CRM State button triggers sync (button present)",
      "status": "FAIL",
      "duration_ms": 60262.62550800003,
      "file_path": "/app/runner/tests/campaign/fe-camp.test.ts",
      "test_path": "tests/campaign/fe-camp.test.ts > Campaign Builder (FE-CAMP) > FE-CAMP-019 — Pull CRM State button triggers sync (button present)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 2m35s\",\"retry_after_seconds\":155,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-CAMP-020",
      "description": "Stage drag-and-drop reorders without crashes (page renders)",
      "status": "FAIL",
      "duration_ms": 60630.21257900004,
      "file_path": "/app/runner/tests/campaign/fe-camp.test.ts",
      "test_path": "tests/campaign/fe-camp.test.ts > Campaign Builder (FE-CAMP) > FE-CAMP-020 — Stage drag-and-drop reorders without crashes (page renders)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 1m35s\",\"retry_after_seconds\":95,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-DEAL-SEARCH-001",
      "description": "Type email into Search Deals input → table filters by email",
      "status": "FAIL",
      "duration_ms": 60650.826134999996,
      "file_path": "/app/runner/tests/campaign/fe-deal-search.test.ts",
      "test_path": "tests/campaign/fe-deal-search.test.ts > Deal Search regression (FE-DEAL-SEARCH) > FE-DEAL-SEARCH-001 — Type email into Search Deals input → table filters by email",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 55s\",\"retry_after_seconds\":55,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-DEAL-SEARCH-002",
      "description": "Type partial first name → filter applies",
      "status": "PASS",
      "duration_ms": 66101.149988,
      "file_path": "/app/runner/tests/campaign/fe-deal-search.test.ts",
      "test_path": "tests/campaign/fe-deal-search.test.ts > Deal Search regression (FE-DEAL-SEARCH) > FE-DEAL-SEARCH-002 — Type partial first name → filter applies"
    },
    {
      "id": "FE-DEAL-SEARCH-003",
      "description": "Press Enter in search submits without page reload",
      "status": "PASS",
      "duration_ms": 8127.9877010000055,
      "file_path": "/app/runner/tests/campaign/fe-deal-search.test.ts",
      "test_path": "tests/campaign/fe-deal-search.test.ts > Deal Search regression (FE-DEAL-SEARCH) > FE-DEAL-SEARCH-003 — Press Enter in search submits without page reload"
    },
    {
      "id": "FE-DEAL-SEARCH-004",
      "description": "Clear input → full deal list returns",
      "status": "PASS",
      "duration_ms": 6039.713879000017,
      "file_path": "/app/runner/tests/campaign/fe-deal-search.test.ts",
      "test_path": "tests/campaign/fe-deal-search.test.ts > Deal Search regression (FE-DEAL-SEARCH) > FE-DEAL-SEARCH-004 — Clear input → full deal list returns"
    },
    {
      "id": "FE-DEAL-SEARCH-005",
      "description": "Search persists across pagination",
      "status": "PASS",
      "duration_ms": 0.6552520000259392,
      "file_path": "/app/runner/tests/campaign/fe-deal-search.test.ts",
      "test_path": "tests/campaign/fe-deal-search.test.ts > Deal Search regression (FE-DEAL-SEARCH) > FE-DEAL-SEARCH-005 — Search persists across pagination"
    },
    {
      "id": "FE-DEAL-SEARCH-006",
      "description": "Include lost deals toggle ON/OFF persists",
      "status": "PASS",
      "duration_ms": 5319.6276620000135,
      "file_path": "/app/runner/tests/campaign/fe-deal-search.test.ts",
      "test_path": "tests/campaign/fe-deal-search.test.ts > Deal Search regression (FE-DEAL-SEARCH) > FE-DEAL-SEARCH-006 — Include lost deals toggle ON/OFF persists"
    },
    {
      "id": "FE-CRED-001",
      "description": "Header credit balance widget reflects /v1/credit",
      "status": "PASS",
      "duration_ms": 1426.871456,
      "file_path": "/app/runner/tests/credits/fe-credits.test.ts",
      "test_path": "tests/credits/fe-credits.test.ts > Credits + billing (FE-CRED) > FE-CRED-001 — Header credit balance widget reflects /v1/credit"
    },
    {
      "id": "FE-CRED-002",
      "description": "Top-up via card increases balance (smoke @paid)",
      "status": "PASS",
      "duration_ms": 0.8787989999996171,
      "file_path": "/app/runner/tests/credits/fe-credits.test.ts",
      "test_path": "tests/credits/fe-credits.test.ts > Credits + billing (FE-CRED) > FE-CRED-002 — Top-up via card increases balance (smoke @paid)"
    },
    {
      "id": "FE-CRED-003",
      "description": "Twilio SMS decrements balance by 1 (smoke)",
      "status": "PASS",
      "duration_ms": 0.31526800000028743,
      "file_path": "/app/runner/tests/credits/fe-credits.test.ts",
      "test_path": "tests/credits/fe-credits.test.ts > Credits + billing (FE-CRED) > FE-CRED-003 — Twilio SMS decrements balance by 1 (smoke)"
    },
    {
      "id": "FE-CRED-004",
      "description": "Twilio failure releases reserved credits (smoke)",
      "status": "PASS",
      "duration_ms": 1.4463470000000598,
      "file_path": "/app/runner/tests/credits/fe-credits.test.ts",
      "test_path": "tests/credits/fe-credits.test.ts > Credits + billing (FE-CRED) > FE-CRED-004 — Twilio failure releases reserved credits (smoke)"
    },
    {
      "id": "FE-CRED-005",
      "description": "Toky SMS leaves balance unchanged (smoke)",
      "status": "PASS",
      "duration_ms": 0.32368399999995745,
      "file_path": "/app/runner/tests/credits/fe-credits.test.ts",
      "test_path": "tests/credits/fe-credits.test.ts > Credits + billing (FE-CRED) > FE-CRED-005 — Toky SMS leaves balance unchanged (smoke)"
    },
    {
      "id": "FE-CRED-006",
      "description": "Personalised stage send charges AI unit not phone (smoke)",
      "status": "PASS",
      "duration_ms": 0.38779299999987416,
      "file_path": "/app/runner/tests/credits/fe-credits.test.ts",
      "test_path": "tests/credits/fe-credits.test.ts > Credits + billing (FE-CRED) > FE-CRED-006 — Personalised stage send charges AI unit not phone (smoke)"
    },
    {
      "id": "FE-CRED-007",
      "description": "Failed AI personalization → AI credit not committed (smoke)",
      "status": "PASS",
      "duration_ms": 0.3251270000000659,
      "file_path": "/app/runner/tests/credits/fe-credits.test.ts",
      "test_path": "tests/credits/fe-credits.test.ts > Credits + billing (FE-CRED) > FE-CRED-007 — Failed AI personalization → AI credit not committed (smoke)"
    },
    {
      "id": "FE-CRED-008",
      "description": "Hit balance=0 → friendly out-of-credits modal (smoke)",
      "status": "PASS",
      "duration_ms": 0.2753339999999298,
      "file_path": "/app/runner/tests/credits/fe-credits.test.ts",
      "test_path": "tests/credits/fe-credits.test.ts > Credits + billing (FE-CRED) > FE-CRED-008 — Hit balance=0 → friendly out-of-credits modal (smoke)"
    },
    {
      "id": "FE-CRED-009",
      "description": "Add-on activation increases credit allowance (smoke)",
      "status": "PASS",
      "duration_ms": 0.40693899999996574,
      "file_path": "/app/runner/tests/credits/fe-credits.test.ts",
      "test_path": "tests/credits/fe-credits.test.ts > Credits + billing (FE-CRED) > FE-CRED-009 — Add-on activation increases credit allowance (smoke)"
    },
    {
      "id": "FE-CRED-010",
      "description": "Cancel add-on at end of period → next month reverts (smoke)",
      "status": "PASS",
      "duration_ms": 0.4243419999997968,
      "file_path": "/app/runner/tests/credits/fe-credits.test.ts",
      "test_path": "tests/credits/fe-credits.test.ts > Credits + billing (FE-CRED) > FE-CRED-010 — Cancel add-on at end of period → next month reverts (smoke)"
    },
    {
      "id": "FE-CRM-001",
      "description": "Pipedrive verify-api-key endpoint exists",
      "status": "PASS",
      "duration_ms": 1476.3875360000002,
      "file_path": "/app/runner/tests/crm/fe-crm.test.ts",
      "test_path": "tests/crm/fe-crm.test.ts > CRM sync (FE-CRM) > FE-CRM-001 — Pipedrive verify-api-key endpoint exists"
    },
    {
      "id": "FE-CRM-002",
      "description": "Invalid Pipedrive API key → friendly error (smoke)",
      "status": "PASS",
      "duration_ms": 1.0802549999998519,
      "file_path": "/app/runner/tests/crm/fe-crm.test.ts",
      "test_path": "tests/crm/fe-crm.test.ts > CRM sync (FE-CRM) > FE-CRM-002 — Invalid Pipedrive API key → friendly error (smoke)"
    },
    {
      "id": "FE-CRM-003",
      "description": "Map Pipedrive user to RevHero account (smoke)",
      "status": "PASS",
      "duration_ms": 0.43145499999991443,
      "file_path": "/app/runner/tests/crm/fe-crm.test.ts",
      "test_path": "tests/crm/fe-crm.test.ts > CRM sync (FE-CRM) > FE-CRM-003 — Map Pipedrive user to RevHero account (smoke)"
    },
    {
      "id": "FE-CRM-004",
      "description": "Enable CRM sync on campaign pulls existing deals (smoke)",
      "status": "PASS",
      "duration_ms": 0.3803290000000743,
      "file_path": "/app/runner/tests/crm/fe-crm.test.ts",
      "test_path": "tests/crm/fe-crm.test.ts > CRM sync (FE-CRM) > FE-CRM-004 — Enable CRM sync on campaign pulls existing deals (smoke)"
    },
    {
      "id": "FE-CRM-005",
      "description": "Force-pull from CRM enqueues sweeper candidates (smoke)",
      "status": "PASS",
      "duration_ms": 0.6154179999998632,
      "file_path": "/app/runner/tests/crm/fe-crm.test.ts",
      "test_path": "tests/crm/fe-crm.test.ts > CRM sync (FE-CRM) > FE-CRM-005 — Force-pull from CRM enqueues sweeper candidates (smoke)"
    },
    {
      "id": "FE-CRM-006",
      "description": "Disable CRM sync stops auto-pulls (smoke)",
      "status": "PASS",
      "duration_ms": 0.46015899999974863,
      "file_path": "/app/runner/tests/crm/fe-crm.test.ts",
      "test_path": "tests/crm/fe-crm.test.ts > CRM sync (FE-CRM) > FE-CRM-006 — Disable CRM sync stops auto-pulls (smoke)"
    },
    {
      "id": "FE-CRM-007",
      "description": "Stage move with CRM connected → Pipedrive note + stage update (smoke)",
      "status": "PASS",
      "duration_ms": 0.2786710000000312,
      "file_path": "/app/runner/tests/crm/fe-crm.test.ts",
      "test_path": "tests/crm/fe-crm.test.ts > CRM sync (FE-CRM) > FE-CRM-007 — Stage move with CRM connected → Pipedrive note + stage update (smoke)"
    },
    {
      "id": "FE-CRM-008",
      "description": "Pipedrive webhook updates RevHero deal record (smoke)",
      "status": "PASS",
      "duration_ms": 0.40463499999987107,
      "file_path": "/app/runner/tests/crm/fe-crm.test.ts",
      "test_path": "tests/crm/fe-crm.test.ts > CRM sync (FE-CRM) > FE-CRM-008 — Pipedrive webhook updates RevHero deal record (smoke)"
    },
    {
      "id": "FE-CRM-009",
      "description": "Pipedrive outage → CRM goroutine fails silently, move proceeds (smoke)",
      "status": "PASS",
      "duration_ms": 0.33260100000006787,
      "file_path": "/app/runner/tests/crm/fe-crm.test.ts",
      "test_path": "tests/crm/fe-crm.test.ts > CRM sync (FE-CRM) > FE-CRM-009 — Pipedrive outage → CRM goroutine fails silently, move proceeds (smoke)"
    },
    {
      "id": "FE-CRM-010",
      "description": "HubSpot verify-api-key endpoint exists",
      "status": "PASS",
      "duration_ms": 1038.311424,
      "file_path": "/app/runner/tests/crm/fe-crm.test.ts",
      "test_path": "tests/crm/fe-crm.test.ts > CRM sync (FE-CRM) > FE-CRM-010 — HubSpot verify-api-key endpoint exists"
    },
    {
      "id": "FE-CSV-011",
      "description": "lead_ingestion_analytics table exists in deals-actions DB",
      "status": "PASS",
      "duration_ms": 224.53527199999962,
      "file_path": "/app/runner/tests/csv/fe-csv-leadingestion.test.ts",
      "test_path": "tests/csv/fe-csv-leadingestion.test.ts > Lead Ingestion Executor (FE-CSV) > FE-CSV-011 — lead_ingestion_analytics table exists in deals-actions DB"
    },
    {
      "id": "FE-CSV-012",
      "description": "lead-ingestion event contract has v1 (smoke)",
      "status": "PASS",
      "duration_ms": 0.4719300000001567,
      "file_path": "/app/runner/tests/csv/fe-csv-leadingestion.test.ts",
      "test_path": "tests/csv/fe-csv-leadingestion.test.ts > Lead Ingestion Executor (FE-CSV) > FE-CSV-012 — lead-ingestion event contract has v1 (smoke)"
    },
    {
      "id": "FE-CSV-013",
      "description": "OAuth2 token acquisition + refresh via leadingestion/auth.go (smoke)",
      "status": "PASS",
      "duration_ms": 0.3890459999997802,
      "file_path": "/app/runner/tests/csv/fe-csv-leadingestion.test.ts",
      "test_path": "tests/csv/fe-csv-leadingestion.test.ts > Lead Ingestion Executor (FE-CSV) > FE-CSV-013 — OAuth2 token acquisition + refresh via leadingestion/auth.go (smoke)"
    },
    {
      "id": "FE-CSV-014",
      "description": "analytics record carries success / partial / failed status (smoke)",
      "status": "PASS",
      "duration_ms": 0.2171640000001389,
      "file_path": "/app/runner/tests/csv/fe-csv-leadingestion.test.ts",
      "test_path": "tests/csv/fe-csv-leadingestion.test.ts > Lead Ingestion Executor (FE-CSV) > FE-CSV-014 — analytics record carries success / partial / failed status (smoke)"
    },
    {
      "id": "FE-CSV-001",
      "description": "GET /v1/csv-imports/template returns CSV template",
      "status": "PASS",
      "duration_ms": 1344.9649670000001,
      "file_path": "/app/runner/tests/csv/fe-csv.test.ts",
      "test_path": "tests/csv/fe-csv.test.ts > CSV imports (FE-CSV) > FE-CSV-001 — GET /v1/csv-imports/template returns CSV template"
    },
    {
      "id": "FE-CSV-002",
      "description": "POST /v1/stages/:id/csv-imports creates pending job (smoke)",
      "status": "PASS",
      "duration_ms": 0.8169940000002498,
      "file_path": "/app/runner/tests/csv/fe-csv.test.ts",
      "test_path": "tests/csv/fe-csv.test.ts > CSV imports (FE-CSV) > FE-CSV-002 — POST /v1/stages/:id/csv-imports creates pending job (smoke)"
    },
    {
      "id": "FE-CSV-003",
      "description": "Job advances pending → processing → completed (smoke)",
      "status": "PASS",
      "duration_ms": 0.38703099999975166,
      "file_path": "/app/runner/tests/csv/fe-csv.test.ts",
      "test_path": "tests/csv/fe-csv.test.ts > CSV imports (FE-CSV) > FE-CSV-003 — Job advances pending → processing → completed (smoke)"
    },
    {
      "id": "FE-CSV-004",
      "description": "Missing required columns → per-row error report (smoke)",
      "status": "PASS",
      "duration_ms": 0.2996889999999439,
      "file_path": "/app/runner/tests/csv/fe-csv.test.ts",
      "test_path": "tests/csv/fe-csv.test.ts > CSV imports (FE-CSV) > FE-CSV-004 — Missing required columns → per-row error report (smoke)"
    },
    {
      "id": "FE-CSV-005",
      "description": "Malformed phones skipped, valid rows ingested (smoke)",
      "status": "PASS",
      "duration_ms": 0.3206070000001091,
      "file_path": "/app/runner/tests/csv/fe-csv.test.ts",
      "test_path": "tests/csv/fe-csv.test.ts > CSV imports (FE-CSV) > FE-CSV-005 — Malformed phones skipped, valid rows ingested (smoke)"
    },
    {
      "id": "FE-CSV-006",
      "description": "Duplicate emails skipped or merged (smoke)",
      "status": "PASS",
      "duration_ms": 0.3417970000000423,
      "file_path": "/app/runner/tests/csv/fe-csv.test.ts",
      "test_path": "tests/csv/fe-csv.test.ts > CSV imports (FE-CSV) > FE-CSV-006 — Duplicate emails skipped or merged (smoke)"
    },
    {
      "id": "FE-CSV-007",
      "description": "Reprocess endpoint idempotent (smoke)",
      "status": "PASS",
      "duration_ms": 0.30040100000042,
      "file_path": "/app/runner/tests/csv/fe-csv.test.ts",
      "test_path": "tests/csv/fe-csv.test.ts > CSV imports (FE-CSV) > FE-CSV-007 — Reprocess endpoint idempotent (smoke)"
    },
    {
      "id": "FE-CSV-008",
      "description": "GET /v1/stages/:id/csv-imports lists jobs (smoke)",
      "status": "PASS",
      "duration_ms": 0.30684100000007675,
      "file_path": "/app/runner/tests/csv/fe-csv.test.ts",
      "test_path": "tests/csv/fe-csv.test.ts > CSV imports (FE-CSV) > FE-CSV-008 — GET /v1/stages/:id/csv-imports lists jobs (smoke)"
    },
    {
      "id": "FE-CSV-009",
      "description": "suppress-import-actions flag toggles trigger behavior (smoke)",
      "status": "PASS",
      "duration_ms": 0.35549200000014025,
      "file_path": "/app/runner/tests/csv/fe-csv.test.ts",
      "test_path": "tests/csv/fe-csv.test.ts > CSV imports (FE-CSV) > FE-CSV-009 — suppress-import-actions flag toggles trigger behavior (smoke)"
    },
    {
      "id": "FE-CSV-010",
      "description": "Oversized CSV handled gracefully (smoke)",
      "status": "PASS",
      "duration_ms": 0.45069999999986976,
      "file_path": "/app/runner/tests/csv/fe-csv.test.ts",
      "test_path": "tests/csv/fe-csv.test.ts > CSV imports (FE-CSV) > FE-CSV-010 — Oversized CSV handled gracefully (smoke)"
    },
    {
      "id": "FE-DEAL-001",
      "description": "Sweep endpoint returns jobs_scheduled count",
      "status": "PASS",
      "duration_ms": 206.0062109999999,
      "file_path": "/app/runner/tests/deal-mover/fe-deal.test.ts",
      "test_path": "tests/deal-mover/fe-deal.test.ts > Deal Mover (FE-DEAL) > FE-DEAL-001 — Sweep endpoint returns jobs_scheduled count"
    },
    {
      "id": "FE-DEAL-002",
      "description": "Sweep moves a deal forward (smoke — needs seeded campaign)",
      "status": "PASS",
      "duration_ms": 0.4835419999999431,
      "file_path": "/app/runner/tests/deal-mover/fe-deal.test.ts",
      "test_path": "tests/deal-mover/fe-deal.test.ts > Deal Mover (FE-DEAL) > FE-DEAL-002 — Sweep moves a deal forward (smoke — needs seeded campaign)"
    },
    {
      "id": "FE-DEAL-003",
      "description": "Inactive campaign skips sweep (smoke)",
      "status": "PASS",
      "duration_ms": 0.2428220000001602,
      "file_path": "/app/runner/tests/deal-mover/fe-deal.test.ts",
      "test_path": "tests/deal-mover/fe-deal.test.ts > Deal Mover (FE-DEAL) > FE-DEAL-003 — Inactive campaign skips sweep (smoke)"
    },
    {
      "id": "FE-DEAL-004",
      "description": "Inactive user's stages skipped (smoke)",
      "status": "PASS",
      "duration_ms": 0.3283919999998943,
      "file_path": "/app/runner/tests/deal-mover/fe-deal.test.ts",
      "test_path": "tests/deal-mover/fe-deal.test.ts > Deal Mover (FE-DEAL) > FE-DEAL-004 — Inactive user's stages skipped (smoke)"
    },
    {
      "id": "FE-DEAL-005",
      "description": "max_deals_to_move quota respected (smoke)",
      "status": "PASS",
      "duration_ms": 0.17807199999992918,
      "file_path": "/app/runner/tests/deal-mover/fe-deal.test.ts",
      "test_path": "tests/deal-mover/fe-deal.test.ts > Deal Mover (FE-DEAL) > FE-DEAL-005 — max_deals_to_move quota respected (smoke)"
    },
    {
      "id": "FE-DEAL-006",
      "description": "Worker pops job within 5s (smoke)",
      "status": "PASS",
      "duration_ms": 0.39209200000004785,
      "file_path": "/app/runner/tests/deal-mover/fe-deal.test.ts",
      "test_path": "tests/deal-mover/fe-deal.test.ts > Deal Mover (FE-DEAL) > FE-DEAL-006 — Worker pops job within 5s (smoke)"
    },
    {
      "id": "FE-DEAL-007",
      "description": "Worker triggers email/SMS action (smoke)",
      "status": "PASS",
      "duration_ms": 0.2875050000000101,
      "file_path": "/app/runner/tests/deal-mover/fe-deal.test.ts",
      "test_path": "tests/deal-mover/fe-deal.test.ts > Deal Mover (FE-DEAL) > FE-DEAL-007 — Worker triggers email/SMS action (smoke)"
    },
    {
      "id": "FE-DEAL-008",
      "description": "Action returns 425 → deal rolled back (smoke)",
      "status": "PASS",
      "duration_ms": 0.19602600000007442,
      "file_path": "/app/runner/tests/deal-mover/fe-deal.test.ts",
      "test_path": "tests/deal-mover/fe-deal.test.ts > Deal Mover (FE-DEAL) > FE-DEAL-008 — Action returns 425 → deal rolled back (smoke)"
    },
    {
      "id": "FE-DEAL-009",
      "description": "Action 5xx → exponential backoff retry (smoke)",
      "status": "PASS",
      "duration_ms": 0.6589690000000701,
      "file_path": "/app/runner/tests/deal-mover/fe-deal.test.ts",
      "test_path": "tests/deal-mover/fe-deal.test.ts > Deal Mover (FE-DEAL) > FE-DEAL-009 — Action 5xx → exponential backoff retry (smoke)"
    },
    {
      "id": "FE-DEAL-010",
      "description": "Successful move appears in BFF /v1/deals/filter (smoke)",
      "status": "PASS",
      "duration_ms": 0.41127700000015466,
      "file_path": "/app/runner/tests/deal-mover/fe-deal.test.ts",
      "test_path": "tests/deal-mover/fe-deal.test.ts > Deal Mover (FE-DEAL) > FE-DEAL-010 — Successful move appears in BFF /v1/deals/filter (smoke)"
    },
    {
      "id": "FE-DEAL-011",
      "description": "Successful move does NOT create activity row (smoke)",
      "status": "PASS",
      "duration_ms": 0.5747819999999138,
      "file_path": "/app/runner/tests/deal-mover/fe-deal.test.ts",
      "test_path": "tests/deal-mover/fe-deal.test.ts > Deal Mover (FE-DEAL) > FE-DEAL-011 — Successful move does NOT create activity row (smoke)"
    },
    {
      "id": "FE-DEAL-012",
      "description": "CRM sync goroutine fires after move (smoke)",
      "status": "PASS",
      "duration_ms": 0.3048389999999017,
      "file_path": "/app/runner/tests/deal-mover/fe-deal.test.ts",
      "test_path": "tests/deal-mover/fe-deal.test.ts > Deal Mover (FE-DEAL) > FE-DEAL-012 — CRM sync goroutine fires after move (smoke)"
    },
    {
      "id": "FE-DEAL-013",
      "description": "/v1/stages/scheduled endpoint reachable",
      "status": "PASS",
      "duration_ms": 39.79036999999994,
      "file_path": "/app/runner/tests/deal-mover/fe-deal.test.ts",
      "test_path": "tests/deal-mover/fe-deal.test.ts > Deal Mover (FE-DEAL) > FE-DEAL-013 — /v1/stages/scheduled endpoint reachable"
    },
    {
      "id": "FE-DEAL-014",
      "description": "/v1/stages/moved endpoint reachable",
      "status": "PASS",
      "duration_ms": 27.51808099999994,
      "file_path": "/app/runner/tests/deal-mover/fe-deal.test.ts",
      "test_path": "tests/deal-mover/fe-deal.test.ts > Deal Mover (FE-DEAL) > FE-DEAL-014 — /v1/stages/moved endpoint reachable"
    },
    {
      "id": "FE-DEAL-015",
      "description": "Redis isolation between staging and prod (smoke)",
      "status": "PASS",
      "duration_ms": 0.31425500000000284,
      "file_path": "/app/runner/tests/deal-mover/fe-deal.test.ts",
      "test_path": "tests/deal-mover/fe-deal.test.ts > Deal Mover (FE-DEAL) > FE-DEAL-015 — Redis isolation between staging and prod (smoke)"
    },
    {
      "id": "FE-DEAL-016",
      "description": "Super-admin sweeper button (smoke)",
      "status": "PASS",
      "duration_ms": 0.24508700000001227,
      "file_path": "/app/runner/tests/deal-mover/fe-deal.test.ts",
      "test_path": "tests/deal-mover/fe-deal.test.ts > Deal Mover (FE-DEAL) > FE-DEAL-016 — Super-admin sweeper button (smoke)"
    },
    {
      "id": "FE-DEAL-017",
      "description": "next_move_date NULL → deal NOT picked up (smoke)",
      "status": "PASS",
      "duration_ms": 0.2044419999999718,
      "file_path": "/app/runner/tests/deal-mover/fe-deal.test.ts",
      "test_path": "tests/deal-mover/fe-deal.test.ts > Deal Mover (FE-DEAL) > FE-DEAL-017 — next_move_date NULL → deal NOT picked up (smoke)"
    },
    {
      "id": "UNKNOWN-b2wlnx",
      "description": "FE-E2E-001 — Signup → Onboarding → First campaign → First deal email sent (smoke)",
      "status": "PASS",
      "duration_ms": 4.927089000000024,
      "file_path": "/app/runner/tests/e2e/fe-e2e.test.ts",
      "test_path": "tests/e2e/fe-e2e.test.ts > Cross-service E2E (FE-E2E) > FE-E2E-001 — Signup → Onboarding → First campaign → First deal email sent (smoke)"
    },
    {
      "id": "UNKNOWN-zz34hd",
      "description": "FE-E2E-002 — Inbound reply NEGATIVE → deal auto-Lost (smoke)",
      "status": "PASS",
      "duration_ms": 0.823113999999805,
      "file_path": "/app/runner/tests/e2e/fe-e2e.test.ts",
      "test_path": "tests/e2e/fe-e2e.test.ts > Cross-service E2E (FE-E2E) > FE-E2E-002 — Inbound reply NEGATIVE → deal auto-Lost (smoke)"
    },
    {
      "id": "UNKNOWN-edwx7v",
      "description": "FE-E2E-003 — Toky BYOC end-to-end SMS round-trip (smoke)",
      "status": "PASS",
      "duration_ms": 0.4013079999999718,
      "file_path": "/app/runner/tests/e2e/fe-e2e.test.ts",
      "test_path": "tests/e2e/fe-e2e.test.ts > Cross-service E2E (FE-E2E) > FE-E2E-003 — Toky BYOC end-to-end SMS round-trip (smoke)"
    },
    {
      "id": "UNKNOWN-ajjk5k",
      "description": "FE-E2E-004 — Multi-stage campaign with wait + actions (smoke)",
      "status": "PASS",
      "duration_ms": 0.4860670000000482,
      "file_path": "/app/runner/tests/e2e/fe-e2e.test.ts",
      "test_path": "tests/e2e/fe-e2e.test.ts > Cross-service E2E (FE-E2E) > FE-E2E-004 — Multi-stage campaign with wait + actions (smoke)"
    },
    {
      "id": "UNKNOWN-ed0hsi",
      "description": "FE-E2E-005 — Quota cap respected (smoke)",
      "status": "PASS",
      "duration_ms": 0.28963100000009945,
      "file_path": "/app/runner/tests/e2e/fe-e2e.test.ts",
      "test_path": "tests/e2e/fe-e2e.test.ts > Cross-service E2E (FE-E2E) > FE-E2E-005 — Quota cap respected (smoke)"
    },
    {
      "id": "UNKNOWN-l4jn99",
      "description": "FE-E2E-006 — Inactive user pause-billing edge case (smoke)",
      "status": "PASS",
      "duration_ms": 0.3322299999999814,
      "file_path": "/app/runner/tests/e2e/fe-e2e.test.ts",
      "test_path": "tests/e2e/fe-e2e.test.ts > Cross-service E2E (FE-E2E) > FE-E2E-006 — Inactive user pause-billing edge case (smoke)"
    },
    {
      "id": "UNKNOWN-aqpa78",
      "description": "FE-E2E-007 — Free-plan SMS via Toky succeeds, via Twilio rejected (smoke)",
      "status": "PASS",
      "duration_ms": 0.2981560000000627,
      "file_path": "/app/runner/tests/e2e/fe-e2e.test.ts",
      "test_path": "tests/e2e/fe-e2e.test.ts > Cross-service E2E (FE-E2E) > FE-E2E-007 — Free-plan SMS via Toky succeeds, via Twilio rejected (smoke)"
    },
    {
      "id": "UNKNOWN-t23sxs",
      "description": "FE-E2E-008 — JWT expiry mid-flow auto-refreshes (smoke)",
      "status": "PASS",
      "duration_ms": 0.28617400000007365,
      "file_path": "/app/runner/tests/e2e/fe-e2e.test.ts",
      "test_path": "tests/e2e/fe-e2e.test.ts > Cross-service E2E (FE-E2E) > FE-E2E-008 — JWT expiry mid-flow auto-refreshes (smoke)"
    },
    {
      "id": "UNKNOWN-zc3ok9",
      "description": "FE-E2E-009 — Multi-tenant isolation across mailboxes/Toky/deals (smoke)",
      "status": "PASS",
      "duration_ms": 0.24945600000000923,
      "file_path": "/app/runner/tests/e2e/fe-e2e.test.ts",
      "test_path": "tests/e2e/fe-e2e.test.ts > Cross-service E2E (FE-E2E) > FE-E2E-009 — Multi-tenant isolation across mailboxes/Toky/deals (smoke)"
    },
    {
      "id": "UNKNOWN-ockfmf",
      "description": "FE-E2E-010 — Webhook-only services not exposed (smoke — covered by WEBHOOK-AUTH)",
      "status": "PASS",
      "duration_ms": 0.24489800000014839,
      "file_path": "/app/runner/tests/e2e/fe-e2e.test.ts",
      "test_path": "tests/e2e/fe-e2e.test.ts > Cross-service E2E (FE-E2E) > FE-E2E-010 — Webhook-only services not exposed (smoke — covered by WEBHOOK-AUTH)"
    },
    {
      "id": "FE-EMAIL-IN-012",
      "description": "bounce-webhook endpoint requires internal-services auth",
      "status": "PASS",
      "duration_ms": 364.4732530000001,
      "file_path": "/app/runner/tests/email/fe-email-in-bounce.test.ts",
      "test_path": "tests/email/fe-email-in-bounce.test.ts > Email bounce debounce (FE-EMAIL-IN) > FE-EMAIL-IN-012 — bounce-webhook endpoint requires internal-services auth"
    },
    {
      "id": "FE-EMAIL-IN-013",
      "description": "duplicate bounces within debounce window are absorbed (smoke)",
      "status": "PASS",
      "duration_ms": 51.0346599999998,
      "file_path": "/app/runner/tests/email/fe-email-in-bounce.test.ts",
      "test_path": "tests/email/fe-email-in-bounce.test.ts > Email bounce debounce (FE-EMAIL-IN) > FE-EMAIL-IN-013 — duplicate bounces within debounce window are absorbed (smoke)"
    },
    {
      "id": "FE-EMAIL-IN-014",
      "description": "bounced address propagates to the blocklist (smoke)",
      "status": "PASS",
      "duration_ms": 0.35116500000003725,
      "file_path": "/app/runner/tests/email/fe-email-in-bounce.test.ts",
      "test_path": "tests/email/fe-email-in-bounce.test.ts > Email bounce debounce (FE-EMAIL-IN) > FE-EMAIL-IN-014 — bounced address propagates to the blocklist (smoke)"
    },
    {
      "id": "FE-EMAIL-IN-001",
      "description": "Reply appears in FE thread within ~30s (smoke)",
      "status": "PASS",
      "duration_ms": 2.0244860000000244,
      "file_path": "/app/runner/tests/email/fe-email-in.test.ts",
      "test_path": "tests/email/fe-email-in.test.ts > Inbound Email + Sentiment (FE-EMAIL-IN) > FE-EMAIL-IN-001 — Reply appears in FE thread within ~30s (smoke)"
    },
    {
      "id": "FE-EMAIL-IN-002",
      "description": "email row has sentiment after scoring (smoke)",
      "status": "PASS",
      "duration_ms": 0.3411670000000413,
      "file_path": "/app/runner/tests/email/fe-email-in.test.ts",
      "test_path": "tests/email/fe-email-in.test.ts > Inbound Email + Sentiment (FE-EMAIL-IN) > FE-EMAIL-IN-002 — email row has sentiment after scoring (smoke)"
    },
    {
      "id": "FE-EMAIL-IN-003",
      "description": "'unsubscribe' triggers NEGATIVE heuristic + deal-loss (smoke)",
      "status": "PASS",
      "duration_ms": 0.39627999999993335,
      "file_path": "/app/runner/tests/email/fe-email-in.test.ts",
      "test_path": "tests/email/fe-email-in.test.ts > Inbound Email + Sentiment (FE-EMAIL-IN) > FE-EMAIL-IN-003 — 'unsubscribe' triggers NEGATIVE heuristic + deal-loss (smoke)"
    },
    {
      "id": "FE-EMAIL-IN-004",
      "description": "OOO autoresponder → NEUTRAL + date extraction (smoke)",
      "status": "PASS",
      "duration_ms": 0.37606099999993603,
      "file_path": "/app/runner/tests/email/fe-email-in.test.ts",
      "test_path": "tests/email/fe-email-in.test.ts > Inbound Email + Sentiment (FE-EMAIL-IN) > FE-EMAIL-IN-004 — OOO autoresponder → NEUTRAL + date extraction (smoke)"
    },
    {
      "id": "FE-EMAIL-IN-005",
      "description": "Self-reply skips sentiment (smoke)",
      "status": "PASS",
      "duration_ms": 0.3742780000000039,
      "file_path": "/app/runner/tests/email/fe-email-in.test.ts",
      "test_path": "tests/email/fe-email-in.test.ts > Inbound Email + Sentiment (FE-EMAIL-IN) > FE-EMAIL-IN-005 — Self-reply skips sentiment (smoke)"
    },
    {
      "id": "FE-EMAIL-IN-006",
      "description": "Inbound XSS subject escapes on render (smoke)",
      "status": "PASS",
      "duration_ms": 0.4747259999999187,
      "file_path": "/app/runner/tests/email/fe-email-in.test.ts",
      "test_path": "tests/email/fe-email-in.test.ts > Inbound Email + Sentiment (FE-EMAIL-IN) > FE-EMAIL-IN-006 — Inbound XSS subject escapes on render (smoke)"
    },
    {
      "id": "FE-EMAIL-IN-007",
      "description": "Bounce notification flags original send (smoke)",
      "status": "PASS",
      "duration_ms": 0.3660330000000158,
      "file_path": "/app/runner/tests/email/fe-email-in.test.ts",
      "test_path": "tests/email/fe-email-in.test.ts > Inbound Email + Sentiment (FE-EMAIL-IN) > FE-EMAIL-IN-007 — Bounce notification flags original send (smoke)"
    },
    {
      "id": "FE-EMAIL-IN-008",
      "description": "POST /v1/emails/sentiment-webhook from public internet — must return 401/403/404",
      "status": "PASS",
      "duration_ms": 139.1825570000001,
      "file_path": "/app/runner/tests/email/fe-email-in.test.ts",
      "test_path": "tests/email/fe-email-in.test.ts > Inbound Email + Sentiment (FE-EMAIL-IN) > FE-EMAIL-IN-008 — POST /v1/emails/sentiment-webhook from public internet — must return 401/403/404"
    },
    {
      "id": "FE-EMAIL-IN-009",
      "description": "Mark inbound email Read/Unread/Favourite/Archive (smoke)",
      "status": "PASS",
      "duration_ms": 0.3770329999999831,
      "file_path": "/app/runner/tests/email/fe-email-in.test.ts",
      "test_path": "tests/email/fe-email-in.test.ts > Inbound Email + Sentiment (FE-EMAIL-IN) > FE-EMAIL-IN-009 — Mark inbound email Read/Unread/Favourite/Archive (smoke)"
    },
    {
      "id": "FE-EMAIL-IN-010",
      "description": "Conversation history merges sent + received chronologically (smoke)",
      "status": "PASS",
      "duration_ms": 0.2850619999999253,
      "file_path": "/app/runner/tests/email/fe-email-in.test.ts",
      "test_path": "tests/email/fe-email-in.test.ts > Inbound Email + Sentiment (FE-EMAIL-IN) > FE-EMAIL-IN-010 — Conversation history merges sent + received chronologically (smoke)"
    },
    {
      "id": "FE-EMAIL-IN-011",
      "description": "Cross-tenant email isolation (smoke)",
      "status": "PASS",
      "duration_ms": 0.27162700000008044,
      "file_path": "/app/runner/tests/email/fe-email-in.test.ts",
      "test_path": "tests/email/fe-email-in.test.ts > Inbound Email + Sentiment (FE-EMAIL-IN) > FE-EMAIL-IN-011 — Cross-tenant email isolation (smoke)"
    },
    {
      "id": "FE-EMAIL-OUT-013",
      "description": "POST /v1/emails/render endpoint exists + accepts template_body",
      "status": "FAIL",
      "duration_ms": 60648.690976,
      "file_path": "/app/runner/tests/email/fe-email-out-render.test.ts",
      "test_path": "tests/email/fe-email-out-render.test.ts > Email template render preview (FE-EMAIL-OUT) > FE-EMAIL-OUT-013 — POST /v1/emails/render endpoint exists + accepts template_body",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 30s\",\"retry_after_seconds\":30,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-EMAIL-OUT-014",
      "description": "Invalid deal_id is rejected with 4xx (not 500)",
      "status": "PASS",
      "duration_ms": 35245.018824,
      "file_path": "/app/runner/tests/email/fe-email-out-render.test.ts",
      "test_path": "tests/email/fe-email-out-render.test.ts > Email template render preview (FE-EMAIL-OUT) > FE-EMAIL-OUT-014 — Invalid deal_id is rejected with 4xx (not 500)"
    },
    {
      "id": "FE-EMAIL-OUT-015",
      "description": "Missing template_body returns 400 with friendly error",
      "status": "FAIL",
      "duration_ms": 1076.7788419999997,
      "file_path": "/app/runner/tests/email/fe-email-out-render.test.ts",
      "test_path": "tests/email/fe-email-out-render.test.ts > Email template render preview (FE-EMAIL-OUT) > FE-EMAIL-OUT-015 — Missing template_body returns 400 with friendly error",
      "error": "expected [ 400, 422 ] to include 404"
    },
    {
      "id": "FE-EMAIL-OUT-001",
      "description": "Connect Gmail mailbox via OAuth (external-blocked) — assert URL request returns redirect URL",
      "status": "FAIL",
      "duration_ms": 60475.317268,
      "file_path": "/app/runner/tests/email/fe-email-out.test.ts",
      "test_path": "tests/email/fe-email-out.test.ts > Outbound Email (FE-EMAIL-OUT) > FE-EMAIL-OUT-001 — Connect Gmail mailbox via OAuth (external-blocked) — assert URL request returns redirect URL",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 2m34s\",\"retry_after_seconds\":154,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-EMAIL-OUT-002",
      "description": "Connect Microsoft mailbox same flow (external-blocked)",
      "status": "FAIL",
      "duration_ms": 60263.743407,
      "file_path": "/app/runner/tests/email/fe-email-out.test.ts",
      "test_path": "tests/email/fe-email-out.test.ts > Outbound Email (FE-EMAIL-OUT) > FE-EMAIL-OUT-002 — Connect Microsoft mailbox same flow (external-blocked)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 1m34s\",\"retry_after_seconds\":94,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-EMAIL-OUT-003",
      "description": "Disconnect mailbox via POST /v1/user-mailboxes/:id/disconnect (smoke)",
      "status": "PASS",
      "duration_ms": 1.9934270000085235,
      "file_path": "/app/runner/tests/email/fe-email-out.test.ts",
      "test_path": "tests/email/fe-email-out.test.ts > Outbound Email (FE-EMAIL-OUT) > FE-EMAIL-OUT-003 — Disconnect mailbox via POST /v1/user-mailboxes/:id/disconnect (smoke)"
    },
    {
      "id": "FE-EMAIL-OUT-004",
      "description": "Test Email (rate-limited 5/hr) endpoint exists",
      "status": "FAIL",
      "duration_ms": 60243.041488999996,
      "file_path": "/app/runner/tests/email/fe-email-out.test.ts",
      "test_path": "tests/email/fe-email-out.test.ts > Outbound Email (FE-EMAIL-OUT) > FE-EMAIL-OUT-004 — Test Email (rate-limited 5/hr) endpoint exists",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 34s\",\"retry_after_seconds\":34,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-EMAIL-OUT-005",
      "description": "Test-Email button disabled when ai_personalization_enabled=false (FE check)",
      "status": "PASS",
      "duration_ms": 1.0522119999805,
      "file_path": "/app/runner/tests/email/fe-email-out.test.ts",
      "test_path": "tests/email/fe-email-out.test.ts > Outbound Email (FE-EMAIL-OUT) > FE-EMAIL-OUT-005 — Test-Email button disabled when ai_personalization_enabled=false (FE check)"
    },
    {
      "id": "FE-EMAIL-OUT-006",
      "description": "6 test emails in 1 hour → 429",
      "status": "PASS",
      "duration_ms": 0.4882099999813363,
      "file_path": "/app/runner/tests/email/fe-email-out.test.ts",
      "test_path": "tests/email/fe-email-out.test.ts > Outbound Email (FE-EMAIL-OUT) > FE-EMAIL-OUT-006 — 6 test emails in 1 hour → 429"
    },
    {
      "id": "FE-EMAIL-OUT-007",
      "description": "Send manual email with merge tags (composer renders)",
      "status": "PASS",
      "duration_ms": 45004.38435799998,
      "file_path": "/app/runner/tests/email/fe-email-out.test.ts",
      "test_path": "tests/email/fe-email-out.test.ts > Outbound Email (FE-EMAIL-OUT) > FE-EMAIL-OUT-007 — Send manual email with merge tags (composer renders)"
    },
    {
      "id": "FE-EMAIL-OUT-008",
      "description": "Manual email to deal contact creates sent_email row (smoke)",
      "status": "PASS",
      "duration_ms": 0.640804999973625,
      "file_path": "/app/runner/tests/email/fe-email-out.test.ts",
      "test_path": "tests/email/fe-email-out.test.ts > Outbound Email (FE-EMAIL-OUT) > FE-EMAIL-OUT-008 — Manual email to deal contact creates sent_email row (smoke)"
    },
    {
      "id": "FE-EMAIL-OUT-009",
      "description": "Email signature appended to outbound (smoke)",
      "status": "PASS",
      "duration_ms": 2.260256000008667,
      "file_path": "/app/runner/tests/email/fe-email-out.test.ts",
      "test_path": "tests/email/fe-email-out.test.ts > Outbound Email (FE-EMAIL-OUT) > FE-EMAIL-OUT-009 — Email signature appended to outbound (smoke)"
    },
    {
      "id": "FE-EMAIL-OUT-010",
      "description": "Empty subject → form validation rejects",
      "status": "PASS",
      "duration_ms": 37223.134055,
      "file_path": "/app/runner/tests/email/fe-email-out.test.ts",
      "test_path": "tests/email/fe-email-out.test.ts > Outbound Email (FE-EMAIL-OUT) > FE-EMAIL-OUT-010 — Empty subject → form validation rejects"
    },
    {
      "id": "FE-EMAIL-OUT-011",
      "description": "Long body (>50 KB) handled (smoke — no 500)",
      "status": "PASS",
      "duration_ms": 0.6540210000239313,
      "file_path": "/app/runner/tests/email/fe-email-out.test.ts",
      "test_path": "tests/email/fe-email-out.test.ts > Outbound Email (FE-EMAIL-OUT) > FE-EMAIL-OUT-011 — Long body (>50 KB) handled (smoke — no 500)"
    },
    {
      "id": "FE-EMAIL-OUT-012",
      "description": "XSS in subject + body sanitised (smoke — no script execution)",
      "status": "PASS",
      "duration_ms": 0.45281500002602115,
      "file_path": "/app/runner/tests/email/fe-email-out.test.ts",
      "test_path": "tests/email/fe-email-out.test.ts > Outbound Email (FE-EMAIL-OUT) > FE-EMAIL-OUT-012 — XSS in subject + body sanitised (smoke — no script execution)"
    },
    {
      "id": "FE-EMAIL-001",
      "description": "/email-system/email lists messages or empty state",
      "status": "FAIL",
      "duration_ms": 60816.92083,
      "file_path": "/app/runner/tests/email/fe-email.test.ts",
      "test_path": "tests/email/fe-email.test.ts > Email System (FE-EMAIL) > FE-EMAIL-001 — /email-system/email lists messages or empty state",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 11m28s\",\"retry_after_seconds\":688,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-EMAIL-002",
      "description": "'Mailbox not connected' empty state with Connect Mailbox CTA",
      "status": "FAIL",
      "duration_ms": 60259.824957,
      "file_path": "/app/runner/tests/email/fe-email.test.ts",
      "test_path": "tests/email/fe-email.test.ts > Email System (FE-EMAIL) > FE-EMAIL-002 — 'Mailbox not connected' empty state with Connect Mailbox CTA",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 10m28s\",\"retry_after_seconds\":628,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-EMAIL-003",
      "description": "Connect Mailbox button opens OAuth flow (button presence)",
      "status": "FAIL",
      "duration_ms": 60512.045796000006,
      "file_path": "/app/runner/tests/email/fe-email.test.ts",
      "test_path": "tests/email/fe-email.test.ts > Email System (FE-EMAIL) > FE-EMAIL-003 — Connect Mailbox button opens OAuth flow (button presence)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 9m28s\",\"retry_after_seconds\":568,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-EMAIL-004",
      "description": "Email filters work (filter UI exists)",
      "status": "FAIL",
      "duration_ms": 60538.52111200002,
      "file_path": "/app/runner/tests/email/fe-email.test.ts",
      "test_path": "tests/email/fe-email.test.ts > Email System (FE-EMAIL) > FE-EMAIL-004 — Email filters work (filter UI exists)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 8m27s\",\"retry_after_seconds\":507,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-EMAIL-005",
      "description": "Search Emails input filters list",
      "status": "FAIL",
      "duration_ms": 60409.842064000026,
      "file_path": "/app/runner/tests/email/fe-email.test.ts",
      "test_path": "tests/email/fe-email.test.ts > Email System (FE-EMAIL) > FE-EMAIL-005 — Search Emails input filters list",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 7m27s\",\"retry_after_seconds\":447,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-EMAIL-006",
      "description": "'+' button opens compose / add modal",
      "status": "FAIL",
      "duration_ms": 60230.25345399999,
      "file_path": "/app/runner/tests/email/fe-email.test.ts",
      "test_path": "tests/email/fe-email.test.ts > Email System (FE-EMAIL) > FE-EMAIL-006 — '+' button opens compose / add modal",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 6m26s\",\"retry_after_seconds\":386,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-EMAIL-007",
      "description": "/email-system/email/add page renders without crashing",
      "status": "FAIL",
      "duration_ms": 60254.88623300003,
      "file_path": "/app/runner/tests/email/fe-email.test.ts",
      "test_path": "tests/email/fe-email.test.ts > Email System (FE-EMAIL) > FE-EMAIL-007 — /email-system/email/add page renders without crashing",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 5m26s\",\"retry_after_seconds\":326,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-EMAIL-008",
      "description": "Compose form requires recipient + subject + body",
      "status": "FAIL",
      "duration_ms": 60242.93591399997,
      "file_path": "/app/runner/tests/email/fe-email.test.ts",
      "test_path": "tests/email/fe-email.test.ts > Email System (FE-EMAIL) > FE-EMAIL-008 — Compose form requires recipient + subject + body",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 4m26s\",\"retry_after_seconds\":266,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-EMAIL-009",
      "description": "Send email triggers BFF call (network observation)",
      "status": "PASS",
      "duration_ms": 5.29166799999075,
      "file_path": "/app/runner/tests/email/fe-email.test.ts",
      "test_path": "tests/email/fe-email.test.ts > Email System (FE-EMAIL) > FE-EMAIL-009 — Send email triggers BFF call (network observation)"
    },
    {
      "id": "FE-EMAIL-010",
      "description": "/email-system/email/[id] shows email detail (route accessible)",
      "status": "FAIL",
      "duration_ms": 60384.16254500003,
      "file_path": "/app/runner/tests/email/fe-email.test.ts",
      "test_path": "tests/email/fe-email.test.ts > Email System (FE-EMAIL) > FE-EMAIL-010 — /email-system/email/[id] shows email detail (route accessible)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 3m26s\",\"retry_after_seconds\":206,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-EMAIL-011",
      "description": "Email categories sidebar navigates",
      "status": "FAIL",
      "duration_ms": 60449.18166599993,
      "file_path": "/app/runner/tests/email/fe-email.test.ts",
      "test_path": "tests/email/fe-email.test.ts > Email System (FE-EMAIL) > FE-EMAIL-011 — Email categories sidebar navigates",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 2m25s\",\"retry_after_seconds\":145,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-EMAIL-012",
      "description": "Pagination at top right (X of Y) updates with results",
      "status": "PASS",
      "duration_ms": 1.8397600000025705,
      "file_path": "/app/runner/tests/email/fe-email.test.ts",
      "test_path": "tests/email/fe-email.test.ts > Email System (FE-EMAIL) > FE-EMAIL-012 — Pagination at top right (X of Y) updates with results"
    },
    {
      "id": "FE-LAY-001",
      "description": "Sidebar visible on every authenticated dashboard page",
      "status": "PASS",
      "duration_ms": 7337.153349999999,
      "file_path": "/app/runner/tests/layout/fe-layout-cross.test.ts",
      "test_path": "tests/layout/fe-layout-cross.test.ts > Layout / Shell (FE-LAY) > FE-LAY-001 — Sidebar visible on every authenticated dashboard page"
    },
    {
      "id": "FE-LAY-002",
      "description": "Sidebar shows Dashboard / Campaign / Phone / Email / Settings (smoke)",
      "status": "FAIL",
      "duration_ms": 60970.225809999996,
      "file_path": "/app/runner/tests/layout/fe-layout-cross.test.ts",
      "test_path": "tests/layout/fe-layout-cross.test.ts > Layout / Shell (FE-LAY) > FE-LAY-002 — Sidebar shows Dashboard / Campaign / Phone / Email / Settings (smoke)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 12m35s\",\"retry_after_seconds\":755,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-LAY-003",
      "description": "Header shows credit balance, notification bell, sign out",
      "status": "FAIL",
      "duration_ms": 60323.573896999995,
      "file_path": "/app/runner/tests/layout/fe-layout-cross.test.ts",
      "test_path": "tests/layout/fe-layout-cross.test.ts > Layout / Shell (FE-LAY) > FE-LAY-003 — Header shows credit balance, notification bell, sign out",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 11m34s\",\"retry_after_seconds\":694,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-LAY-004",
      "description": "Active sidebar item highlighted in primary color (smoke)",
      "status": "PASS",
      "duration_ms": 1.3154619999986608,
      "file_path": "/app/runner/tests/layout/fe-layout-cross.test.ts",
      "test_path": "tests/layout/fe-layout-cross.test.ts > Layout / Shell (FE-LAY) > FE-LAY-004 — Active sidebar item highlighted in primary color (smoke)"
    },
    {
      "id": "FE-LAY-005",
      "description": "Click sidebar item navigates without full page reload (smoke)",
      "status": "PASS",
      "duration_ms": 0.8500580000109039,
      "file_path": "/app/runner/tests/layout/fe-layout-cross.test.ts",
      "test_path": "tests/layout/fe-layout-cross.test.ts > Layout / Shell (FE-LAY) > FE-LAY-005 — Click sidebar item navigates without full page reload (smoke)"
    },
    {
      "id": "FE-LAY-006",
      "description": "Mobile nav (<768px) collapses sidebar to hamburger (smoke)",
      "status": "PASS",
      "duration_ms": 0.4112840000016149,
      "file_path": "/app/runner/tests/layout/fe-layout-cross.test.ts",
      "test_path": "tests/layout/fe-layout-cross.test.ts > Layout / Shell (FE-LAY) > FE-LAY-006 — Mobile nav (<768px) collapses sidebar to hamburger (smoke)"
    },
    {
      "id": "FE-LAY-007",
      "description": "Layout no CLS when notifications appear/dismiss (smoke)",
      "status": "PASS",
      "duration_ms": 0.4503160000022035,
      "file_path": "/app/runner/tests/layout/fe-layout-cross.test.ts",
      "test_path": "tests/layout/fe-layout-cross.test.ts > Layout / Shell (FE-LAY) > FE-LAY-007 — Layout no CLS when notifications appear/dismiss (smoke)"
    },
    {
      "id": "FE-LAY-008",
      "description": "Layout no CLS when modals open/close (smoke)",
      "status": "PASS",
      "duration_ms": 0.3816990000050282,
      "file_path": "/app/runner/tests/layout/fe-layout-cross.test.ts",
      "test_path": "tests/layout/fe-layout-cross.test.ts > Layout / Shell (FE-LAY) > FE-LAY-008 — Layout no CLS when modals open/close (smoke)"
    },
    {
      "id": "FE-CROSS-001",
      "description": "All staging API calls go to *.test.revhero.io (FE-BUG-002 regression)",
      "status": "FAIL",
      "duration_ms": 60519.607868999985,
      "file_path": "/app/runner/tests/layout/fe-layout-cross.test.ts",
      "test_path": "tests/layout/fe-layout-cross.test.ts > Cross-cutting (FE-CROSS) > FE-CROSS-001 — All staging API calls go to *.test.revhero.io (FE-BUG-002 regression)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 10m34s\",\"retry_after_seconds\":634,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-CROSS-002",
      "description": "Cloud-document uploads go to staging cloud-documents (smoke)",
      "status": "PASS",
      "duration_ms": 1.2920319999975618,
      "file_path": "/app/runner/tests/layout/fe-layout-cross.test.ts",
      "test_path": "tests/layout/fe-layout-cross.test.ts > Cross-cutting (FE-CROSS) > FE-CROSS-002 — Cloud-document uploads go to staging cloud-documents (smoke)"
    },
    {
      "id": "FE-CROSS-003",
      "description": "Dev-only routes accessible on staging (proxy.ts hostname check)",
      "status": "FAIL",
      "duration_ms": 60327.80797599998,
      "file_path": "/app/runner/tests/layout/fe-layout-cross.test.ts",
      "test_path": "tests/layout/fe-layout-cross.test.ts > Cross-cutting (FE-CROSS) > FE-CROSS-003 — Dev-only routes accessible on staging (proxy.ts hostname check)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 9m33s\",\"retry_after_seconds\":573,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-CROSS-004",
      "description": "Same routes redirect to /automation-campaign on prod (skip on staging)",
      "status": "PASS",
      "duration_ms": 0.6156550000014249,
      "file_path": "/app/runner/tests/layout/fe-layout-cross.test.ts",
      "test_path": "tests/layout/fe-layout-cross.test.ts > Cross-cutting (FE-CROSS) > FE-CROSS-004 — Same routes redirect to /automation-campaign on prod (skip on staging)"
    },
    {
      "id": "FE-CROSS-005",
      "description": "Free Plan signup completes without payment form (FE-BUG-001 regression)",
      "status": "PASS",
      "duration_ms": 0.2841279999993276,
      "file_path": "/app/runner/tests/layout/fe-layout-cross.test.ts",
      "test_path": "tests/layout/fe-layout-cross.test.ts > Cross-cutting (FE-CROSS) > FE-CROSS-005 — Free Plan signup completes without payment form (FE-BUG-001 regression)"
    },
    {
      "id": "FE-CROSS-006",
      "description": "Plan-feature labels render numbers with thousands separators (smoke)",
      "status": "PASS",
      "duration_ms": 0.27090400000452064,
      "file_path": "/app/runner/tests/layout/fe-layout-cross.test.ts",
      "test_path": "tests/layout/fe-layout-cross.test.ts > Cross-cutting (FE-CROSS) > FE-CROSS-006 — Plan-feature labels render numbers with thousands separators (smoke)"
    },
    {
      "id": "FE-CROSS-007",
      "description": "Settings right-rail items don't truncate (smoke)",
      "status": "PASS",
      "duration_ms": 0.197225999989314,
      "file_path": "/app/runner/tests/layout/fe-layout-cross.test.ts",
      "test_path": "tests/layout/fe-layout-cross.test.ts > Cross-cutting (FE-CROSS) > FE-CROSS-007 — Settings right-rail items don't truncate (smoke)"
    },
    {
      "id": "FE-CROSS-008",
      "description": "Currency values show 2 decimals consistently (smoke)",
      "status": "PASS",
      "duration_ms": 0.2131249999802094,
      "file_path": "/app/runner/tests/layout/fe-layout-cross.test.ts",
      "test_path": "tests/layout/fe-layout-cross.test.ts > Cross-cutting (FE-CROSS) > FE-CROSS-008 — Currency values show 2 decimals consistently (smoke)"
    },
    {
      "id": "FE-CROSS-009",
      "description": "Campaign create header shows 'Untitled campaign' (FE-BUG-08 regression)",
      "status": "PASS",
      "duration_ms": 0.21501899999566376,
      "file_path": "/app/runner/tests/layout/fe-layout-cross.test.ts",
      "test_path": "tests/layout/fe-layout-cross.test.ts > Cross-cutting (FE-CROSS) > FE-CROSS-009 — Campaign create header shows 'Untitled campaign' (FE-BUG-08 regression)"
    },
    {
      "id": "FE-CROSS-010",
      "description": "Phone /sms doesn't get stuck on skeleton (FE-BUG-04 regression)",
      "status": "PASS",
      "duration_ms": 0.18457300000591204,
      "file_path": "/app/runner/tests/layout/fe-layout-cross.test.ts",
      "test_path": "tests/layout/fe-layout-cross.test.ts > Cross-cutting (FE-CROSS) > FE-CROSS-010 — Phone /sms doesn't get stuck on skeleton (FE-BUG-04 regression)"
    },
    {
      "id": "FE-NOTIF-001",
      "description": "/notifications renders list with All / Read / Unread tabs",
      "status": "PASS",
      "duration_ms": 7274.516728999999,
      "file_path": "/app/runner/tests/notifications/fe-notifications.test.ts",
      "test_path": "tests/notifications/fe-notifications.test.ts > Notifications + Help (FE-NOTIF / FE-HELP) > FE-NOTIF-001 — /notifications renders list with All / Read / Unread tabs"
    },
    {
      "id": "FE-NOTIF-002",
      "description": "Tabs filter notifications",
      "status": "PASS",
      "duration_ms": 4.42992200000117,
      "file_path": "/app/runner/tests/notifications/fe-notifications.test.ts",
      "test_path": "tests/notifications/fe-notifications.test.ts > Notifications + Help (FE-NOTIF / FE-HELP) > FE-NOTIF-002 — Tabs filter notifications"
    },
    {
      "id": "FE-NOTIF-003",
      "description": "Sub-tabs Email/SMS/LinkedIn/System filter by type",
      "status": "PASS",
      "duration_ms": 0.3954169999997248,
      "file_path": "/app/runner/tests/notifications/fe-notifications.test.ts",
      "test_path": "tests/notifications/fe-notifications.test.ts > Notifications + Help (FE-NOTIF / FE-HELP) > FE-NOTIF-003 — Sub-tabs Email/SMS/LinkedIn/System filter by type"
    },
    {
      "id": "FE-NOTIF-004",
      "description": "Mark all as read clears unread",
      "status": "PASS",
      "duration_ms": 0.37560000000121363,
      "file_path": "/app/runner/tests/notifications/fe-notifications.test.ts",
      "test_path": "tests/notifications/fe-notifications.test.ts > Notifications + Help (FE-NOTIF / FE-HELP) > FE-NOTIF-004 — Mark all as read clears unread"
    },
    {
      "id": "FE-NOTIF-005",
      "description": "Per-row 'Mark as Read' updates row (smoke)",
      "status": "PASS",
      "duration_ms": 0.2802620000002207,
      "file_path": "/app/runner/tests/notifications/fe-notifications.test.ts",
      "test_path": "tests/notifications/fe-notifications.test.ts > Notifications + Help (FE-NOTIF / FE-HELP) > FE-NOTIF-005 — Per-row 'Mark as Read' updates row (smoke)"
    },
    {
      "id": "FE-NOTIF-006",
      "description": "Notifications scoped to current account_id (smoke)",
      "status": "PASS",
      "duration_ms": 0.3451340000010532,
      "file_path": "/app/runner/tests/notifications/fe-notifications.test.ts",
      "test_path": "tests/notifications/fe-notifications.test.ts > Notifications + Help (FE-NOTIF / FE-HELP) > FE-NOTIF-006 — Notifications scoped to current account_id (smoke)"
    },
    {
      "id": "FE-NOTIF-007",
      "description": "Bell icon shows unread badge (smoke)",
      "status": "PASS",
      "duration_ms": 0.28413000000000466,
      "file_path": "/app/runner/tests/notifications/fe-notifications.test.ts",
      "test_path": "tests/notifications/fe-notifications.test.ts > Notifications + Help (FE-NOTIF / FE-HELP) > FE-NOTIF-007 — Bell icon shows unread badge (smoke)"
    },
    {
      "id": "FE-NOTIF-008",
      "description": "Relative timestamps update (smoke)",
      "status": "PASS",
      "duration_ms": 0.2558370000006107,
      "file_path": "/app/runner/tests/notifications/fe-notifications.test.ts",
      "test_path": "tests/notifications/fe-notifications.test.ts > Notifications + Help (FE-NOTIF / FE-HELP) > FE-NOTIF-008 — Relative timestamps update (smoke)"
    },
    {
      "id": "FE-HELP-001",
      "description": "/help renders FAQ section (dev-only on staging)",
      "status": "PASS",
      "duration_ms": 5838.1986959999995,
      "file_path": "/app/runner/tests/notifications/fe-notifications.test.ts",
      "test_path": "tests/notifications/fe-notifications.test.ts > Notifications + Help (FE-NOTIF / FE-HELP) > FE-HELP-001 — /help renders FAQ section (dev-only on staging)"
    },
    {
      "id": "FE-HELP-002",
      "description": "Search articles input filters FAQ",
      "status": "PASS",
      "duration_ms": 2.8557959999998275,
      "file_path": "/app/runner/tests/notifications/fe-notifications.test.ts",
      "test_path": "tests/notifications/fe-notifications.test.ts > Notifications + Help (FE-NOTIF / FE-HELP) > FE-HELP-002 — Search articles input filters FAQ"
    },
    {
      "id": "FE-HELP-003",
      "description": "Help category cards render",
      "status": "PASS",
      "duration_ms": 0.28485100000034436,
      "file_path": "/app/runner/tests/notifications/fe-notifications.test.ts",
      "test_path": "tests/notifications/fe-notifications.test.ts > Notifications + Help (FE-NOTIF / FE-HELP) > FE-HELP-003 — Help category cards render"
    },
    {
      "id": "FE-HELP-004",
      "description": "Contact Support button opens email/chat",
      "status": "PASS",
      "duration_ms": 0.192218000000139,
      "file_path": "/app/runner/tests/notifications/fe-notifications.test.ts",
      "test_path": "tests/notifications/fe-notifications.test.ts > Notifications + Help (FE-NOTIF / FE-HELP) > FE-HELP-004 — Contact Support button opens email/chat"
    },
    {
      "id": "FE-HELP-005",
      "description": "/getting-started checklist progress bar updates",
      "status": "PASS",
      "duration_ms": 5180.290661999999,
      "file_path": "/app/runner/tests/notifications/fe-notifications.test.ts",
      "test_path": "tests/notifications/fe-notifications.test.ts > Notifications + Help (FE-NOTIF / FE-HELP) > FE-HELP-005 — /getting-started checklist progress bar updates"
    },
    {
      "id": "FE-HELP-006",
      "description": "Watch Video opens modal",
      "status": "PASS",
      "duration_ms": 4.132236000001285,
      "file_path": "/app/runner/tests/notifications/fe-notifications.test.ts",
      "test_path": "tests/notifications/fe-notifications.test.ts > Notifications + Help (FE-NOTIF / FE-HELP) > FE-HELP-006 — Watch Video opens modal"
    },
    {
      "id": "FE-HELP-007",
      "description": "Add Signature redirects to email signature settings",
      "status": "PASS",
      "duration_ms": 5.028258000002097,
      "file_path": "/app/runner/tests/notifications/fe-notifications.test.ts",
      "test_path": "tests/notifications/fe-notifications.test.ts > Notifications + Help (FE-NOTIF / FE-HELP) > FE-HELP-007 — Add Signature redirects to email signature settings"
    },
    {
      "id": "FE-HELP-008",
      "description": "Start Guided Walkthrough triggers tour",
      "status": "PASS",
      "duration_ms": 0.5269029999981285,
      "file_path": "/app/runner/tests/notifications/fe-notifications.test.ts",
      "test_path": "tests/notifications/fe-notifications.test.ts > Notifications + Help (FE-NOTIF / FE-HELP) > FE-HELP-008 — Start Guided Walkthrough triggers tour"
    },
    {
      "id": "FE-PERF-001",
      "description": "/automation-campaign reaches DOMContentLoaded under 15000ms (warn >5000ms)",
      "status": "PASS",
      "duration_ms": 2639.2551129999997,
      "file_path": "/app/runner/tests/perf/fe-perf.test.ts",
      "test_path": "tests/perf/fe-perf.test.ts > Performance (FE-PERF) > FE-PERF-001 — /automation-campaign reaches DOMContentLoaded under 15000ms (warn >5000ms)"
    },
    {
      "id": "FE-PERF-002",
      "description": "/dashboard reaches DOMContentLoaded under 15000ms (warn >5000ms)",
      "status": "PASS",
      "duration_ms": 1547.8565719999997,
      "file_path": "/app/runner/tests/perf/fe-perf.test.ts",
      "test_path": "tests/perf/fe-perf.test.ts > Performance (FE-PERF) > FE-PERF-002 — /dashboard reaches DOMContentLoaded under 15000ms (warn >5000ms)"
    },
    {
      "id": "FE-PERF-003",
      "description": "/email-system/email reaches DOMContentLoaded under 15000ms (warn >5000ms)",
      "status": "PASS",
      "duration_ms": 1732.6433340000003,
      "file_path": "/app/runner/tests/perf/fe-perf.test.ts",
      "test_path": "tests/perf/fe-perf.test.ts > Performance (FE-PERF) > FE-PERF-003 — /email-system/email reaches DOMContentLoaded under 15000ms (warn >5000ms)"
    },
    {
      "id": "FE-PERF-004",
      "description": "/phone-system/sms reaches DOMContentLoaded under 15000ms (warn >5000ms)",
      "status": "FAIL",
      "duration_ms": 60844.559303,
      "file_path": "/app/runner/tests/perf/fe-perf.test.ts",
      "test_path": "tests/perf/fe-perf.test.ts > Performance (FE-PERF) > FE-PERF-004 — /phone-system/sms reaches DOMContentLoaded under 15000ms (warn >5000ms)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 12m39s\",\"retry_after_seconds\":759,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-PERF-005",
      "description": "/notifications reaches DOMContentLoaded under 15000ms (warn >5000ms)",
      "status": "FAIL",
      "duration_ms": 60386.75578800001,
      "file_path": "/app/runner/tests/perf/fe-perf.test.ts",
      "test_path": "tests/perf/fe-perf.test.ts > Performance (FE-PERF) > FE-PERF-005 — /notifications reaches DOMContentLoaded under 15000ms (warn >5000ms)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 11m39s\",\"retry_after_seconds\":699,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-PERF-006",
      "description": "/settings/general reaches DOMContentLoaded under 15000ms (warn >5000ms)",
      "status": "FAIL",
      "duration_ms": 60391.41356800002,
      "file_path": "/app/runner/tests/perf/fe-perf.test.ts",
      "test_path": "tests/perf/fe-perf.test.ts > Performance (FE-PERF) > FE-PERF-006 — /settings/general reaches DOMContentLoaded under 15000ms (warn >5000ms)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 10m39s\",\"retry_after_seconds\":639,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-PERF-007",
      "description": "/admin/dashboard reaches DOMContentLoaded under 15000ms (warn >5000ms)",
      "status": "FAIL",
      "duration_ms": 60579.92923399998,
      "file_path": "/app/runner/tests/perf/fe-perf.test.ts",
      "test_path": "tests/perf/fe-perf.test.ts > Performance (FE-PERF) > FE-PERF-007 — /admin/dashboard reaches DOMContentLoaded under 15000ms (warn >5000ms)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 9m38s\",\"retry_after_seconds\":578,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-PERF-008",
      "description": "axe-core /automation-campaign zero serious violations",
      "status": "FAIL",
      "duration_ms": 60221.89686400001,
      "file_path": "/app/runner/tests/perf/fe-perf.test.ts",
      "test_path": "tests/perf/fe-perf.test.ts > Performance (FE-PERF) > FE-PERF-008 — axe-core /automation-campaign zero serious violations",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 8m38s\",\"retry_after_seconds\":518,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-PERF-009",
      "description": "axe-core /settings/general zero serious violations",
      "status": "FAIL",
      "duration_ms": 60269.653857,
      "file_path": "/app/runner/tests/perf/fe-perf.test.ts",
      "test_path": "tests/perf/fe-perf.test.ts > Performance (FE-PERF) > FE-PERF-009 — axe-core /settings/general zero serious violations",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 7m37s\",\"retry_after_seconds\":457,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-PERF-010",
      "description": "Form inputs have associated labels (axe label rule)",
      "status": "FAIL",
      "duration_ms": 60260.69227700005,
      "file_path": "/app/runner/tests/perf/fe-perf.test.ts",
      "test_path": "tests/perf/fe-perf.test.ts > Performance (FE-PERF) > FE-PERF-010 — Form inputs have associated labels (axe label rule)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 6m37s\",\"retry_after_seconds\":397,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-PERF-011",
      "description": "Color contrast meets WCAG AA (axe color-contrast rule)",
      "status": "FAIL",
      "duration_ms": 60360.122221999976,
      "file_path": "/app/runner/tests/perf/fe-perf.test.ts",
      "test_path": "tests/perf/fe-perf.test.ts > Performance (FE-PERF) > FE-PERF-011 — Color contrast meets WCAG AA (axe color-contrast rule)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 5m37s\",\"retry_after_seconds\":337,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-PERF-012",
      "description": "Tab order through forms is logical (smoke)",
      "status": "PASS",
      "duration_ms": 2.2849150000256486,
      "file_path": "/app/runner/tests/perf/fe-perf.test.ts",
      "test_path": "tests/perf/fe-perf.test.ts > Performance (FE-PERF) > FE-PERF-012 — Tab order through forms is logical (smoke)"
    },
    {
      "id": "FE-PERF-013",
      "description": "Images have alt text (axe image-alt rule)",
      "status": "FAIL",
      "duration_ms": 60189.84730600001,
      "file_path": "/app/runner/tests/perf/fe-perf.test.ts",
      "test_path": "tests/perf/fe-perf.test.ts > Performance (FE-PERF) > FE-PERF-013 — Images have alt text (axe image-alt rule)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 4m37s\",\"retry_after_seconds\":277,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-PERF-014",
      "description": "Page titles match content (smoke)",
      "status": "PASS",
      "duration_ms": 0.8680369999492541,
      "file_path": "/app/runner/tests/perf/fe-perf.test.ts",
      "test_path": "tests/perf/fe-perf.test.ts > Performance (FE-PERF) > FE-PERF-014 — Page titles match content (smoke)"
    },
    {
      "id": "FE-PERF-015",
      "description": "No 404s on static assets (smoke — checked via network observer)",
      "status": "FAIL",
      "duration_ms": 60176.76189299999,
      "file_path": "/app/runner/tests/perf/fe-perf.test.ts",
      "test_path": "tests/perf/fe-perf.test.ts > Performance (FE-PERF) > FE-PERF-015 — No 404s on static assets (smoke — checked via network observer)",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 3m36s\",\"retry_after_seconds\":216,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-SEAT-001",
      "description": "Sub-User Invite form requires valid email + role",
      "status": "PASS",
      "duration_ms": 5784.4334,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Sub-user invite (FE-SEAT) > FE-SEAT-001 — Sub-User Invite form requires valid email + role"
    },
    {
      "id": "FE-SEAT-002",
      "description": "Invite creates pending seat row (smoke)",
      "status": "PASS",
      "duration_ms": 9.412285000000338,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Sub-user invite (FE-SEAT) > FE-SEAT-002 — Invite creates pending seat row (smoke)"
    },
    {
      "id": "FE-SEAT-003",
      "description": "Recipient receives /invite/[id] email (smoke)",
      "status": "PASS",
      "duration_ms": 3.6819900000000416,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Sub-user invite (FE-SEAT) > FE-SEAT-003 — Recipient receives /invite/[id] email (smoke)"
    },
    {
      "id": "FE-SEAT-004",
      "description": "/invite/[id] shows account + inviter + Accept",
      "status": "PASS",
      "duration_ms": 3711.540736,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Sub-user invite (FE-SEAT) > FE-SEAT-004 — /invite/[id] shows account + inviter + Accept"
    },
    {
      "id": "FE-SEAT-005",
      "description": "Accept invite from new email creates account (smoke)",
      "status": "PASS",
      "duration_ms": 0.40560199999890756,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Sub-user invite (FE-SEAT) > FE-SEAT-005 — Accept invite from new email creates account (smoke)"
    },
    {
      "id": "FE-SEAT-006",
      "description": "Reuse accepted invite shows already-accepted (smoke)",
      "status": "PASS",
      "duration_ms": 0.5649970000013127,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Sub-user invite (FE-SEAT) > FE-SEAT-006 — Reuse accepted invite shows already-accepted (smoke)"
    },
    {
      "id": "FE-SEAT-007",
      "description": "Expired invite shows expired-link (smoke)",
      "status": "PASS",
      "duration_ms": 0.16492599999946833,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Sub-user invite (FE-SEAT) > FE-SEAT-007 — Expired invite shows expired-link (smoke)"
    },
    {
      "id": "FE-SEAT-008",
      "description": "Admin revokes seat → MEMBER session invalidated (smoke)",
      "status": "PASS",
      "duration_ms": 0.49691100000018196,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Sub-user invite (FE-SEAT) > FE-SEAT-008 — Admin revokes seat → MEMBER session invalidated (smoke)"
    },
    {
      "id": "FE-SEAT-009",
      "description": "GET /v1/user/seats returns seat count",
      "status": "PASS",
      "duration_ms": 3367.772441000001,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Sub-user invite (FE-SEAT) > FE-SEAT-009 — GET /v1/user/seats returns seat count"
    },
    {
      "id": "FE-AH-001",
      "description": "PUT /v1/active-hours/:id saves schedule (smoke)",
      "status": "PASS",
      "duration_ms": 0.40453900000102294,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Active hours (FE-AH) > FE-AH-001 — PUT /v1/active-hours/:id saves schedule (smoke)"
    },
    {
      "id": "FE-AH-002",
      "description": "Stage actions defer outside active window (smoke)",
      "status": "PASS",
      "duration_ms": 0.19844799999918905,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Active hours (FE-AH) > FE-AH-002 — Stage actions defer outside active window (smoke)"
    },
    {
      "id": "FE-AH-003",
      "description": "Saturday outside window → defer to Monday (smoke)",
      "status": "PASS",
      "duration_ms": 1.4711049999987154,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Active hours (FE-AH) > FE-AH-003 — Saturday outside window → defer to Monday (smoke)"
    },
    {
      "id": "FE-AH-004",
      "description": "PUT /v1/active-hours-preferences globally disables (smoke)",
      "status": "PASS",
      "duration_ms": 0.5987679999998363,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Active hours (FE-AH) > FE-AH-004 — PUT /v1/active-hours-preferences globally disables (smoke)"
    },
    {
      "id": "FE-SIG-001",
      "description": "Save email signature persists across reload (smoke)",
      "status": "PASS",
      "duration_ms": 0.30725900000106776,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Signature + booking link (FE-SIG) > FE-SIG-001 — Save email signature persists across reload (smoke)"
    },
    {
      "id": "FE-SIG-002",
      "description": "Outbound email shows signature appended (smoke)",
      "status": "PASS",
      "duration_ms": 0.2668940000003204,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Signature + booking link (FE-SIG) > FE-SIG-002 — Outbound email shows signature appended (smoke)"
    },
    {
      "id": "FE-SIG-003",
      "description": "Save booking link persists (smoke)",
      "status": "PASS",
      "duration_ms": 0.18630599999960396,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Signature + booking link (FE-SIG) > FE-SIG-003 — Save booking link persists (smoke)"
    },
    {
      "id": "FE-SIG-004",
      "description": "{{sender_booking_link}} merge tag rendered (smoke)",
      "status": "PASS",
      "duration_ms": 0.2456449999990582,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Signature + booking link (FE-SIG) > FE-SIG-004 — {{sender_booking_link}} merge tag rendered (smoke)"
    },
    {
      "id": "FE-SIG-005",
      "description": "Empty signature → no trailing artifact (smoke)",
      "status": "PASS",
      "duration_ms": 0.17607700000007753,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Signature + booking link (FE-SIG) > FE-SIG-005 — Empty signature → no trailing artifact (smoke)"
    },
    {
      "id": "FE-MISC-001",
      "description": "Wrong current password → friendly error not 500 (smoke)",
      "status": "PASS",
      "duration_ms": 0.23972499999945285,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Misc settings (FE-MISC) > FE-MISC-001 — Wrong current password → friendly error not 500 (smoke)"
    },
    {
      "id": "FE-MISC-002",
      "description": "Same-as-old password blocked (smoke)",
      "status": "PASS",
      "duration_ms": 13.311117999999624,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Misc settings (FE-MISC) > FE-MISC-002 — Same-as-old password blocked (smoke)"
    },
    {
      "id": "FE-MISC-003",
      "description": "Password change success → next login uses new (smoke)",
      "status": "PASS",
      "duration_ms": 1.0654340000000957,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Misc settings (FE-MISC) > FE-MISC-003 — Password change success → next login uses new (smoke)"
    },
    {
      "id": "FE-MISC-004",
      "description": "Driver License upload accepts JPG/PNG/PDF (smoke)",
      "status": "PASS",
      "duration_ms": 1.9559430000008433,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Misc settings (FE-MISC) > FE-MISC-004 — Driver License upload accepts JPG/PNG/PDF (smoke)"
    },
    {
      "id": "FE-MISC-005",
      "description": "Driver License rejects >5 MB (smoke)",
      "status": "PASS",
      "duration_ms": 0.5220770000014454,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Misc settings (FE-MISC) > FE-MISC-005 — Driver License rejects >5 MB (smoke)"
    },
    {
      "id": "FE-MISC-006",
      "description": "GET /v1/user/driver-license returns previously uploaded",
      "status": "PASS",
      "duration_ms": 2342.350280999999,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Misc settings (FE-MISC) > FE-MISC-006 — GET /v1/user/driver-license returns previously uploaded"
    },
    {
      "id": "FE-MISC-007",
      "description": "Add invalid card → friendly inline error (smoke)",
      "status": "PASS",
      "duration_ms": 0.4864420000012615,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Misc settings (FE-MISC) > FE-MISC-007 — Add invalid card → friendly inline error (smoke)"
    },
    {
      "id": "FE-MISC-008",
      "description": "Delete only payment method blocked (smoke)",
      "status": "PASS",
      "duration_ms": 0.2588290000021516,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Misc settings (FE-MISC) > FE-MISC-008 — Delete only payment method blocked (smoke)"
    },
    {
      "id": "FE-MISC-009",
      "description": "Set default payment method updates (smoke)",
      "status": "PASS",
      "duration_ms": 4.0230330000013055,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Misc settings (FE-MISC) > FE-MISC-009 — Set default payment method updates (smoke)"
    },
    {
      "id": "FE-MISC-010",
      "description": "AI Customized Templates editor saves + renders (smoke)",
      "status": "PASS",
      "duration_ms": 0.28608900000108406,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Misc settings (FE-MISC) > FE-MISC-010 — AI Customized Templates editor saves + renders (smoke)"
    },
    {
      "id": "FE-PUR-001",
      "description": "/purchase-lists renders (dev-only on staging)",
      "status": "PASS",
      "duration_ms": 7070.2099670000025,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Purchase Lists (FE-PUR) > FE-PUR-001 — /purchase-lists renders (dev-only on staging)"
    },
    {
      "id": "FE-PUR-002",
      "description": "Search by Name filters list (smoke)",
      "status": "PASS",
      "duration_ms": 0.5727020000012999,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Purchase Lists (FE-PUR) > FE-PUR-002 — Search by Name filters list (smoke)"
    },
    {
      "id": "FE-PUR-003",
      "description": "Status badges In Progress / Success render correct colors (smoke)",
      "status": "PASS",
      "duration_ms": 0.3329860000012559,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Purchase Lists (FE-PUR) > FE-PUR-003 — Status badges In Progress / Success render correct colors (smoke)"
    },
    {
      "id": "FE-PUR-004",
      "description": "Download Leads icon enabled only on Success (smoke)",
      "status": "PASS",
      "duration_ms": 0.2823129999997036,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Purchase Lists (FE-PUR) > FE-PUR-004 — Download Leads icon enabled only on Success (smoke)"
    },
    {
      "id": "FE-PUR-005",
      "description": "/purchase-lists/create renders form",
      "status": "PASS",
      "duration_ms": 4564.984461,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Purchase Lists (FE-PUR) > FE-PUR-005 — /purchase-lists/create renders form"
    },
    {
      "id": "FE-PUR-006",
      "description": "Create requires name + filters (smoke)",
      "status": "PASS",
      "duration_ms": 0.44913200000155484,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Purchase Lists (FE-PUR) > FE-PUR-006 — Create requires name + filters (smoke)"
    },
    {
      "id": "FE-PUR-007",
      "description": "Pagination Rows-per-page selector (smoke)",
      "status": "PASS",
      "duration_ms": 0.23158900000271387,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Purchase Lists (FE-PUR) > FE-PUR-007 — Pagination Rows-per-page selector (smoke)"
    },
    {
      "id": "FE-PUR-008",
      "description": "Targeting eye-icon opens detail modal (smoke)",
      "status": "PASS",
      "duration_ms": 0.9094059999988531,
      "file_path": "/app/runner/tests/seats/fe-seat-ah-sig-misc.test.ts",
      "test_path": "tests/seats/fe-seat-ah-sig-misc.test.ts > Purchase Lists (FE-PUR) > FE-PUR-008 — Targeting eye-icon opens detail modal (smoke)"
    },
    {
      "id": "FE-SEC-001",
      "description": "Direct API call to BFF without token → 401",
      "status": "PASS",
      "duration_ms": 198.39901199999986,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Security (FE-SEC) > FE-SEC-001 — Direct API call to BFF without token → 401"
    },
    {
      "id": "FE-SEC-002",
      "description": "Manipulated JWT → 401, FE redirects to login",
      "status": "PASS",
      "duration_ms": 14.73526199999992,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Security (FE-SEC) > FE-SEC-002 — Manipulated JWT → 401, FE redirects to login"
    },
    {
      "id": "FE-SEC-003",
      "description": "XSS via campaign name escaped on render (smoke)",
      "status": "PASS",
      "duration_ms": 5.204643000000033,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Security (FE-SEC) > FE-SEC-003 — XSS via campaign name escaped on render (smoke)"
    },
    {
      "id": "FE-SEC-004",
      "description": "XSS via email signature escaped (smoke)",
      "status": "PASS",
      "duration_ms": 0.619513999999981,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Security (FE-SEC) > FE-SEC-004 — XSS via email signature escaped (smoke)"
    },
    {
      "id": "FE-SEC-005",
      "description": "XSS via business profile description escaped (smoke)",
      "status": "PASS",
      "duration_ms": 0.47014500000000226,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Security (FE-SEC) > FE-SEC-005 — XSS via business profile description escaped (smoke)"
    },
    {
      "id": "FE-SEC-006",
      "description": "SQL injection via search inputs safe (smoke — Prisma parameterised)",
      "status": "PASS",
      "duration_ms": 2.545671000000084,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Security (FE-SEC) > FE-SEC-006 — SQL injection via search inputs safe (smoke — Prisma parameterised)"
    },
    {
      "id": "FE-SEC-007",
      "description": "Direct nav to /admin/* as non-admin blocked",
      "status": "PASS",
      "duration_ms": 7959.203888,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Security (FE-SEC) > FE-SEC-007 — Direct nav to /admin/* as non-admin blocked"
    },
    {
      "id": "FE-SEC-008",
      "description": "IDOR /automation-campaign/[id] foreign id → 403/404 (smoke)",
      "status": "PASS",
      "duration_ms": 0.3537190000006376,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Security (FE-SEC) > FE-SEC-008 — IDOR /automation-campaign/[id] foreign id → 403/404 (smoke)"
    },
    {
      "id": "FE-SEC-009",
      "description": "IDOR /admin/billing/clients/[id] foreign id → 403/404 (smoke)",
      "status": "PASS",
      "duration_ms": 0.32441499999913503,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Security (FE-SEC) > FE-SEC-009 — IDOR /admin/billing/clients/[id] foreign id → 403/404 (smoke)"
    },
    {
      "id": "FE-SEC-010",
      "description": "File upload wrong type rejected (smoke)",
      "status": "PASS",
      "duration_ms": 0.2588209999994433,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Security (FE-SEC) > FE-SEC-010 — File upload wrong type rejected (smoke)"
    },
    {
      "id": "FE-SEC-011",
      "description": "File upload oversized rejected (smoke)",
      "status": "PASS",
      "duration_ms": 8.306801999999152,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Security (FE-SEC) > FE-SEC-011 — File upload oversized rejected (smoke)"
    },
    {
      "id": "FE-SEC-012",
      "description": "File upload uses staging cloud-documents URL (regression)",
      "status": "PASS",
      "duration_ms": 0.5374110000011569,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Security (FE-SEC) > FE-SEC-012 — File upload uses staging cloud-documents URL (regression)"
    },
    {
      "id": "FE-SEC-013",
      "description": "CSP blocks third-party scripts not in allowlist (smoke)",
      "status": "PASS",
      "duration_ms": 0.2837890000009793,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Security (FE-SEC) > FE-SEC-013 — CSP blocks third-party scripts not in allowlist (smoke)"
    },
    {
      "id": "FE-SEC-014",
      "description": "Frames-ancestors blocks iframe embedding (smoke)",
      "status": "PASS",
      "duration_ms": 591.7594130000016,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Security (FE-SEC) > FE-SEC-014 — Frames-ancestors blocks iframe embedding (smoke)"
    },
    {
      "id": "FE-SEC-015",
      "description": "Logout invalidates session token (smoke)",
      "status": "PASS",
      "duration_ms": 0.5332730000009178,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Security (FE-SEC) > FE-SEC-015 — Logout invalidates session token (smoke)"
    },
    {
      "id": "FE-ROLE-001",
      "description": "MEMBER login lands on dashboard",
      "status": "PASS",
      "duration_ms": 1606.8324570000004,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Multi-role enforcement (FE-ROLE) > FE-ROLE-001 — MEMBER login lands on dashboard"
    },
    {
      "id": "FE-ROLE-002",
      "description": "MEMBER /admin/dashboard redirected or 403",
      "status": "PASS",
      "duration_ms": 6004.191034000001,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Multi-role enforcement (FE-ROLE) > FE-ROLE-002 — MEMBER /admin/dashboard redirected or 403"
    },
    {
      "id": "FE-ROLE-003",
      "description": "MEMBER PUT /v1/admin/plans/:id → 403 (smoke)",
      "status": "PASS",
      "duration_ms": 0.5342950000012934,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Multi-role enforcement (FE-ROLE) > FE-ROLE-003 — MEMBER PUT /v1/admin/plans/:id → 403 (smoke)"
    },
    {
      "id": "FE-ROLE-004",
      "description": "MEMBER scoped to own account_id (smoke)",
      "status": "PASS",
      "duration_ms": 0.2625980000011623,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Multi-role enforcement (FE-ROLE) > FE-ROLE-004 — MEMBER scoped to own account_id (smoke)"
    },
    {
      "id": "FE-ROLE-005",
      "description": "MEMBER admin-only actions hidden from UI (smoke)",
      "status": "PASS",
      "duration_ms": 0.3445919999976468,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Multi-role enforcement (FE-ROLE) > FE-ROLE-005 — MEMBER admin-only actions hidden from UI (smoke)"
    },
    {
      "id": "FE-ROLE-006",
      "description": "MEMBER edits own profile, can't delete account (smoke)",
      "status": "PASS",
      "duration_ms": 1.1157590000002529,
      "file_path": "/app/runner/tests/security/fe-sec-role.test.ts",
      "test_path": "tests/security/fe-sec-role.test.ts > Multi-role enforcement (FE-ROLE) > FE-ROLE-006 — MEMBER edits own profile, can't delete account (smoke)"
    },
    {
      "id": "UNKNOWN-0bjw5h",
      "description": "WEBHOOK-AUTH-001 — email-ingress sentiment-webhook rejects without auth",
      "status": "PASS",
      "duration_ms": 159.663546,
      "file_path": "/app/runner/tests/security/fe-webhook-auth.test.ts",
      "test_path": "tests/security/fe-webhook-auth.test.ts > Internal-services webhook auth (cross-service) > WEBHOOK-AUTH-001 — email-ingress sentiment-webhook rejects without auth"
    },
    {
      "id": "UNKNOWN-u0ut0h",
      "description": "WEBHOOK-AUTH-002 — sms-service sentiment-webhook rejects without auth",
      "status": "PASS",
      "duration_ms": 62.29520200000002,
      "file_path": "/app/runner/tests/security/fe-webhook-auth.test.ts",
      "test_path": "tests/security/fe-webhook-auth.test.ts > Internal-services webhook auth (cross-service) > WEBHOOK-AUTH-002 — sms-service sentiment-webhook rejects without auth"
    },
    {
      "id": "UNKNOWN-h7jzr9",
      "description": "WEBHOOK-AUTH-003 — deal-mover sweeper rejects without auth",
      "status": "PASS",
      "duration_ms": 170.03902699999992,
      "file_path": "/app/runner/tests/security/fe-webhook-auth.test.ts",
      "test_path": "tests/security/fe-webhook-auth.test.ts > Internal-services webhook auth (cross-service) > WEBHOOK-AUTH-003 — deal-mover sweeper rejects without auth"
    },
    {
      "id": "FE-SET-G-016",
      "description": "/settings/general AI Chat Response tab renders",
      "status": "FAIL",
      "duration_ms": 60546.792885,
      "file_path": "/app/runner/tests/settings/fe-set-g-aichat.test.ts",
      "test_path": "tests/settings/fe-set-g-aichat.test.ts > AI Chat Response settings (FE-SET-G) > FE-SET-G-016 — /settings/general AI Chat Response tab renders",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 4m0s\",\"retry_after_seconds\":240,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-SET-G-017",
      "description": "Selecting a campaign reveals channel configuration toggles",
      "status": "FAIL",
      "duration_ms": 60235.205350000004,
      "file_path": "/app/runner/tests/settings/fe-set-g-aichat.test.ts",
      "test_path": "tests/settings/fe-set-g-aichat.test.ts > AI Chat Response settings (FE-SET-G) > FE-SET-G-017 — Selecting a campaign reveals channel configuration toggles",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 3m0s\",\"retry_after_seconds\":180,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-SET-G-018",
      "description": "AI chat config persists in LocalStorage across reload",
      "status": "FAIL",
      "duration_ms": 60169.11558500001,
      "file_path": "/app/runner/tests/settings/fe-set-g-aichat.test.ts",
      "test_path": "tests/settings/fe-set-g-aichat.test.ts > AI Chat Response settings (FE-SET-G) > FE-SET-G-018 — AI chat config persists in LocalStorage across reload",
      "error": "BFF /v1/auth/login returned 429: {\"data\":{\"error\":\"too many login attempts; try again in 2m0s\",\"retry_after_seconds\":120,\"scope\":\"email\"},\"message\":\"Too many login attempts. Please wait and try again.\"}"
    },
    {
      "id": "FE-SET-G-001",
      "description": "/settings/general renders Billing section by default",
      "status": "PASS",
      "duration_ms": 5607.559928000001,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — General (FE-SET-G) > FE-SET-G-001 — /settings/general renders Billing section by default"
    },
    {
      "id": "FE-SET-G-002",
      "description": "Right sidebar nav items show full text (fe-ui-01 regression)",
      "status": "PASS",
      "duration_ms": 11202.534482,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — General (FE-SET-G) > FE-SET-G-002 — Right sidebar nav items show full text (fe-ui-01 regression)"
    },
    {
      "id": "FE-SET-G-003",
      "description": "Right sidebar nav items list (smoke)",
      "status": "PASS",
      "duration_ms": 0.7577230000024429,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — General (FE-SET-G) > FE-SET-G-003 — Right sidebar nav items list (smoke)"
    },
    {
      "id": "FE-SET-G-004",
      "description": "Switching nav items updates panel without reload (smoke)",
      "status": "PASS",
      "duration_ms": 0.5616900000022724,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — General (FE-SET-G) > FE-SET-G-004 — Switching nav items updates panel without reload (smoke)"
    },
    {
      "id": "FE-SET-G-005",
      "description": "Current Plan card shows plan name + price (smoke)",
      "status": "PASS",
      "duration_ms": 0.33360800000082236,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — General (FE-SET-G) > FE-SET-G-005 — Current Plan card shows plan name + price (smoke)"
    },
    {
      "id": "FE-SET-G-006",
      "description": "Plan features show numbers with thousands separators (fe-ui-02 regression)",
      "status": "PASS",
      "duration_ms": 3123.5159490000005,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — General (FE-SET-G) > FE-SET-G-006 — Plan features show numbers with thousands separators (fe-ui-02 regression)"
    },
    {
      "id": "FE-SET-G-007",
      "description": "Promo code card shows discount + expiry + COPY (smoke)",
      "status": "PASS",
      "duration_ms": 1.083137000001443,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — General (FE-SET-G) > FE-SET-G-007 — Promo code card shows discount + expiry + COPY (smoke)"
    },
    {
      "id": "FE-SET-G-008",
      "description": "Manage Add-ons button opens manage-plans page (smoke)",
      "status": "PASS",
      "duration_ms": 0.29025799999726587,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — General (FE-SET-G) > FE-SET-G-008 — Manage Add-ons button opens manage-plans page (smoke)"
    },
    {
      "id": "FE-SET-G-009",
      "description": "CRM API tab shows connected CRM with masked key (smoke)",
      "status": "PASS",
      "duration_ms": 0.5906849999992119,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — General (FE-SET-G) > FE-SET-G-009 — CRM API tab shows connected CRM with masked key (smoke)"
    },
    {
      "id": "FE-SET-G-010",
      "description": "Sub-User Management lists invited users (smoke)",
      "status": "PASS",
      "duration_ms": 0.3717290000022331,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — General (FE-SET-G) > FE-SET-G-010 — Sub-User Management lists invited users (smoke)"
    },
    {
      "id": "FE-SET-G-011",
      "description": "Sub-User Invite form validates email (smoke)",
      "status": "PASS",
      "duration_ms": 0.309252999999444,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — General (FE-SET-G) > FE-SET-G-011 — Sub-User Invite form validates email (smoke)"
    },
    {
      "id": "FE-SET-G-012",
      "description": "Active Hours tab allows setting weekly schedule (smoke)",
      "status": "PASS",
      "duration_ms": 0.24670699999842327,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — General (FE-SET-G) > FE-SET-G-012 — Active Hours tab allows setting weekly schedule (smoke)"
    },
    {
      "id": "FE-SET-G-013",
      "description": "Email Signatures tab renders editor + preview (smoke)",
      "status": "PASS",
      "duration_ms": 0.24501500000042142,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — General (FE-SET-G) > FE-SET-G-013 — Email Signatures tab renders editor + preview (smoke)"
    },
    {
      "id": "FE-SET-G-014",
      "description": "Book Link tab persists URL (smoke)",
      "status": "PASS",
      "duration_ms": 0.3134910000007949,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — General (FE-SET-G) > FE-SET-G-014 — Book Link tab persists URL (smoke)"
    },
    {
      "id": "FE-SET-G-015",
      "description": "AI Customized Templates tab lists templates (smoke)",
      "status": "PASS",
      "duration_ms": 0.32719599999836646,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — General (FE-SET-G) > FE-SET-G-015 — AI Customized Templates tab lists templates (smoke)"
    },
    {
      "id": "FE-SET-S-001",
      "description": "/settings/system renders Brand Status + Phone Settings",
      "status": "PASS",
      "duration_ms": 4857.113355000001,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — System (FE-SET-S) > FE-SET-S-001 — /settings/system renders Brand Status + Phone Settings"
    },
    {
      "id": "FE-SET-S-002",
      "description": "Right sidebar Phone / Email Settings (smoke)",
      "status": "PASS",
      "duration_ms": 0.8582189999979164,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — System (FE-SET-S) > FE-SET-S-002 — Right sidebar Phone / Email Settings (smoke)"
    },
    {
      "id": "FE-SET-S-003",
      "description": "Brand Status badge color matches status (smoke)",
      "status": "PASS",
      "duration_ms": 0.2631080000028305,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — System (FE-SET-S) > FE-SET-S-003 — Brand Status badge color matches status (smoke)"
    },
    {
      "id": "FE-SET-S-004",
      "description": "Register Brand button opens modal (smoke)",
      "status": "PASS",
      "duration_ms": 0.1743830000013986,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — System (FE-SET-S) > FE-SET-S-004 — Register Brand button opens modal (smoke)"
    },
    {
      "id": "FE-SET-S-005",
      "description": "Phone Number Settings shows empty state (smoke)",
      "status": "PASS",
      "duration_ms": 0.5408319999987725,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — System (FE-SET-S) > FE-SET-S-005 — Phone Number Settings shows empty state (smoke)"
    },
    {
      "id": "FE-SET-S-006",
      "description": "Email Settings shows OAuth connection state (smoke)",
      "status": "PASS",
      "duration_ms": 0.3066689999977825,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — System (FE-SET-S) > FE-SET-S-006 — Email Settings shows OAuth connection state (smoke)"
    },
    {
      "id": "FE-SET-S-007",
      "description": "Save Route button persists route preferences (smoke)",
      "status": "PASS",
      "duration_ms": 0.19455099999686354,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — System (FE-SET-S) > FE-SET-S-007 — Save Route button persists route preferences (smoke)"
    },
    {
      "id": "FE-SET-M-001",
      "description": "/settings/manage-plans renders manage add-ons section",
      "status": "PASS",
      "duration_ms": 5671.680326000005,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — Manage Plans (FE-SET-M) > FE-SET-M-001 — /settings/manage-plans renders manage add-ons section"
    },
    {
      "id": "FE-SET-M-002",
      "description": "Existing add-ons list (smoke)",
      "status": "PASS",
      "duration_ms": 0.4577770000032615,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — Manage Plans (FE-SET-M) > FE-SET-M-002 — Existing add-ons list (smoke)"
    },
    {
      "id": "FE-SET-M-003",
      "description": "Empty state friendly message (smoke)",
      "status": "PASS",
      "duration_ms": 0.2719539999961853,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — Manage Plans (FE-SET-M) > FE-SET-M-003 — Empty state friendly message (smoke)"
    },
    {
      "id": "FE-SET-M-004",
      "description": "Available add-ons list (smoke)",
      "status": "PASS",
      "duration_ms": 1.0995379999949364,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — Manage Plans (FE-SET-M) > FE-SET-M-004 — Available add-ons list (smoke)"
    },
    {
      "id": "FE-SET-M-005",
      "description": "Add new add-on triggers checkout flow (smoke)",
      "status": "PASS",
      "duration_ms": 0.2132259999998496,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — Manage Plans (FE-SET-M) > FE-SET-M-005 — Add new add-on triggers checkout flow (smoke)"
    },
    {
      "id": "FE-SET-M-006",
      "description": "Cancel add-on triggers confirmation modal (smoke)",
      "status": "PASS",
      "duration_ms": 0.23416400000132853,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > Settings — Manage Plans (FE-SET-M) > FE-SET-M-006 — Cancel add-on triggers confirmation modal (smoke)"
    },
    {
      "id": "FE-USER-001",
      "description": "/user renders profile fields",
      "status": "PASS",
      "duration_ms": 7255.632390999999,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > User Settings (FE-USER) > FE-USER-001 — /user renders profile fields"
    },
    {
      "id": "FE-USER-002",
      "description": "Created date renders correctly (NOT 'Invalid Date')",
      "status": "PASS",
      "duration_ms": 6261.8386859999955,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > User Settings (FE-USER) > FE-USER-002 — Created date renders correctly (NOT 'Invalid Date')"
    },
    {
      "id": "FE-USER-003",
      "description": "Change Password button opens modal (smoke)",
      "status": "PASS",
      "duration_ms": 2.3322320000006584,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > User Settings (FE-USER) > FE-USER-003 — Change Password button opens modal (smoke)"
    },
    {
      "id": "FE-USER-004",
      "description": "Password modal validates fields (smoke)",
      "status": "PASS",
      "duration_ms": 0.47252700000535697,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > User Settings (FE-USER) > FE-USER-004 — Password modal validates fields (smoke)"
    },
    {
      "id": "FE-USER-005",
      "description": "Wrong current password → friendly error (smoke)",
      "status": "PASS",
      "duration_ms": 0.2880540000041947,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > User Settings (FE-USER) > FE-USER-005 — Wrong current password → friendly error (smoke)"
    },
    {
      "id": "FE-USER-006",
      "description": "Password change success closes modal + toast (smoke)",
      "status": "PASS",
      "duration_ms": 0.22087000000465196,
      "file_path": "/app/runner/tests/settings/fe-settings.test.ts",
      "test_path": "tests/settings/fe-settings.test.ts > User Settings (FE-USER) > FE-USER-006 — Password change success closes modal + toast (smoke)"
    },
    {
      "id": "FE-PHONE-001",
      "description": "/phone-system redirects to /phone-system/sms",
      "status": "PASS",
      "duration_ms": 6952.255784999999,
      "file_path": "/app/runner/tests/sms/fe-phone.test.ts",
      "test_path": "tests/sms/fe-phone.test.ts > Phone System (FE-PHONE) > FE-PHONE-001 — /phone-system redirects to /phone-system/sms"
    },
    {
      "id": "FE-PHONE-002",
      "description": "/phone-system/sms renders empty state (FE-BUG-04 fix — no permanent skeleton)",
      "status": "PASS",
      "duration_ms": 9110.763769000001,
      "file_path": "/app/runner/tests/sms/fe-phone.test.ts",
      "test_path": "tests/sms/fe-phone.test.ts > Phone System (FE-PHONE) > FE-PHONE-002 — /phone-system/sms renders empty state (FE-BUG-04 fix — no permanent skeleton)"
    },
    {
      "id": "FE-PHONE-003",
      "description": "Empty state shows 'Go to Phone System Settings' CTA (best-effort)",
      "status": "PASS",
      "duration_ms": 5377.278464999999,
      "file_path": "/app/runner/tests/sms/fe-phone.test.ts",
      "test_path": "tests/sms/fe-phone.test.ts > Phone System (FE-PHONE) > FE-PHONE-003 — Empty state shows 'Go to Phone System Settings' CTA (best-effort)"
    },
    {
      "id": "FE-PHONE-004",
      "description": "/phone-system/voicemails lists voicemails or empty state",
      "status": "PASS",
      "duration_ms": 4230.933731999998,
      "file_path": "/app/runner/tests/sms/fe-phone.test.ts",
      "test_path": "tests/sms/fe-phone.test.ts > Phone System (FE-PHONE) > FE-PHONE-004 — /phone-system/voicemails lists voicemails or empty state"
    },
    {
      "id": "FE-PHONE-005",
      "description": "Brand registration flow accessible from phone system",
      "status": "PASS",
      "duration_ms": 0.5274329999992915,
      "file_path": "/app/runner/tests/sms/fe-phone.test.ts",
      "test_path": "tests/sms/fe-phone.test.ts > Phone System (FE-PHONE) > FE-PHONE-005 — Brand registration flow accessible from phone system"
    },
    {
      "id": "FE-PHONE-006",
      "description": "A2P status badge displays correct color/text (smoke)",
      "status": "PASS",
      "duration_ms": 0.5481619999991381,
      "file_path": "/app/runner/tests/sms/fe-phone.test.ts",
      "test_path": "tests/sms/fe-phone.test.ts > Phone System (FE-PHONE) > FE-PHONE-006 — A2P status badge displays correct color/text (smoke)"
    },
    {
      "id": "FE-PHONE-007",
      "description": "Phone Number purchase flow renders available numbers (smoke)",
      "status": "PASS",
      "duration_ms": 1.318437999998423,
      "file_path": "/app/runner/tests/sms/fe-phone.test.ts",
      "test_path": "tests/sms/fe-phone.test.ts > Phone System (FE-PHONE) > FE-PHONE-007 — Phone Number purchase flow renders available numbers (smoke)"
    },
    {
      "id": "FE-PHONE-008",
      "description": "Buy phone number button triggers purchase API call (smoke)",
      "status": "PASS",
      "duration_ms": 0.2914230000023963,
      "file_path": "/app/runner/tests/sms/fe-phone.test.ts",
      "test_path": "tests/sms/fe-phone.test.ts > Phone System (FE-PHONE) > FE-PHONE-008 — Buy phone number button triggers purchase API call (smoke)"
    },
    {
      "id": "FE-PHONE-009",
      "description": "Send SMS modal validates recipient + body (smoke)",
      "status": "PASS",
      "duration_ms": 0.3795170000012149,
      "file_path": "/app/runner/tests/sms/fe-phone.test.ts",
      "test_path": "tests/sms/fe-phone.test.ts > Phone System (FE-PHONE) > FE-PHONE-009 — Send SMS modal validates recipient + body (smoke)"
    },
    {
      "id": "FE-SMS-TOKY-001",
      "description": "BYOC card lists Toky in /settings/system (smoke)",
      "status": "PASS",
      "duration_ms": 4.1964620000001105,
      "file_path": "/app/runner/tests/sms/fe-sms-toky.test.ts",
      "test_path": "tests/sms/fe-sms-toky.test.ts > Toky BYOC path (FE-SMS-TOKY) > FE-SMS-TOKY-001 — BYOC card lists Toky in /settings/system (smoke)"
    },
    {
      "id": "FE-SMS-TOKY-002",
      "description": "Save bogus Toky API key → red error (smoke)",
      "status": "PASS",
      "duration_ms": 1.2128399999999147,
      "file_path": "/app/runner/tests/sms/fe-sms-toky.test.ts",
      "test_path": "tests/sms/fe-sms-toky.test.ts > Toky BYOC path (FE-SMS-TOKY) > FE-SMS-TOKY-002 — Save bogus Toky API key → red error (smoke)"
    },
    {
      "id": "FE-SMS-TOKY-003",
      "description": "Save real test API key creates carrier_credentials row (smoke)",
      "status": "PASS",
      "duration_ms": 0.36877700000013647,
      "file_path": "/app/runner/tests/sms/fe-sms-toky.test.ts",
      "test_path": "tests/sms/fe-sms-toky.test.ts > Toky BYOC path (FE-SMS-TOKY) > FE-SMS-TOKY-003 — Save real test API key creates carrier_credentials row (smoke)"
    },
    {
      "id": "FE-SMS-TOKY-004",
      "description": "Save handshake registers webhook on Toky side (smoke)",
      "status": "PASS",
      "duration_ms": 0.29415900000003603,
      "file_path": "/app/runner/tests/sms/fe-sms-toky.test.ts",
      "test_path": "tests/sms/fe-sms-toky.test.ts > Toky BYOC path (FE-SMS-TOKY) > FE-SMS-TOKY-004 — Save handshake registers webhook on Toky side (smoke)"
    },
    {
      "id": "FE-SMS-TOKY-005",
      "description": "Re-save credential clears existing webhook auth (smoke)",
      "status": "PASS",
      "duration_ms": 0.19439200000010715,
      "file_path": "/app/runner/tests/sms/fe-sms-toky.test.ts",
      "test_path": "tests/sms/fe-sms-toky.test.ts > Toky BYOC path (FE-SMS-TOKY) > FE-SMS-TOKY-005 — Re-save credential clears existing webhook auth (smoke)"
    },
    {
      "id": "FE-SMS-TOKY-006",
      "description": "Add Toky Number lists user inventory (smoke)",
      "status": "PASS",
      "duration_ms": 0.6843860000001314,
      "file_path": "/app/runner/tests/sms/fe-sms-toky.test.ts",
      "test_path": "tests/sms/fe-sms-toky.test.ts > Toky BYOC path (FE-SMS-TOKY) > FE-SMS-TOKY-006 — Add Toky Number lists user inventory (smoke)"
    },
    {
      "id": "FE-SMS-TOKY-007",
      "description": "Import test number creates phonenumbers row (smoke)",
      "status": "PASS",
      "duration_ms": 0.5485529999998562,
      "file_path": "/app/runner/tests/sms/fe-sms-toky.test.ts",
      "test_path": "tests/sms/fe-sms-toky.test.ts > Toky BYOC path (FE-SMS-TOKY) > FE-SMS-TOKY-007 — Import test number creates phonenumbers row (smoke)"
    },
    {
      "id": "FE-SMS-TOKY-008",
      "description": "Send SMS via Toky doesn't decrement credits (smoke)",
      "status": "PASS",
      "duration_ms": 0.30174200000010387,
      "file_path": "/app/runner/tests/sms/fe-sms-toky.test.ts",
      "test_path": "tests/sms/fe-sms-toky.test.ts > Toky BYOC path (FE-SMS-TOKY) > FE-SMS-TOKY-008 — Send SMS via Toky doesn't decrement credits (smoke)"
    },
    {
      "id": "FE-SMS-TOKY-009",
      "description": "Reply lands inbound within 10s (smoke)",
      "status": "PASS",
      "duration_ms": 0.4379159999998592,
      "file_path": "/app/runner/tests/sms/fe-sms-toky.test.ts",
      "test_path": "tests/sms/fe-sms-toky.test.ts > Toky BYOC path (FE-SMS-TOKY) > FE-SMS-TOKY-009 — Reply lands inbound within 10s (smoke)"
    },
    {
      "id": "FE-SMS-TOKY-010",
      "description": "Toky inbound webhook validates HTTP Basic auth",
      "status": "PASS",
      "duration_ms": 175.57484799999997,
      "file_path": "/app/runner/tests/sms/fe-sms-toky.test.ts",
      "test_path": "tests/sms/fe-sms-toky.test.ts > Toky BYOC path (FE-SMS-TOKY) > FE-SMS-TOKY-010 — Toky inbound webhook validates HTTP Basic auth"
    },
    {
      "id": "FE-SMS-TOKY-011",
      "description": "Toky payload is JSON array (smoke)",
      "status": "PASS",
      "duration_ms": 0.36011099999996077,
      "file_path": "/app/runner/tests/sms/fe-sms-toky.test.ts",
      "test_path": "tests/sms/fe-sms-toky.test.ts > Toky BYOC path (FE-SMS-TOKY) > FE-SMS-TOKY-011 — Toky payload is JSON array (smoke)"
    },
    {
      "id": "FE-SMS-TOKY-012",
      "description": "Toky inbound NEGATIVE sentiment marks deal LOST (smoke)",
      "status": "PASS",
      "duration_ms": 0.641365000000178,
      "file_path": "/app/runner/tests/sms/fe-sms-toky.test.ts",
      "test_path": "tests/sms/fe-sms-toky.test.ts > Toky BYOC path (FE-SMS-TOKY) > FE-SMS-TOKY-012 — Toky inbound NEGATIVE sentiment marks deal LOST (smoke)"
    },
    {
      "id": "FE-SMS-TOKY-013",
      "description": "Replay same payload twice → idempotent (smoke)",
      "status": "PASS",
      "duration_ms": 0.2604149999999663,
      "file_path": "/app/runner/tests/sms/fe-sms-toky.test.ts",
      "test_path": "tests/sms/fe-sms-toky.test.ts > Toky BYOC path (FE-SMS-TOKY) > FE-SMS-TOKY-013 — Replay same payload twice → idempotent (smoke)"
    },
    {
      "id": "FE-SMS-TOKY-014",
      "description": "Disconnect Toky credential revokes webhook (smoke)",
      "status": "PASS",
      "duration_ms": 0.3404440000001614,
      "file_path": "/app/runner/tests/sms/fe-sms-toky.test.ts",
      "test_path": "tests/sms/fe-sms-toky.test.ts > Toky BYOC path (FE-SMS-TOKY) > FE-SMS-TOKY-014 — Disconnect Toky credential revokes webhook (smoke)"
    },
    {
      "id": "FE-SMS-TOKY-015",
      "description": "Twilio + Toky number coexistence (smoke)",
      "status": "PASS",
      "duration_ms": 0.275574000000006,
      "file_path": "/app/runner/tests/sms/fe-sms-toky.test.ts",
      "test_path": "tests/sms/fe-sms-toky.test.ts > Toky BYOC path (FE-SMS-TOKY) > FE-SMS-TOKY-015 — Twilio + Toky number coexistence (smoke)"
    },
    {
      "id": "FE-SMS-TOKY-016",
      "description": "AI personalization charges AI credits but not phone (smoke)",
      "status": "PASS",
      "duration_ms": 0.7820389999999406,
      "file_path": "/app/runner/tests/sms/fe-sms-toky.test.ts",
      "test_path": "tests/sms/fe-sms-toky.test.ts > Toky BYOC path (FE-SMS-TOKY) > FE-SMS-TOKY-016 — AI personalization charges AI credits but not phone (smoke)"
    },
    {
      "id": "FE-SMS-TOKY-017",
      "description": "Twilio regression after Toky enabled (smoke)",
      "status": "PASS",
      "duration_ms": 0.3443019999999706,
      "file_path": "/app/runner/tests/sms/fe-sms-toky.test.ts",
      "test_path": "tests/sms/fe-sms-toky.test.ts > Toky BYOC path (FE-SMS-TOKY) > FE-SMS-TOKY-017 — Twilio regression after Toky enabled (smoke)"
    },
    {
      "id": "FE-SMS-TOKY-018",
      "description": "Legacy provider=NULL treated as 'twilio' (smoke)",
      "status": "PASS",
      "duration_ms": 0.22473999999988337,
      "file_path": "/app/runner/tests/sms/fe-sms-toky.test.ts",
      "test_path": "tests/sms/fe-sms-toky.test.ts > Toky BYOC path (FE-SMS-TOKY) > FE-SMS-TOKY-018 — Legacy provider=NULL treated as 'twilio' (smoke)"
    },
    {
      "id": "FE-SMS-TOKY-019",
      "description": "Toky API key with zero numbers → empty inventory (smoke)",
      "status": "PASS",
      "duration_ms": 0.23730199999999968,
      "file_path": "/app/runner/tests/sms/fe-sms-toky.test.ts",
      "test_path": "tests/sms/fe-sms-toky.test.ts > Toky BYOC path (FE-SMS-TOKY) > FE-SMS-TOKY-019 — Toky API key with zero numbers → empty inventory (smoke)"
    },
    {
      "id": "FE-SMS-TOKY-020",
      "description": "Webhook dedup respects DRF pagination shape (smoke)",
      "status": "PASS",
      "duration_ms": 0.340012999999999,
      "file_path": "/app/runner/tests/sms/fe-sms-toky.test.ts",
      "test_path": "tests/sms/fe-sms-toky.test.ts > Toky BYOC path (FE-SMS-TOKY) > FE-SMS-TOKY-020 — Webhook dedup respects DRF pagination shape (smoke)"
    },
    {
      "id": "FE-SMS-TW-001",
      "description": "A2P brand registration starts from /settings/system (smoke)",
      "status": "PASS",
      "duration_ms": 2.56910199999993,
      "file_path": "/app/runner/tests/sms/fe-sms-tw.test.ts",
      "test_path": "tests/sms/fe-sms-tw.test.ts > Twilio SMS path (FE-SMS-TW) > FE-SMS-TW-001 — A2P brand registration starts from /settings/system (smoke)"
    },
    {
      "id": "FE-SMS-TW-002",
      "description": "Phone-number purchase blocked when A2P != brand_approved",
      "status": "PASS",
      "duration_ms": 1.9339570000001913,
      "file_path": "/app/runner/tests/sms/fe-sms-tw.test.ts",
      "test_path": "tests/sms/fe-sms-tw.test.ts > Twilio SMS path (FE-SMS-TW) > FE-SMS-TW-002 — Phone-number purchase blocked when A2P != brand_approved"
    },
    {
      "id": "FE-SMS-TW-003",
      "description": "Phone-number purchase succeeds when approved",
      "status": "PASS",
      "duration_ms": 2.6089059999999336,
      "file_path": "/app/runner/tests/sms/fe-sms-tw.test.ts",
      "test_path": "tests/sms/fe-sms-tw.test.ts > Twilio SMS path (FE-SMS-TW) > FE-SMS-TW-003 — Phone-number purchase succeeds when approved"
    },
    {
      "id": "FE-SMS-TW-004",
      "description": "Send SMS from /phone-system/sms (smoke)",
      "status": "PASS",
      "duration_ms": 1.313579000000118,
      "file_path": "/app/runner/tests/sms/fe-sms-tw.test.ts",
      "test_path": "tests/sms/fe-sms-tw.test.ts > Twilio SMS path (FE-SMS-TW) > FE-SMS-TW-004 — Send SMS from /phone-system/sms (smoke)"
    },
    {
      "id": "FE-SMS-TW-005",
      "description": "Send SMS with merge tag rendered correctly",
      "status": "PASS",
      "duration_ms": 0.6638880000000427,
      "file_path": "/app/runner/tests/sms/fe-sms-tw.test.ts",
      "test_path": "tests/sms/fe-sms-tw.test.ts > Twilio SMS path (FE-SMS-TW) > FE-SMS-TW-005 — Send SMS with merge tag rendered correctly"
    },
    {
      "id": "FE-SMS-TW-006",
      "description": "Send SMS with no credits → 402 / out-of-credits",
      "status": "PASS",
      "duration_ms": 0.45949800000016694,
      "file_path": "/app/runner/tests/sms/fe-sms-tw.test.ts",
      "test_path": "tests/sms/fe-sms-tw.test.ts > Twilio SMS path (FE-SMS-TW) > FE-SMS-TW-006 — Send SMS with no credits → 402 / out-of-credits"
    },
    {
      "id": "FE-SMS-TW-007",
      "description": "Twilio API failure releases reserved credits",
      "status": "PASS",
      "duration_ms": 0.4966660000000047,
      "file_path": "/app/runner/tests/sms/fe-sms-tw.test.ts",
      "test_path": "tests/sms/fe-sms-tw.test.ts > Twilio SMS path (FE-SMS-TW) > FE-SMS-TW-007 — Twilio API failure releases reserved credits"
    },
    {
      "id": "FE-SMS-TW-008",
      "description": "Send SMS exceeds rate limit → 429",
      "status": "PASS",
      "duration_ms": 0.2875659999999698,
      "file_path": "/app/runner/tests/sms/fe-sms-tw.test.ts",
      "test_path": "tests/sms/fe-sms-tw.test.ts > Twilio SMS path (FE-SMS-TW) > FE-SMS-TW-008 — Send SMS exceeds rate limit → 429"
    },
    {
      "id": "FE-SMS-TW-009",
      "description": "Inbound SMS appears in FE thread (smoke)",
      "status": "PASS",
      "duration_ms": 3.6623400000000856,
      "file_path": "/app/runner/tests/sms/fe-sms-tw.test.ts",
      "test_path": "tests/sms/fe-sms-tw.test.ts > Twilio SMS path (FE-SMS-TW) > FE-SMS-TW-009 — Inbound SMS appears in FE thread (smoke)"
    },
    {
      "id": "FE-SMS-TW-010",
      "description": "Inbound negative sentiment marks deal LOST (smoke)",
      "status": "PASS",
      "duration_ms": 0.8160609999999906,
      "file_path": "/app/runner/tests/sms/fe-sms-tw.test.ts",
      "test_path": "tests/sms/fe-sms-tw.test.ts > Twilio SMS path (FE-SMS-TW) > FE-SMS-TW-010 — Inbound negative sentiment marks deal LOST (smoke)"
    },
    {
      "id": "FE-SMS-TW-011",
      "description": "Twilio webhook with wrong bears_key → 401",
      "status": "PASS",
      "duration_ms": 225.98704700000008,
      "file_path": "/app/runner/tests/sms/fe-sms-tw.test.ts",
      "test_path": "tests/sms/fe-sms-tw.test.ts > Twilio SMS path (FE-SMS-TW) > FE-SMS-TW-011 — Twilio webhook with wrong bears_key → 401"
    },
    {
      "id": "FE-SMS-TW-012",
      "description": "Twilio status callback updates messages.status (smoke)",
      "status": "PASS",
      "duration_ms": 0.30472899999995207,
      "file_path": "/app/runner/tests/sms/fe-sms-tw.test.ts",
      "test_path": "tests/sms/fe-sms-tw.test.ts > Twilio SMS path (FE-SMS-TW) > FE-SMS-TW-012 — Twilio status callback updates messages.status (smoke)"
    },
    {
      "id": "FE-ACT-VM-001",
      "description": "POST /v1/stages/:id/actions/voicemail endpoint exists",
      "status": "PASS",
      "duration_ms": 2887.3687149999996,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — Voicemail (FE-ACT-VM) > FE-ACT-VM-001 — POST /v1/stages/:id/actions/voicemail endpoint exists"
    },
    {
      "id": "FE-ACT-VM-002",
      "description": "Voicemail editor accepts audio upload (smoke)",
      "status": "PASS",
      "duration_ms": 2.145195000000058,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — Voicemail (FE-ACT-VM) > FE-ACT-VM-002 — Voicemail editor accepts audio upload (smoke)"
    },
    {
      "id": "FE-ACT-VM-003",
      "description": "PUT updates voicemail action (smoke)",
      "status": "PASS",
      "duration_ms": 0.6138380000002144,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — Voicemail (FE-ACT-VM) > FE-ACT-VM-003 — PUT updates voicemail action (smoke)"
    },
    {
      "id": "FE-ACT-VM-004",
      "description": "DELETE removes action (smoke)",
      "status": "PASS",
      "duration_ms": 0.343656999999439,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — Voicemail (FE-ACT-VM) > FE-ACT-VM-004 — DELETE removes action (smoke)"
    },
    {
      "id": "FE-ACT-VM-005",
      "description": "Trigger dispatches voicemail (smoke)",
      "status": "PASS",
      "duration_ms": 0.35897599999952945,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — Voicemail (FE-ACT-VM) > FE-ACT-VM-005 — Trigger dispatches voicemail (smoke)"
    },
    {
      "id": "FE-ACT-VM-006",
      "description": "Reject wrong file type with friendly error (smoke)",
      "status": "PASS",
      "duration_ms": 0.628935000000638,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — Voicemail (FE-ACT-VM) > FE-ACT-VM-006 — Reject wrong file type with friendly error (smoke)"
    },
    {
      "id": "FE-ACT-VM-007",
      "description": "Reject oversized audio with friendly error (smoke)",
      "status": "PASS",
      "duration_ms": 0.3651060000001962,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — Voicemail (FE-ACT-VM) > FE-ACT-VM-007 — Reject oversized audio with friendly error (smoke)"
    },
    {
      "id": "FE-ACT-AIC-001",
      "description": "POST /v1/stages/:id/actions/ai-call endpoint exists",
      "status": "PASS",
      "duration_ms": 1185.4655590000002,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — AI Call (FE-ACT-AIC) > FE-ACT-AIC-001 — POST /v1/stages/:id/actions/ai-call endpoint exists"
    },
    {
      "id": "FE-ACT-AIC-002",
      "description": "PUT updates AI-call action (smoke)",
      "status": "PASS",
      "duration_ms": 1.2703950000004625,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — AI Call (FE-ACT-AIC) > FE-ACT-AIC-002 — PUT updates AI-call action (smoke)"
    },
    {
      "id": "FE-ACT-AIC-003",
      "description": "DELETE removes action (smoke)",
      "status": "PASS",
      "duration_ms": 0.3585349999993923,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — AI Call (FE-ACT-AIC) > FE-ACT-AIC-003 — DELETE removes action (smoke)"
    },
    {
      "id": "FE-ACT-AIC-004",
      "description": "Trigger requests AI call (smoke)",
      "status": "PASS",
      "duration_ms": 0.2670850000004066,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — AI Call (FE-ACT-AIC) > FE-ACT-AIC-004 — Trigger requests AI call (smoke)"
    },
    {
      "id": "FE-ACT-AIC-005",
      "description": "Empty prompt_template → validation error (smoke)",
      "status": "PASS",
      "duration_ms": 0.20865799999955925,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — AI Call (FE-ACT-AIC) > FE-ACT-AIC-005 — Empty prompt_template → validation error (smoke)"
    },
    {
      "id": "FE-ACT-BBS-001",
      "description": "Endpoint exists",
      "status": "PASS",
      "duration_ms": 1574.219099,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — BizBuySell (FE-ACT-BBS) > FE-ACT-BBS-001 — Endpoint exists"
    },
    {
      "id": "FE-ACT-BBS-002",
      "description": "CRUD verified (smoke)",
      "status": "PASS",
      "duration_ms": 0.3721800000002986,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — BizBuySell (FE-ACT-BBS) > FE-ACT-BBS-002 — CRUD verified (smoke)"
    },
    {
      "id": "FE-ACT-BBS-003",
      "description": "Trigger dispatches request (smoke)",
      "status": "PASS",
      "duration_ms": 0.23295099999995728,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — BizBuySell (FE-ACT-BBS) > FE-ACT-BBS-003 — Trigger dispatches request (smoke)"
    },
    {
      "id": "FE-ACT-PD-001",
      "description": "Endpoint exists",
      "status": "PASS",
      "duration_ms": 1778.7934990000012,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — PandaDoc (FE-ACT-PD) > FE-ACT-PD-001 — Endpoint exists"
    },
    {
      "id": "FE-ACT-PD-002",
      "description": "Editor lists folders/templates (smoke)",
      "status": "PASS",
      "duration_ms": 0.3071190000009665,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — PandaDoc (FE-ACT-PD) > FE-ACT-PD-002 — Editor lists folders/templates (smoke)"
    },
    {
      "id": "FE-ACT-PD-003",
      "description": "CRUD verified (smoke)",
      "status": "PASS",
      "duration_ms": 0.4022560000012163,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — PandaDoc (FE-ACT-PD) > FE-ACT-PD-003 — CRUD verified (smoke)"
    },
    {
      "id": "FE-ACT-PD-004",
      "description": "Trigger creates + emails doc (smoke)",
      "status": "PASS",
      "duration_ms": 0.14849499999945692,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — PandaDoc (FE-ACT-PD) > FE-ACT-PD-004 — Trigger creates + emails doc (smoke)"
    },
    {
      "id": "FE-ACT-PD-005",
      "description": "Invalid template_id → graceful failure (smoke)",
      "status": "PASS",
      "duration_ms": 0.18601499999931548,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — PandaDoc (FE-ACT-PD) > FE-ACT-PD-005 — Invalid template_id → graceful failure (smoke)"
    },
    {
      "id": "UNKNOWN-ant6ek",
      "description": "FE-ACT-S2C-001 — Endpoint exists",
      "status": "PASS",
      "duration_ms": 1135.4203870000001,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — Send-to-Campaign (FE-ACT-S2C) > FE-ACT-S2C-001 — Endpoint exists"
    },
    {
      "id": "UNKNOWN-aajcx3",
      "description": "FE-ACT-S2C-002 — Editor lists user's campaigns + stages (smoke)",
      "status": "PASS",
      "duration_ms": 0.4400160000004689,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — Send-to-Campaign (FE-ACT-S2C) > FE-ACT-S2C-002 — Editor lists user's campaigns + stages (smoke)"
    },
    {
      "id": "UNKNOWN-s1om1c",
      "description": "FE-ACT-S2C-003 — Trigger moves deal across campaigns (smoke)",
      "status": "PASS",
      "duration_ms": 2.925130999999965,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — Send-to-Campaign (FE-ACT-S2C) > FE-ACT-S2C-003 — Trigger moves deal across campaigns (smoke)"
    },
    {
      "id": "UNKNOWN-5qo0tk",
      "description": "FE-ACT-S2C-004 — Cycle prevention at save time (smoke)",
      "status": "PASS",
      "duration_ms": 3.3086719999992056,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — Send-to-Campaign (FE-ACT-S2C) > FE-ACT-S2C-004 — Cycle prevention at save time (smoke)"
    },
    {
      "id": "FE-ACT-SF-001",
      "description": "Endpoint exists",
      "status": "PASS",
      "duration_ms": 1659.4734649999991,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — Siteforge (FE-ACT-SF) > FE-ACT-SF-001 — Endpoint exists"
    },
    {
      "id": "FE-ACT-SF-002",
      "description": "CRUD verified (smoke)",
      "status": "PASS",
      "duration_ms": 2.2451709999986633,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — Siteforge (FE-ACT-SF) > FE-ACT-SF-002 — CRUD verified (smoke)"
    },
    {
      "id": "FE-ACT-SF-003",
      "description": "Invalid API key at save → friendly error (smoke)",
      "status": "PASS",
      "duration_ms": 1.3771109999997861,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — Siteforge (FE-ACT-SF) > FE-ACT-SF-003 — Invalid API key at save → friendly error (smoke)"
    },
    {
      "id": "FE-ACT-SF-004",
      "description": "Trigger logs activity (smoke)",
      "status": "PASS",
      "duration_ms": 0.21347700000114855,
      "file_path": "/app/runner/tests/stage-actions/fe-stage-actions.test.ts",
      "test_path": "tests/stage-actions/fe-stage-actions.test.ts > Stage action — Siteforge (FE-ACT-SF) > FE-ACT-SF-004 — Trigger logs activity (smoke)"
    },
    {
      "id": "FE-VM-001",
      "description": "/phone-system/voicemails lists records or empty state",
      "status": "PASS",
      "duration_ms": 5228.453064,
      "file_path": "/app/runner/tests/voicemails/fe-vm.test.ts",
      "test_path": "tests/voicemails/fe-vm.test.ts > Voicemails page (FE-VM) > FE-VM-001 — /phone-system/voicemails lists records or empty state"
    },
    {
      "id": "FE-VM-002",
      "description": "Each row shows recipient/duration/status/timestamp (smoke)",
      "status": "PASS",
      "duration_ms": 1.062300999999934,
      "file_path": "/app/runner/tests/voicemails/fe-vm.test.ts",
      "test_path": "tests/voicemails/fe-vm.test.ts > Voicemails page (FE-VM) > FE-VM-002 — Each row shows recipient/duration/status/timestamp (smoke)"
    },
    {
      "id": "FE-VM-003",
      "description": "Play affordance plays audio inline (smoke)",
      "status": "PASS",
      "duration_ms": 0.5551359999999477,
      "file_path": "/app/runner/tests/voicemails/fe-vm.test.ts",
      "test_path": "tests/voicemails/fe-vm.test.ts > Voicemails page (FE-VM) > FE-VM-003 — Play affordance plays audio inline (smoke)"
    },
    {
      "id": "FE-VM-004",
      "description": "Filter by status works (smoke)",
      "status": "PASS",
      "duration_ms": 0.5500650000003589,
      "file_path": "/app/runner/tests/voicemails/fe-vm.test.ts",
      "test_path": "tests/voicemails/fe-vm.test.ts > Voicemails page (FE-VM) > FE-VM-004 — Filter by status works (smoke)"
    },
    {
      "id": "FE-VM-005",
      "description": "Pagination works at boundaries (smoke)",
      "status": "PASS",
      "duration_ms": 0.603345000000445,
      "file_path": "/app/runner/tests/voicemails/fe-vm.test.ts",
      "test_path": "tests/voicemails/fe-vm.test.ts > Voicemails page (FE-VM) > FE-VM-005 — Pagination works at boundaries (smoke)"
    },
    {
      "id": "FE-VM-006",
      "description": "Voicemail audio URL is signed/scoped (smoke)",
      "status": "PASS",
      "duration_ms": 0.5097799999994095,
      "file_path": "/app/runner/tests/voicemails/fe-vm.test.ts",
      "test_path": "tests/voicemails/fe-vm.test.ts > Voicemails page (FE-VM) > FE-VM-006 — Voicemail audio URL is signed/scoped (smoke)"
    }
  ]
}