1
import { describe, expect, it, vi } from 'vitest';
3
import { NON_HTTP_PREFIX } from '@/const/auth';
5
import { getJWTPayload } from './jwt';
7
let enableClerkMock = false;
8
let enableNextAuthMock = false;
10
vi.mock('@/const/auth', async (importOriginal) => {
11
const data = await importOriginal();
16
return enableClerkMock;
18
get enableNextAuth() {
19
return enableNextAuthMock;
24
vi.mock('@/config/app', () => ({
25
getAppConfig: vi.fn(),
28
describe('getJWTPayload', () => {
29
it('should parse JWT payload for non-HTTPS token', async () => {
30
const token = `${NON_HTTP_PREFIX}.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ`;
31
const payload = await getJWTPayload(token);
32
expect(payload).toEqual({
39
it('should verify and parse JWT payload for HTTPS token', async () => {
41
'eyJhbGciOiJIUzI1NiJ9.eyJhY2Nlc3NDb2RlIjoiIiwidXNlcklkIjoiMDAxMzYyYzMtNDhjNS00NjM1LWJkM2ItODM3YmZmZjU4ZmMwIiwiYXBpS2V5IjoiYWJjIiwiZW5kcG9pbnQiOiJhYmMiLCJpYXQiOjE3MTY4MDIyMjUsImV4cCI6MTAwMDAwMDAwMDE3MTY4MDIwMDB9.FF0FxsE8Cajs-_hv5GD0TNUDwvekAkI9l_LL_IOPdGQ';
42
const payload = await getJWTPayload(token);
43
expect(payload).toEqual({
47
exp: 10000000001716802000,
49
userId: '001362c3-48c5-4635-bd3b-837bfff58fc0',
53
it('should not verify success and parse JWT payload for dated token', async () => {
55
'eyJhbGciOiJIUzI1NiJ9.eyJhY2Nlc3NDb2RlIjoiIiwidXNlcklkIjoiYWY3M2JhODktZjFhMy00YjliLWEwM2QtZGViZmZlMzE4NmQxIiwiYXBpS2V5IjoiYWJjIiwiZW5kcG9pbnQiOiJhYmMiLCJpYXQiOjE3MTY3OTk5ODAsImV4cCI6MTcxNjgwMDA4MH0.8AGFsLcwyrQG82kVUYOGFXHIwihm2n16ctyArKW9100';
57
await getJWTPayload(token);
59
expect(e).toEqual(new TypeError('"exp" claim timestamp check failed'));