Implement structured error handling with custom exceptions #91
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Add custom error handling module (backend/app/errors/) with:
Register exception handlers in FastAPI app
Migrate all HTTPException raises to typed custom errors
Update error responses to include code, error_code, message, and details fields
Fix validation error handler to properly serialize exception context
Add comprehensive error handling tests (test_error_handling.py)
Update existing tests to expect 409 for conflicts instead of 400
Update existing tests to check 'message' field instead of 'detail'
All tests pass (57/57), linting clean, type checking clean, E2E tests pass (34/34)
Amp thread: https://ampcode.com/threads/T-99ac3974-7980-4570-a919-7317aa90678d