Migrate from Gin to Echo framework and add comprehensive integration tests
Major changes: - Migrate all handlers from Gin to Echo framework - Add new apperrors, echohelpers, and validator packages - Update middleware for Echo compatibility - Add ArchivedHandler to task categorization chain (archived tasks go to cancelled_tasks column) - Add 6 new integration tests: - RecurringTaskLifecycle: NextDueDate advancement for weekly/monthly tasks - MultiUserSharing: Complex sharing with user removal - TaskStateTransitions: All state transitions and kanban column changes - DateBoundaryEdgeCases: Threshold boundary testing - CascadeOperations: Residence deletion cascade effects - MultiUserOperations: Shared residence collaboration - Add single-purpose repository functions for kanban columns (GetOverdueTasks, GetDueSoonTasks, etc.) - Fix RemoveUser route param mismatch (userId -> user_id) - Fix determineExpectedColumn helper to correctly prioritize in_progress over overdue 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
@@ -1,6 +1,7 @@
|
||||
package services
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
"testing"
|
||||
|
||||
"github.com/shopspring/decimal"
|
||||
@@ -115,7 +116,7 @@ func TestResidenceService_GetResidence_AccessDenied(t *testing.T) {
|
||||
residence := testutil.CreateTestResidence(t, db, owner.ID, "Test House")
|
||||
|
||||
_, err := service.GetResidence(residence.ID, otherUser.ID)
|
||||
assert.ErrorIs(t, err, ErrResidenceAccessDenied)
|
||||
testutil.AssertAppError(t, err, http.StatusForbidden, "error.residence_access_denied")
|
||||
}
|
||||
|
||||
func TestResidenceService_GetResidence_NotFound(t *testing.T) {
|
||||
@@ -188,7 +189,7 @@ func TestResidenceService_UpdateResidence_NotOwner(t *testing.T) {
|
||||
req := &requests.UpdateResidenceRequest{Name: &newName}
|
||||
|
||||
_, err := service.UpdateResidence(residence.ID, sharedUser.ID, req)
|
||||
assert.ErrorIs(t, err, ErrNotResidenceOwner)
|
||||
testutil.AssertAppError(t, err, http.StatusForbidden, "error.not_residence_owner")
|
||||
}
|
||||
|
||||
func TestResidenceService_DeleteResidence(t *testing.T) {
|
||||
@@ -222,7 +223,7 @@ func TestResidenceService_DeleteResidence_NotOwner(t *testing.T) {
|
||||
residenceRepo.AddUser(residence.ID, sharedUser.ID)
|
||||
|
||||
_, err := service.DeleteResidence(residence.ID, sharedUser.ID)
|
||||
assert.ErrorIs(t, err, ErrNotResidenceOwner)
|
||||
testutil.AssertAppError(t, err, http.StatusForbidden, "error.not_residence_owner")
|
||||
}
|
||||
|
||||
func TestResidenceService_GenerateShareCode(t *testing.T) {
|
||||
@@ -280,7 +281,7 @@ func TestResidenceService_JoinWithCode_AlreadyMember(t *testing.T) {
|
||||
|
||||
// Owner tries to join their own residence
|
||||
_, err := service.JoinWithCode(shareResp.ShareCode.Code, owner.ID)
|
||||
assert.ErrorIs(t, err, ErrUserAlreadyMember)
|
||||
testutil.AssertAppError(t, err, http.StatusConflict, "error.user_already_member")
|
||||
}
|
||||
|
||||
func TestResidenceService_GetResidenceUsers(t *testing.T) {
|
||||
@@ -330,5 +331,5 @@ func TestResidenceService_RemoveUser_CannotRemoveOwner(t *testing.T) {
|
||||
residence := testutil.CreateTestResidence(t, db, owner.ID, "Test House")
|
||||
|
||||
err := service.RemoveUser(residence.ID, owner.ID, owner.ID)
|
||||
assert.ErrorIs(t, err, ErrCannotRemoveOwner)
|
||||
testutil.AssertAppError(t, err, http.StatusBadRequest, "error.cannot_remove_owner")
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user