mirror of
https://github.com/pagefaultgames/pokerogue.git
synced 2025-10-24 14:05:50 +02:00
* Reuse global scene between tests Co-authored-by: PigeonBar <56974298+PigeonBar@users.noreply.github.com> * Add missing each method to mockContainer * Fix select-modifier-phase test * Sanitize overrides before tests Co-authored-by: PigeonBar <56974298+PigeonBar@users.noreply.github.com> * Sanitize overrides before tests Co-authored-by: PigeonBar <56974298+PigeonBar@users.noreply.github.com> * [WIP] fix things * Fix tests not working with --no-isolate * Update npm tests to use no isolate * Update test-shard-template * Update package.json Co-authored-by: NightKev <34855794+DayKev@users.noreply.github.com> --------- Co-authored-by: PigeonBar <56974298+PigeonBar@users.noreply.github.com> Co-authored-by: NightKev <34855794+DayKev@users.noreply.github.com>
164 lines
5.8 KiB
TypeScript
164 lines
5.8 KiB
TypeScript
import type { AccountInfoResponse } from "#app/@types/PokerogueAccountApi";
|
|
import { SESSION_ID_COOKIE_NAME } from "#app/constants";
|
|
import { PokerogueAccountApi } from "#app/plugins/api/pokerogue-account-api";
|
|
import { getApiBaseUrl } from "#test/testUtils/testUtils";
|
|
import * as Utils from "#app/utils";
|
|
import { http, HttpResponse } from "msw";
|
|
import { beforeAll, afterEach, beforeEach, describe, expect, it, vi } from "vitest";
|
|
import { initServerForApiTests } from "#test/testUtils/testFileInitialization";
|
|
import type { SetupServerApi } from "msw/node";
|
|
|
|
const apiBase = getApiBaseUrl();
|
|
const accountApi = new PokerogueAccountApi(apiBase);
|
|
let server: SetupServerApi;
|
|
|
|
beforeAll(async () => {
|
|
server = await initServerForApiTests();
|
|
});
|
|
|
|
afterEach(() => {
|
|
server.resetHandlers();
|
|
});
|
|
|
|
describe("Pokerogue Account API", () => {
|
|
beforeEach(() => {
|
|
vi.spyOn(console, "warn");
|
|
});
|
|
|
|
describe("Get Info", () => {
|
|
it("should return account-info & 200 on SUCCESS", async () => {
|
|
const expectedAccountInfo: AccountInfoResponse = {
|
|
username: "test",
|
|
lastSessionSlot: -1,
|
|
discordId: "23235353543535",
|
|
googleId: "1ed1d1d11d1d1d1d1d1",
|
|
hasAdminRole: false,
|
|
};
|
|
server.use(http.get(`${apiBase}/account/info`, () => HttpResponse.json(expectedAccountInfo)));
|
|
|
|
const [accountInfo, status] = await accountApi.getInfo();
|
|
|
|
expect(accountInfo).toEqual(expectedAccountInfo);
|
|
expect(status).toBe(200);
|
|
});
|
|
|
|
it("should return null + status-code anad report a warning on FAILURE", async () => {
|
|
server.use(http.get(`${apiBase}/account/info`, () => new HttpResponse("", { status: 401 })));
|
|
|
|
const [accountInfo, status] = await accountApi.getInfo();
|
|
|
|
expect(accountInfo).toBeNull();
|
|
expect(status).toBe(401);
|
|
expect(console.warn).toHaveBeenCalledWith("Could not get account info!", 401, "Unauthorized");
|
|
});
|
|
|
|
it("should return null + 500 anad report a warning on ERROR", async () => {
|
|
server.use(http.get(`${apiBase}/account/info`, () => HttpResponse.error()));
|
|
|
|
const [accountInfo, status] = await accountApi.getInfo();
|
|
|
|
expect(accountInfo).toBeNull();
|
|
expect(status).toBe(500);
|
|
expect(console.warn).toHaveBeenCalledWith("Could not get account info!", expect.any(Error));
|
|
});
|
|
});
|
|
|
|
describe("Register", () => {
|
|
const registerParams = { username: "test", password: "test" };
|
|
|
|
it("should return null on SUCCESS", async () => {
|
|
server.use(http.post(`${apiBase}/account/register`, () => HttpResponse.text()));
|
|
|
|
const error = await accountApi.register(registerParams);
|
|
|
|
expect(error).toBeNull();
|
|
});
|
|
|
|
it("should return error message on FAILURE", async () => {
|
|
server.use(
|
|
http.post(`${apiBase}/account/register`, () => new HttpResponse("Username is already taken", { status: 400 })),
|
|
);
|
|
|
|
const error = await accountApi.register(registerParams);
|
|
|
|
expect(error).toBe("Username is already taken");
|
|
});
|
|
|
|
it('should return "Unknown error" and report a warning on ERROR', async () => {
|
|
server.use(http.post(`${apiBase}/account/register`, () => HttpResponse.error()));
|
|
|
|
const error = await accountApi.register(registerParams);
|
|
|
|
expect(error).toBe("Unknown error!");
|
|
expect(console.warn).toHaveBeenCalledWith("Register failed!", expect.any(Error));
|
|
});
|
|
});
|
|
|
|
describe("Login", () => {
|
|
const loginParams = { username: "test", password: "test" };
|
|
|
|
it("should return null and set the cookie on SUCCESS", async () => {
|
|
vi.spyOn(Utils, "setCookie");
|
|
server.use(http.post(`${apiBase}/account/login`, () => HttpResponse.json({ token: "abctest" })));
|
|
|
|
const error = await accountApi.login(loginParams);
|
|
|
|
expect(error).toBeNull();
|
|
expect(Utils.setCookie).toHaveBeenCalledWith(SESSION_ID_COOKIE_NAME, "abctest");
|
|
});
|
|
|
|
it("should return error message and report a warning on FAILURE", async () => {
|
|
server.use(
|
|
http.post(`${apiBase}/account/login`, () => new HttpResponse("Password is incorrect", { status: 401 })),
|
|
);
|
|
|
|
const error = await accountApi.login(loginParams);
|
|
|
|
expect(error).toBe("Password is incorrect");
|
|
expect(console.warn).toHaveBeenCalledWith("Login failed!", 401, "Unauthorized");
|
|
});
|
|
|
|
it('should return "Unknown error" and report a warning on ERROR', async () => {
|
|
server.use(http.post(`${apiBase}/account/login`, () => HttpResponse.error()));
|
|
|
|
const error = await accountApi.login(loginParams);
|
|
|
|
expect(error).toBe("Unknown error!");
|
|
expect(console.warn).toHaveBeenCalledWith("Login failed!", expect.any(Error));
|
|
});
|
|
});
|
|
|
|
describe("Logout", () => {
|
|
beforeEach(() => {
|
|
vi.spyOn(Utils, "removeCookie");
|
|
});
|
|
|
|
it("should remove cookie on success", async () => {
|
|
vi.spyOn(Utils, "setCookie");
|
|
server.use(http.get(`${apiBase}/account/logout`, () => new HttpResponse("", { status: 200 })));
|
|
|
|
await accountApi.logout();
|
|
|
|
expect(Utils.removeCookie).toHaveBeenCalledWith(SESSION_ID_COOKIE_NAME);
|
|
});
|
|
|
|
it("should report a warning on and remove cookie on FAILURE", async () => {
|
|
server.use(http.get(`${apiBase}/account/logout`, () => new HttpResponse("", { status: 401 })));
|
|
|
|
await accountApi.logout();
|
|
|
|
expect(Utils.removeCookie).toHaveBeenCalledWith(SESSION_ID_COOKIE_NAME);
|
|
expect(console.warn).toHaveBeenCalledWith("Log out failed!", expect.any(Error));
|
|
});
|
|
|
|
it("should report a warning on and remove cookie on ERROR", async () => {
|
|
server.use(http.get(`${apiBase}/account/logout`, () => HttpResponse.error()));
|
|
|
|
await accountApi.logout();
|
|
|
|
expect(Utils.removeCookie).toHaveBeenCalledWith(SESSION_ID_COOKIE_NAME);
|
|
expect(console.warn).toHaveBeenCalledWith("Log out failed!", expect.any(Error));
|
|
});
|
|
});
|
|
});
|