mirror of
https://github.com/StanGirard/quivr.git
synced 2024-11-24 05:55:13 +03:00
Frontend/test/config/2 (#542)
* test(useApiKeyConfig): add unit tests * test(BackendConfig): add unit tests
This commit is contained in:
parent
b3a0db771a
commit
0ce9c8ffcd
@ -19,9 +19,7 @@ afterEach(() => {
|
||||
describe("ChatInput", () => {
|
||||
it("should render correctly", () => {
|
||||
// Rendering the ChatInput component
|
||||
const { getByTestId, baseElement } = render(<ChatInput />);
|
||||
|
||||
console.log({ baseElement });
|
||||
const { getByTestId } = render(<ChatInput />);
|
||||
|
||||
const chatInputForm = getByTestId("chat-input-form");
|
||||
expect(chatInputForm).toBeDefined();
|
||||
|
@ -0,0 +1,67 @@
|
||||
import { act, renderHook } from "@testing-library/react";
|
||||
import { afterEach, describe, expect, it, vi } from "vitest";
|
||||
|
||||
import { useApiKeyConfig } from "../useApiKeyConfig";
|
||||
|
||||
const createApiKeyMock = vi.fn(() => "dummyApiKey");
|
||||
const trackMock = vi.fn((props: unknown) => ({ props }));
|
||||
|
||||
const useAuthApiMock = vi.fn(() => ({
|
||||
createApiKey: () => createApiKeyMock(),
|
||||
}));
|
||||
|
||||
const useEventTrackingMock = vi.fn(() => ({
|
||||
track: (props: unknown) => trackMock(props),
|
||||
}));
|
||||
|
||||
vi.mock("@/lib/api/auth/useAuthApi", () => ({
|
||||
useAuthApi: () => useAuthApiMock(),
|
||||
}));
|
||||
vi.mock("@/services/analytics/useEventTracking", () => ({
|
||||
useEventTracking: () => useEventTrackingMock(),
|
||||
}));
|
||||
|
||||
describe("useApiKeyConfig", () => {
|
||||
afterEach(() => {
|
||||
vi.restoreAllMocks();
|
||||
});
|
||||
|
||||
it("should set the apiKey when handleCreateClick is called", async () => {
|
||||
const { result } = renderHook(() => useApiKeyConfig());
|
||||
|
||||
await act(async () => {
|
||||
await result.current.handleCreateClick();
|
||||
});
|
||||
|
||||
expect(createApiKeyMock).toHaveBeenCalledTimes(1);
|
||||
expect(trackMock).toHaveBeenCalledWith("CREATE_API_KEY");
|
||||
expect(result.current.apiKey).toBe("dummyApiKey");
|
||||
});
|
||||
|
||||
it("should call copyToClipboard when handleCopyClick is called with a non-empty apiKey", () => {
|
||||
vi.mock("react", async () => {
|
||||
const actual = await vi.importActual<typeof import("react")>("react");
|
||||
|
||||
return {
|
||||
...actual,
|
||||
useState: () => ["dummyApiKey", vi.fn()],
|
||||
};
|
||||
});
|
||||
//@ts-ignore - clipboard is not actually readonly
|
||||
global.navigator.clipboard = {
|
||||
writeText: vi.fn(),
|
||||
};
|
||||
|
||||
const { result } = renderHook(() => useApiKeyConfig());
|
||||
|
||||
act(() => result.current.handleCopyClick());
|
||||
|
||||
expect(trackMock).toHaveBeenCalledTimes(1);
|
||||
expect(trackMock).toHaveBeenCalledWith("COPY_API_KEY");
|
||||
|
||||
// eslint-disable-next-line @typescript-eslint/unbound-method
|
||||
expect(global.navigator.clipboard.writeText).toHaveBeenCalledWith(
|
||||
"dummyApiKey"
|
||||
);
|
||||
});
|
||||
});
|
@ -1,21 +1,19 @@
|
||||
import { useState } from "react";
|
||||
|
||||
import { useAxios } from "@/lib/hooks";
|
||||
import { useAuthApi } from "@/lib/api/auth/useAuthApi";
|
||||
import { useEventTracking } from "@/services/analytics/useEventTracking";
|
||||
|
||||
// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types
|
||||
export const useApiKeyConfig = () => {
|
||||
const [apiKey, setApiKey] = useState("");
|
||||
const { axiosInstance } = useAxios();
|
||||
const { track } = useEventTracking();
|
||||
const { createApiKey } = useAuthApi();
|
||||
|
||||
const handleCreateClick = async () => {
|
||||
try {
|
||||
void track("CREATE_API_KEY");
|
||||
const response = await axiosInstance.post<{ api_key: string }>(
|
||||
"/api-key"
|
||||
); // replace with your api-key endpoint URL
|
||||
setApiKey(response.data.api_key);
|
||||
const createdApiKey = await createApiKey();
|
||||
setApiKey(createdApiKey);
|
||||
} catch (error) {
|
||||
console.error("Error creating API key: ", error);
|
||||
}
|
||||
|
@ -0,0 +1,24 @@
|
||||
import { render } from "@testing-library/react";
|
||||
import { describe, expect, it, vi } from "vitest";
|
||||
|
||||
import { BackendConfig } from "../BackendConfig";
|
||||
|
||||
const registerMock = vi.fn(() => void 0);
|
||||
|
||||
describe("BackendConfig", () => {
|
||||
it("renders the component with fields and labels", () => {
|
||||
//@ts-expect-error we don't need registerMock to return all `register` keys
|
||||
const { getByText } = render(<BackendConfig register={registerMock} />);
|
||||
|
||||
expect(getByText("Backend config")).toBeDefined();
|
||||
expect(getByText("Backend URL")).toBeDefined();
|
||||
expect(getByText("Supabase URL")).toBeDefined();
|
||||
expect(getByText("Supabase key")).toBeDefined();
|
||||
expect(getByText("Keep in local")).toBeDefined();
|
||||
expect(getByText("Keep in local")).toBeDefined();
|
||||
expect(registerMock).toHaveBeenCalledWith("backendUrl");
|
||||
expect(registerMock).toHaveBeenCalledWith("supabaseUrl");
|
||||
expect(registerMock).toHaveBeenCalledWith("supabaseKey");
|
||||
expect(registerMock).toHaveBeenCalledWith("backendUrl");
|
||||
});
|
||||
});
|
@ -6,7 +6,7 @@ import { useRouter } from "next/navigation";
|
||||
import Button from "@/lib/components/ui/Button";
|
||||
|
||||
import { useConfig } from "../hooks/useConfig";
|
||||
import { BackendConfig } from "./BackendConfig";
|
||||
import { BackendConfig } from "./BackendConfig/BackendConfig";
|
||||
import { ModelConfig } from "./ModelConfig";
|
||||
import { UserAccountSection } from "./UserAccountSection";
|
||||
|
||||
|
31
frontend/lib/api/auth/__tests__/useAuthApi.test.ts
Normal file
31
frontend/lib/api/auth/__tests__/useAuthApi.test.ts
Normal file
@ -0,0 +1,31 @@
|
||||
import { renderHook } from "@testing-library/react";
|
||||
import { describe, expect, it, vi } from "vitest";
|
||||
|
||||
import { useAuthApi } from "../useAuthApi";
|
||||
|
||||
const axiosPostMock = vi.fn(() => ({
|
||||
data: {
|
||||
api_key: "",
|
||||
},
|
||||
}));
|
||||
|
||||
vi.mock("@/lib/hooks", () => ({
|
||||
useAxios: () => ({
|
||||
axiosInstance: {
|
||||
post: axiosPostMock,
|
||||
},
|
||||
}),
|
||||
}));
|
||||
|
||||
describe("useAuthApi", () => {
|
||||
it("should call createApiKey with the correct parameters", async () => {
|
||||
const {
|
||||
result: {
|
||||
current: { createApiKey },
|
||||
},
|
||||
} = renderHook(() => useAuthApi());
|
||||
await createApiKey();
|
||||
expect(axiosPostMock).toHaveBeenCalledTimes(1);
|
||||
expect(axiosPostMock).toHaveBeenCalledWith("/api-key");
|
||||
});
|
||||
});
|
9
frontend/lib/api/auth/auth.ts
Normal file
9
frontend/lib/api/auth/auth.ts
Normal file
@ -0,0 +1,9 @@
|
||||
import { AxiosInstance } from "axios";
|
||||
|
||||
export const createApiKey = async (
|
||||
axiosInstance: AxiosInstance
|
||||
): Promise<string> => {
|
||||
const response = await axiosInstance.post<{ api_key: string }>("/api-key");
|
||||
|
||||
return response.data.api_key;
|
||||
};
|
12
frontend/lib/api/auth/useAuthApi.ts
Normal file
12
frontend/lib/api/auth/useAuthApi.ts
Normal file
@ -0,0 +1,12 @@
|
||||
import { useAxios } from "@/lib/hooks";
|
||||
|
||||
import { createApiKey } from "./auth";
|
||||
|
||||
// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types
|
||||
export const useAuthApi = () => {
|
||||
const { axiosInstance } = useAxios();
|
||||
|
||||
return {
|
||||
createApiKey: async () => createApiKey(axiosInstance),
|
||||
};
|
||||
};
|
Loading…
Reference in New Issue
Block a user