import { load } from 'cheerio'; import supertest from 'supertest'; import { afterAll, describe, expect, it } from 'vitest'; import { config } from '@/config'; import server from '@/index'; const request = supertest(server); afterAll(() => { server.close(); }); describe('error', () => { it(`error`, async () => { const response = await request.get('/test/error'); expect(response.status).toBe(503); expect(response.text).toMatch(/Error: Error test/); }); }); describe('httperror', () => { it(`httperror`, async () => { const response = await request.get('/test/httperror'); expect(response.status).toBe(503); expect(response.text).toContain('FetchError: [GET] "https://httpbingo.org/status/404": 404 Not Found'); }, 20000); }); describe('RequestInProgressError', () => { it(`RequestInProgressError with retry`, async () => { const responses = await Promise.all([request.get('/test/slow'), request.get('/test/slow')]); expect(new Set(responses.map((r) => r.status))).toEqual(new Set([200, 200])); }); it(`RequestInProgressError`, async () => { const responses = await Promise.all([request.get('/test/slow4'), request.get('/test/slow4')]); expect(new Set(responses.map((r) => r.status))).toEqual(new Set([200, 503])); expect(new Set(responses.map((r) => r.headers['cache-control']))).toEqual(new Set([`public, max-age=${config.cache.routeExpire}`, `public, max-age=${config.requestTimeout / 1000}`])); expect(responses.filter((r) => r.text.includes('RequestInProgressError: This path is currently fetching, please come back later!'))).toHaveLength(1); }); }); describe('config-not-found-error', () => { it(`config-not-found-error`, async () => { const response = await request.get('/test/config-not-found-error'); expect(response.status).toBe(503); expect(response.text).toMatch('ConfigNotFoundError: Test config not found error'); }, 20000); }); describe('invalid-parameter-error', () => { it(`invalid-parameter-error`, async () => { const response = await request.get('/test/invalid-parameter-error'); expect(response.status).toBe(503); expect(response.text).toMatch('InvalidParameterError: Test invalid parameter error'); }, 20000); }); describe('captcha-error', () => { it(`captcha-error`, async () => { const response = await request.get('/test/captcha-error'); expect(response.status).toBe(503); expect(response.text).toMatch('CaptchaError: Test captcha error'); }, 20000); }); describe('route throws an error', () => { it('route path error should have path mounted', async () => { await request.get('/test/error'); await request.get('/thisDoesNotExist'); const response = await request.get('/'); const $ = load(response.text); $('.debug-item').each((index, item) => { const key = $(item).find('.debug-key').text().trim(); const value = $(item).find('.debug-value').html()?.trim(); switch (key) { case 'Request Amount:': expect(value).toBe('12'); break; case 'Hot Routes:': expect(value).toBe('9 /test/:id/:params?
'); break; case 'Hot Paths:': expect(value).toBe( '2 /test/error
2 /test/slow
2 /test/slow4
1 /test/httperror
1 /test/config-not-found-error
1 /test/invalid-parameter-error
1 /test/captcha-error
1 /thisDoesNotExist
1 /
' ); break; case 'Hot Error Routes:': expect(value).toBe('6 /test/:id/:params?
'); break; case 'Hot Error Paths:': expect(value).toBe('2 /test/error
1 /test/httperror
1 /test/slow4
1 /test/config-not-found-error
1 /test/invalid-parameter-error
1 /test/captcha-error
1 /thisDoesNotExist
'); break; default: } }); }); });