Merge branch 'pagefaultgames:main' into main

This commit is contained in:
3ae3ae 2024-07-03 12:36:23 +09:00 committed by GitHub
commit d02d28a5e0
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 76 additions and 3 deletions

74
src/test/account.spec.ts Normal file
View File

@ -0,0 +1,74 @@
import * as battleScene from "#app/battle-scene.js";
import { describe, expect, it, vi } from "vitest";
import { initLoggedInUser, loggedInUser, updateUserInfo } from "../account";
import * as utils from "../utils";
describe("account", () => {
describe("initLoggedInUser", () => {
it("should set loggedInUser to Guest and lastSessionSlot to -1", () => {
initLoggedInUser();
expect(loggedInUser.username).toBe("Guest");
expect(loggedInUser.lastSessionSlot).toBe(-1);
});
});
describe("updateUserInfo", () => {
it("should set loggedInUser to Guest if bypassLogin is true", async () => {
vi.spyOn(battleScene, "bypassLogin", "get").mockReturnValue(true);
const [success, status] = await updateUserInfo();
expect(success).toBe(true);
expect(status).toBe(200);
expect(loggedInUser.username).toBe("Guest");
expect(loggedInUser.lastSessionSlot).toBe(-1);
});
it("should fetch user info from the API if bypassLogin is false", async () => {
vi.spyOn(battleScene, "bypassLogin", "get").mockReturnValue(false);
vi.spyOn(utils, "apiFetch").mockResolvedValue(
new Response(
JSON.stringify({
username: "test",
lastSessionSlot: 99,
}),
{
status: 200,
}
)
);
const [success, status] = await updateUserInfo();
expect(success).toBe(true);
expect(status).toBe(200);
expect(loggedInUser.username).toBe("test");
expect(loggedInUser.lastSessionSlot).toBe(99);
});
it("should handle resolved API errors", async () => {
vi.spyOn(battleScene, "bypassLogin", "get").mockReturnValue(false);
vi.spyOn(utils, "apiFetch").mockResolvedValue(
new Response(null, { status: 401 })
);
const [success, status] = await updateUserInfo();
expect(success).toBe(false);
expect(status).toBe(401);
});
it("should handle rejected API errors", async () => {
const consoleErrorSpy = vi.spyOn(console, "error");
vi.spyOn(battleScene, "bypassLogin", "get").mockReturnValue(false);
vi.spyOn(utils, "apiFetch").mockRejectedValue(new Error("Api failed!"));
const [success, status] = await updateUserInfo();
expect(success).toBe(false);
expect(status).toBe(500);
expect(consoleErrorSpy).toHaveBeenCalled();
});
});
});

View File

@ -2077,9 +2077,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler {
this.pokemonHatchedIcon, this.pokemonHatchedIcon,
this.pokemonHatchedCountText this.pokemonHatchedCountText
].map(c => c.setVisible(false)); ].map(c => c.setVisible(false));
} else if (species.speciesId === Species.ETERNATUS) { this.pokemonFormText.setY(25);
this.pokemonHatchedIcon.setVisible(false);
this.pokemonHatchedCountText.setVisible(false);
} else { } else {
this.pokemonCaughtHatchedContainer.setY(25); this.pokemonCaughtHatchedContainer.setY(25);
this.pokemonShinyIcon.setY(117); this.pokemonShinyIcon.setY(117);
@ -2091,6 +2089,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler {
this.pokemonCandyCountText.setText(`x${this.scene.gameData.starterData[species.speciesId].candyCount}`); this.pokemonCandyCountText.setText(`x${this.scene.gameData.starterData[species.speciesId].candyCount}`);
this.pokemonCandyCountText.setVisible(true); this.pokemonCandyCountText.setVisible(true);
this.pokemonFormText.setVisible(true); this.pokemonFormText.setVisible(true);
this.pokemonFormText.setY(42);
this.pokemonHatchedIcon.setVisible(true); this.pokemonHatchedIcon.setVisible(true);
this.pokemonHatchedCountText.setVisible(true); this.pokemonHatchedCountText.setVisible(true);