mirror of
https://github.com/pagefaultgames/pokerogue.git
synced 2025-07-01 05:52:17 +02:00
huhjjjjjb
This commit is contained in:
parent
745714ea28
commit
b341943ea8
@ -1,3 +1,4 @@
|
|||||||
|
import { BattlerIndex } from "#app/battle";
|
||||||
import type Pokemon from "#app/field/pokemon";
|
import type Pokemon from "#app/field/pokemon";
|
||||||
import { BerryModifier, PreserveBerryModifier } from "#app/modifier/modifier";
|
import { BerryModifier, PreserveBerryModifier } from "#app/modifier/modifier";
|
||||||
import type { ModifierOverride } from "#app/modifier/modifier-type";
|
import type { ModifierOverride } from "#app/modifier/modifier-type";
|
||||||
@ -115,8 +116,7 @@ describe("Abilities - Harvest", () => {
|
|||||||
expect(getPlayerBerries()).toHaveLength(1);
|
expect(getPlayerBerries()).toHaveLength(1);
|
||||||
});
|
});
|
||||||
|
|
||||||
// TODO: Figure out why this is borking...???
|
it("remembers berries eaten array across waves and save/reload", async () => {
|
||||||
it("remembers berries eaten tracker across waves and save/reload", async () => {
|
|
||||||
game.override
|
game.override
|
||||||
.startingHeldItems([{ name: "BERRY", type: BerryType.PETAYA, count: 2 }])
|
.startingHeldItems([{ name: "BERRY", type: BerryType.PETAYA, count: 2 }])
|
||||||
.ability(Abilities.BALL_FETCH); // don't actually need harvest for this test
|
.ability(Abilities.BALL_FETCH); // don't actually need harvest for this test
|
||||||
@ -145,6 +145,42 @@ describe("Abilities - Harvest", () => {
|
|||||||
expect(regielekiReloaded.battleData.berriesEaten).toEqual([BerryType.PETAYA]);
|
expect(regielekiReloaded.battleData.berriesEaten).toEqual([BerryType.PETAYA]);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it("keeps berries eaten across reloads", async () => {
|
||||||
|
game.override
|
||||||
|
.startingHeldItems([{ name: "BERRY", type: BerryType.PETAYA, count: 1 }])
|
||||||
|
.moveset([Moves.SPLASH, Moves.EARTHQUAKE])
|
||||||
|
.enemyMoveset([Moves.SUPER_FANG, Moves.HEAL_PULSE])
|
||||||
|
.enemyAbility(Abilities.COMPOUND_EYES);
|
||||||
|
await game.classicMode.startBattle([Species.REGIELEKI]);
|
||||||
|
|
||||||
|
const regieleki = game.scene.getPlayerPokemon()!;
|
||||||
|
regieleki.hp = regieleki.getMaxHp() / 4 + 1;
|
||||||
|
|
||||||
|
game.move.select(Moves.SPLASH);
|
||||||
|
await game.forceEnemyMove(Moves.SUPER_FANG);
|
||||||
|
await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]);
|
||||||
|
await game.toNextTurn();
|
||||||
|
|
||||||
|
// ate 1 berry and recovered it
|
||||||
|
expect(regieleki.battleData.berriesEaten).toEqual([]);
|
||||||
|
expect(getPlayerBerries()).toEqual([expect.objectContaining({ berryType: BerryType.PETAYA, stackCount: 1 })]);
|
||||||
|
expect(game.scene.getPlayerPokemon()?.getStatStage(Stat.SPATK)).toBe(1);
|
||||||
|
|
||||||
|
// heal up so harvest doesn't proc and kill enemy
|
||||||
|
game.move.select(Moves.EARTHQUAKE);
|
||||||
|
await game.forceEnemyMove(Moves.HEAL_PULSE);
|
||||||
|
await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]);
|
||||||
|
await game.toNextWave();
|
||||||
|
|
||||||
|
expect(getPlayerBerries()).toEqual([expect.objectContaining({ berryType: BerryType.PETAYA, stackCount: 1 })]);
|
||||||
|
expect(game.scene.getPlayerPokemon()?.getStatStage(Stat.SPATK)).toBe(1);
|
||||||
|
|
||||||
|
await game.reload.reloadSession();
|
||||||
|
|
||||||
|
expect(getPlayerBerries()).toEqual([expect.objectContaining({ berryType: BerryType.PETAYA, stackCount: 1 })]);
|
||||||
|
expect(game.scene.getPlayerPokemon()?.getStatStage(Stat.SPATK)).toBe(1);
|
||||||
|
});
|
||||||
|
|
||||||
it("cannot restore capped berries", async () => {
|
it("cannot restore capped berries", async () => {
|
||||||
const initBerries: ModifierOverride[] = [
|
const initBerries: ModifierOverride[] = [
|
||||||
{ name: "BERRY", type: BerryType.LUM, count: 2 },
|
{ name: "BERRY", type: BerryType.LUM, count: 2 },
|
||||||
|
@ -129,7 +129,7 @@ describe("Moves - Toxic Spikes", () => {
|
|||||||
await game.phaseInterceptor.to("BattleEndPhase");
|
await game.phaseInterceptor.to("BattleEndPhase");
|
||||||
await game.toNextWave();
|
await game.toNextWave();
|
||||||
|
|
||||||
const sessionData: SessionSaveData = gameData["getSessionSaveData"]();
|
const sessionData: SessionSaveData = gameData.getSessionSaveData();
|
||||||
localStorage.setItem("sessionTestData", encrypt(JSON.stringify(sessionData), true));
|
localStorage.setItem("sessionTestData", encrypt(JSON.stringify(sessionData), true));
|
||||||
const recoveredData: SessionSaveData = gameData.parseSessionData(
|
const recoveredData: SessionSaveData = gameData.parseSessionData(
|
||||||
decrypt(localStorage.getItem("sessionTestData")!, true),
|
decrypt(localStorage.getItem("sessionTestData")!, true),
|
||||||
|
Loading…
Reference in New Issue
Block a user