Add webhook logging, pagination, middleware, migrations, and prod hardening
- Webhook event logging repo and subscription webhook idempotency - Pagination helper (echohelpers) with cursor/offset support - Request ID and structured logging middleware - Push client improvements (FCM HTTP v1, better error handling) - Task model version column, business constraint migrations, targeted indexes - Expanded categorization chain tests - Email service and config hardening - CI workflow updates, .gitignore additions, .env.example updates Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -113,7 +113,7 @@ func TestTaskRepository_Cancel(t *testing.T) {
|
||||
|
||||
assert.False(t, task.IsCancelled)
|
||||
|
||||
err := repo.Cancel(task.ID)
|
||||
err := repo.Cancel(task.ID, task.Version)
|
||||
require.NoError(t, err)
|
||||
|
||||
found, err := repo.FindByID(task.ID)
|
||||
@@ -129,8 +129,8 @@ func TestTaskRepository_Uncancel(t *testing.T) {
|
||||
residence := testutil.CreateTestResidence(t, db, user.ID, "Test House")
|
||||
task := testutil.CreateTestTask(t, db, residence.ID, user.ID, "Test Task")
|
||||
|
||||
repo.Cancel(task.ID)
|
||||
err := repo.Uncancel(task.ID)
|
||||
repo.Cancel(task.ID, task.Version)
|
||||
err := repo.Uncancel(task.ID, task.Version+1) // version incremented by Cancel
|
||||
require.NoError(t, err)
|
||||
|
||||
found, err := repo.FindByID(task.ID)
|
||||
@@ -146,7 +146,7 @@ func TestTaskRepository_Archive(t *testing.T) {
|
||||
residence := testutil.CreateTestResidence(t, db, user.ID, "Test House")
|
||||
task := testutil.CreateTestTask(t, db, residence.ID, user.ID, "Test Task")
|
||||
|
||||
err := repo.Archive(task.ID)
|
||||
err := repo.Archive(task.ID, task.Version)
|
||||
require.NoError(t, err)
|
||||
|
||||
found, err := repo.FindByID(task.ID)
|
||||
@@ -162,8 +162,8 @@ func TestTaskRepository_Unarchive(t *testing.T) {
|
||||
residence := testutil.CreateTestResidence(t, db, user.ID, "Test House")
|
||||
task := testutil.CreateTestTask(t, db, residence.ID, user.ID, "Test Task")
|
||||
|
||||
repo.Archive(task.ID)
|
||||
err := repo.Unarchive(task.ID)
|
||||
repo.Archive(task.ID, task.Version)
|
||||
err := repo.Unarchive(task.ID, task.Version+1) // version incremented by Archive
|
||||
require.NoError(t, err)
|
||||
|
||||
found, err := repo.FindByID(task.ID)
|
||||
@@ -316,7 +316,7 @@ func TestKanbanBoard_CancelledTasksHiddenFromKanbanBoard(t *testing.T) {
|
||||
|
||||
// Create a cancelled task
|
||||
task := testutil.CreateTestTask(t, db, residence.ID, user.ID, "Cancelled Task")
|
||||
repo.Cancel(task.ID)
|
||||
repo.Cancel(task.ID, task.Version)
|
||||
|
||||
board, err := repo.GetKanbanData(residence.ID, 30, time.Now().UTC())
|
||||
require.NoError(t, err)
|
||||
@@ -571,7 +571,7 @@ func TestKanbanBoard_ArchivedTasksHiddenFromKanbanBoard(t *testing.T) {
|
||||
// Create a regular task and an archived task
|
||||
testutil.CreateTestTask(t, db, residence.ID, user.ID, "Regular Task")
|
||||
archivedTask := testutil.CreateTestTask(t, db, residence.ID, user.ID, "Archived Task")
|
||||
repo.Archive(archivedTask.ID)
|
||||
repo.Archive(archivedTask.ID, archivedTask.Version)
|
||||
|
||||
board, err := repo.GetKanbanData(residence.ID, 30, time.Now().UTC())
|
||||
require.NoError(t, err)
|
||||
@@ -856,7 +856,7 @@ func TestKanbanBoard_MultipleResidences(t *testing.T) {
|
||||
|
||||
// Create a cancelled task in house 1
|
||||
cancelledTask := testutil.CreateTestTask(t, db, residence1.ID, user.ID, "Cancelled in House 1")
|
||||
repo.Cancel(cancelledTask.ID)
|
||||
repo.Cancel(cancelledTask.ID, cancelledTask.Version)
|
||||
|
||||
board, err := repo.GetKanbanDataForMultipleResidences([]uint{residence1.ID, residence2.ID}, 30, time.Now().UTC())
|
||||
require.NoError(t, err)
|
||||
|
||||
Reference in New Issue
Block a user