Merge branch 'beta' into update-create-test-script

This commit is contained in:
Adrian T. 2024-10-05 15:14:30 +08:00 committed by GitHub
commit 14364a11a4
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 59 additions and 1 deletions

View File

@ -4623,7 +4623,7 @@ async function applyAbAttrsInternal<TAttr extends AbAttr>(
messages: string[] = [], messages: string[] = [],
) { ) {
for (const passive of [ false, true ]) { for (const passive of [ false, true ]) {
if (!pokemon?.canApplyAbility(passive)) { if (!pokemon?.canApplyAbility(passive) || (passive && pokemon.getPassiveAbility().id === pokemon.getAbility().id)) {
continue; continue;
} }

View File

@ -0,0 +1,58 @@
import { Stat } from "#app/enums/stat";
import { Abilities } from "#enums/abilities";
import { Moves } from "#enums/moves";
import { Species } from "#enums/species";
import GameManager from "#test/utils/gameManager";
import Phaser from "phaser";
import { afterEach, beforeAll, beforeEach, describe, it, expect } from "vitest";
describe("Ability Duplication", () => {
let phaserGame: Phaser.Game;
let game: GameManager;
beforeAll(() => {
phaserGame = new Phaser.Game({
type: Phaser.HEADLESS,
});
});
afterEach(() => {
game.phaseInterceptor.restoreOg();
});
beforeEach(() => {
game = new GameManager(phaserGame);
game.override
.moveset([ Moves.SPLASH ])
.battleType("single")
.ability(Abilities.HUGE_POWER)
.enemyAbility(Abilities.BALL_FETCH)
.enemyMoveset(Moves.SPLASH);
});
it("huge power should only be applied once if both normal and passive", async () => {
game.override.passiveAbility(Abilities.HUGE_POWER);
await game.classicMode.startBattle([ Species.MAGIKARP ]);
const [ magikarp ] = game.scene.getPlayerField();
const magikarpAttack = magikarp.getEffectiveStat(Stat.ATK);
magikarp.summonData.abilitySuppressed = true;
expect(magikarp.getEffectiveStat(Stat.ATK)).toBe(magikarpAttack / 2);
});
it("huge power should stack with pure power", async () => {
game.override.passiveAbility(Abilities.PURE_POWER);
await game.classicMode.startBattle([ Species.MAGIKARP ]);
const [ magikarp ] = game.scene.getPlayerField();
const magikarpAttack = magikarp.getEffectiveStat(Stat.ATK);
magikarp.summonData.abilitySuppressed = true;
expect(magikarp.getEffectiveStat(Stat.ATK)).toBe(magikarpAttack / 4);
});
});