Skip to content

feat(audit): correlation id on notifications + notification_sent/fail…#13

Merged
fupelaqu merged 1 commit into
mainfrom
feature/audit
Jun 14, 2026
Merged

feat(audit): correlation id on notifications + notification_sent/fail…#13
fupelaqu merged 1 commit into
mainfrom
feature/audit

Conversation

@fupelaqu

Copy link
Copy Markdown
Contributor

…ed audit (Story 13.7 Phase B gate #3)

All notification payloads (Mail #21, SMS #20, Push #25, Ws #21) carry an optional correlation_id; the Notification trait exposes it (abstract def correlationId) plus a withCorrelationId wither, so producers thread the originating flow's id and the behavior reads it generically.

NotificationBehavior.sendNotification emits a terminal audit line via the upstream AuditLog("notification") — notification_sent (Sent/Delivered) or notification_failed (Undelivered/Rejected) — only when an actual send/ack happened this round (skips deferred/no-op/Pending). audit is a lazy val (trait default method, no abstract setter → binary-compatible for implementers).

Bumps genericPersistence -> 0.9-SNAPSHOT and notification version -> 0.9-SNAPSHOT. SimpleMailNotificationsHandlerSpec: +audit-line capture test (10 green); +compile (2.12+2.13) + scalafmtAll clean.

…ed audit (Story 13.7 Phase B gate #3)

All notification payloads (Mail #21, SMS #20, Push #25, Ws #21) carry an optional correlation_id; the Notification trait exposes it (abstract def correlationId) plus a withCorrelationId wither, so producers thread the originating flow's id and the behavior reads it generically.

NotificationBehavior.sendNotification emits a terminal audit line via the upstream AuditLog("notification") — notification_sent (Sent/Delivered) or notification_failed (Undelivered/Rejected) — only when an actual send/ack happened this round (skips deferred/no-op/Pending). audit is a lazy val (trait default method, no abstract setter → binary-compatible for implementers).

Bumps genericPersistence -> 0.9-SNAPSHOT and notification version -> 0.9-SNAPSHOT. SimpleMailNotificationsHandlerSpec: +audit-line capture test (10 green); +compile (2.12+2.13) + scalafmtAll clean.

Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
@codecov

codecov Bot commented Jun 14, 2026

Copy link
Copy Markdown

Codecov Report

✅ All modified and coverable lines are covered by tests.
✅ Project coverage is 70.94%. Comparing base (ab38284) to head (5e4f97e).

Additional details and impacted files
@@            Coverage Diff             @@
##             main      #13      +/-   ##
==========================================
- Coverage   71.39%   70.94%   -0.45%     
==========================================
  Files          61       61              
  Lines        1115     1122       +7     
  Branches      169      178       +9     
==========================================
  Hits          796      796              
- Misses        319      326       +7     
Flag Coverage Δ
unittests 70.94% <100.00%> (-0.45%) ⬇️

Flags with carried forward coverage won't be shown. Click here to find out more.

☔ View full report in Codecov by Harness.
📢 Have feedback on the report? Share it here.

🚀 New features to boost your workflow:
  • ❄️ Test Analytics: Detect flaky tests, report on failures, and find test suite problems.

@fupelaqu fupelaqu merged commit 77ac909 into main Jun 14, 2026
4 of 5 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant