e6e6d17b72
PR Checks / test-and-build (pull_request) Successful in 3m12s
- Добавлена абстракция ISystemClock + SystemClock / FakeSystemClock для тестируемого scheduling. - Добавлена миграция V014: confirmation_sent_at в sessions. - Обновлен SendConfirmationHandler: записывает confirmation_sent_at. - Обновлен SessionSchedulerService: - выделен ISessionTriggerStore / DbSessionTriggerStore - SQL-запросы используют параметр @Now вместо now() - добавлен публичный TickAsync для тестов - защита от дублей через confirmation_sent_at IS NULL - Обновлен RescheduleVotingDeadlineService: использует ISystemClock. - Добавлены интерфейсы ISendConfirmationHandler, ISendOneHourReminderHandler, ISendJoinLinkHandler для unit-тестируемости. - Добавлены 8 unit-тестов SessionSchedulerService: - все 3 триггера (T-24h, T-1h, T-5min) - идемпотентность при повторном запуске - ошибки handler не падают и не блокируют другие сессии - ошибки store логируются без падения worker-а Bump version -> 1.13.0 Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
14 lines
463 B
SQL
14 lines
463 B
SQL
ALTER TABLE sessions
|
|
ADD COLUMN confirmation_sent_at TIMESTAMPTZ;
|
|
|
|
-- Update existing ConfirmationSent sessions to have a sentinel value
|
|
-- so they don't get re-processed after migration
|
|
UPDATE sessions
|
|
SET confirmation_sent_at = now()
|
|
WHERE status = 'ConfirmationSent';
|
|
|
|
-- Partial index for efficient T-24h query
|
|
CREATE INDEX ix_sessions_confirmation_reminders ON sessions (scheduled_at)
|
|
WHERE status = 'Planned'
|
|
AND confirmation_sent_at IS NULL;
|