Add reported-issues, Goodreads sync & notifs

Introduce user-reported-issues and Goodreads shelf sync features and wire them into notifications. Adds Prisma migrations and schema changes (ReportedIssue, GoodreadsShelf, GoodreadsBookMapping), API endpoints for reporting (POST /audiobooks/[asin]/report-issue) and admin management (list, resolve/dismiss, replace), and an admin UI section to view/dismiss/replace reported issues. Adds a new notification event (issue_reported) with updates to notification schemas, docs and provider handling, plus a notification-events constants file. Refactors request creation to use createRequestForUser service, adds a Goodreads sync processor/service/hooks/UI modals, a scrape-resilience util, and related tests and minor integration updates.
This commit is contained in:
kikootwo
2026-02-11 16:49:55 -05:00
parent b013538b63
commit 20c8fb0898
69 changed files with 4167 additions and 766 deletions
@@ -27,7 +27,7 @@ describe('ChangePasswordModal', () => {
});
it('rejects submission when access token is missing', async () => {
const fetchMock = vi.fn();
const fetchMock = vi.fn().mockResolvedValue({ ok: true, json: async () => ({}) });
vi.stubGlobal('fetch', fetchMock);
render(<ChangePasswordModal isOpen onClose={vi.fn()} />);
@@ -48,10 +48,8 @@ describe('ChangePasswordModal', () => {
expect(screen.getByText('Not authenticated')).toBeInTheDocument();
});
expect(fetchMock).not.toHaveBeenCalledWith(
'/api/auth/change-password',
expect.anything()
);
// Only the password policy fetch should have fired (useEffect on mount), not a password change call
expect(fetchMock).not.toHaveBeenCalledWith('/api/auth/change-password', expect.anything());
});
it('submits successfully and auto-closes after showing success', async () => {