Files
supabase/apps/studio/components/interfaces/Support/SupportForm.utils.test.ts
Jordi Enric ec26943390 feat: improve db overload debugging UX (#43564)
When the dashboard hits a DB connection timeout, users currently see a
raw error message with no
path forward. This PR adds an inline troubleshooting system that detects
known error types and
surfaces contextual next steps — restart the DB, read the docs, or debug
with AI.

##  Changes

- New ErrorDisplay component (packages/ui-patterns) — styled error card
with a title, monospace error
block, optional troubleshooting slot, and a "Contact support" link that
always renders. Accepts
  typed supportFormParams to pre-fill the support form.

- Error classification in handleError (data/fetchers.ts) — on every API
error, the message is tested
against ERROR_PATTERNS. If matched, handleError throws a typed subclass
(ConnectionTimeoutError
extends ResponseError) instead of a plain ResponseError. Stack traces
now show the exact error
  class. All existing instanceof ResponseError checks continue to work.

- ErrorMatcher component — reads errorType from the thrown class
instance, does an O(1) lookup into
ERROR_MAPPINGS, and renders the matching troubleshooting accordion as
children of ErrorDisplay.
  Falls back to plain ErrorDisplay for unclassified errors.

- Connection timeout mapping — first error type wired up, with three
troubleshooting steps: restart
the database, link to the docs, and "Debug with AI" (opens the AI
assistant sidebar with a
  pre-filled prompt).

- Telemetry — three new typed events track when the troubleshooter is
shown, when accordion steps are
   toggled, and which CTAs are clicked.

##  Adding a new error type

  1. Add a class to types/api-errors.ts
  2. Add { pattern, ErrorClass } to data/error-patterns.ts
  3. Create a troubleshooting component in errorMappings/
  4. Add an entry to error-mappings.tsx
2026-03-16 11:22:30 +01:00

25 lines
796 B
TypeScript

import { describe, expect, it } from 'vitest'
import { createSupportFormUrl } from './SupportForm.utils'
describe('createSupportFormUrl', () => {
it('returns base URL with no params', () => {
expect(createSupportFormUrl({})).toBe('/support/new')
})
it('does not append a bare ? when params are empty', () => {
expect(createSupportFormUrl({})).not.toContain('?')
})
it('includes provided params in the query string', () => {
const url = createSupportFormUrl({ projectRef: 'my-project' })
expect(url).toContain('projectRef=my-project')
})
it('includes multiple params', () => {
const url = createSupportFormUrl({ projectRef: 'my-project', subject: 'help' })
expect(url).toContain('projectRef=my-project')
expect(url).toContain('subject=help')
})
})