mirror of
https://github.com/CompassConnections/Compass.git
synced 2026-05-10 08:03:45 -04:00
* setting up test structure * . * added playwright config file, deleted original playwright folder and moved "some.test" file * continued test structure setup * Updating test folder structure * Added database seeding script and backend testing folder structure * removed the database test * Replaced db seeding script * Updated userInformation.ts to use values from choices.tsx * merge prep * removing extra unit test, moving api test to correct folder * Pushing to get help with sql Unit test * Updating get-profiles unit tests * Added more unit tests * . * Added more unit tests * Added getSupabaseToken unit test * . * excluding supabase token test so ci can pass * . * Seperated the seedDatabase func into its own file so it can be accessed seperatly * Fixed failing test * . * . * Fix tests * Fix lint * Clean --------- Co-authored-by: MartinBraquet <martin.braquet@gmail.com>
114 lines
3.9 KiB
TypeScript
114 lines
3.9 KiB
TypeScript
jest.mock('common/discord/core');
|
|
jest.mock('shared/supabase/utils');
|
|
jest.mock('shared/supabase/init');
|
|
jest.mock('common/util/try-catch');
|
|
|
|
import { contact } from "api/contact";
|
|
import * as supabaseInit from "shared/supabase/init";
|
|
import * as supabaseUtils from "shared/supabase/utils";
|
|
import { tryCatch } from "common/util/try-catch";
|
|
import { sendDiscordMessage } from "common/discord/core";
|
|
import { AuthedUser } from "api/helpers/endpoint";
|
|
|
|
describe('contact', () => {
|
|
let mockPg: any;
|
|
beforeEach(() => {
|
|
jest.resetAllMocks();
|
|
|
|
mockPg = {
|
|
oneOrNone: jest.fn(),
|
|
};
|
|
|
|
(supabaseInit.createSupabaseDirectClient as jest.Mock)
|
|
.mockReturnValue(mockPg);
|
|
});
|
|
|
|
afterEach(() => {
|
|
jest.restoreAllMocks();
|
|
});
|
|
|
|
describe('should', () => {
|
|
it('send a discord message to the user', async () => {
|
|
const mockProps = {
|
|
content: {
|
|
type: 'doc',
|
|
content: [
|
|
{
|
|
type: 'paragraph',
|
|
content: [
|
|
{
|
|
type: 'text',
|
|
text: 'Error test message'
|
|
}
|
|
]
|
|
}
|
|
]
|
|
},
|
|
userId: '123'
|
|
};
|
|
const mockAuth = { uid: '321' } as AuthedUser;
|
|
const mockReq = {} as any;
|
|
const mockDbUser = { name: 'Humphrey Mocker' };
|
|
const mockReturnData = {} as any;
|
|
|
|
(tryCatch as jest.Mock).mockResolvedValue({ data: mockReturnData, error: null });
|
|
(mockPg.oneOrNone as jest.Mock).mockResolvedValue(mockDbUser);
|
|
(sendDiscordMessage as jest.Mock).mockResolvedValue(null);
|
|
|
|
const results = await contact(mockProps, mockAuth, mockReq);
|
|
expect(supabaseUtils.insert).toBeCalledTimes(1)
|
|
expect(supabaseUtils.insert).toBeCalledWith(
|
|
mockPg,
|
|
'contact',
|
|
{
|
|
user_id: mockProps.userId,
|
|
content: JSON.stringify(mockProps.content)
|
|
}
|
|
);
|
|
expect(results.success).toBe(true);
|
|
await results.continue();
|
|
expect(sendDiscordMessage).toBeCalledWith(
|
|
expect.stringContaining(`New message from ${mockDbUser.name}`),
|
|
'contact'
|
|
)
|
|
expect(sendDiscordMessage).toBeCalledTimes(1);
|
|
});
|
|
|
|
it('throw an error if the inser function fails', async () => {
|
|
const mockProps = {
|
|
content: {
|
|
type: 'doc',
|
|
content: [
|
|
{
|
|
type: 'paragraph',
|
|
content: [
|
|
{
|
|
type: 'text',
|
|
text: 'Error test message'
|
|
}
|
|
]
|
|
}
|
|
]
|
|
},
|
|
userId: '123'
|
|
};
|
|
const mockAuth = { uid: '321' } as AuthedUser;
|
|
const mockReq = {} as any;
|
|
|
|
(tryCatch as jest.Mock).mockResolvedValue({ data: null, error: Error });
|
|
|
|
expect(contact(mockProps, mockAuth, mockReq))
|
|
.rejects
|
|
.toThrowError('Failed to submit contact message');
|
|
expect(supabaseUtils.insert).toBeCalledTimes(1)
|
|
expect(supabaseUtils.insert).toBeCalledWith(
|
|
mockPg,
|
|
'contact',
|
|
{
|
|
user_id: mockProps.userId,
|
|
content: JSON.stringify(mockProps.content)
|
|
}
|
|
);
|
|
});
|
|
});
|
|
}); |