mirror of
https://github.com/pagefaultgames/pokerogue.git
synced 2025-06-21 17:12:44 +02:00
[Bug] Fix super luck implementation (#5625)
* Fix super luck implementation * Use numberholder instead of booleanholder * Update tsdoc for getCritStage
This commit is contained in:
parent
420c2e37c2
commit
9e4162d429
@ -3499,8 +3499,18 @@ export class BonusCritAbAttr extends AbAttr {
|
|||||||
constructor() {
|
constructor() {
|
||||||
super(false);
|
super(false);
|
||||||
}
|
}
|
||||||
override apply(pokemon: Pokemon, passive: boolean, simulated: boolean, cancelled: Utils.BooleanHolder, args: any[]): void {
|
|
||||||
(args[0] as Utils.BooleanHolder).value = true;
|
/**
|
||||||
|
* Apply the bonus crit ability by increasing the value in the provided number holder by 1
|
||||||
|
*
|
||||||
|
* @param pokemon The pokemon with the BonusCrit ability (unused)
|
||||||
|
* @param passive Unused
|
||||||
|
* @param simulated Unused
|
||||||
|
* @param cancelled Unused
|
||||||
|
* @param args Args[0] is a number holder containing the crit stage.
|
||||||
|
*/
|
||||||
|
override apply(pokemon: Pokemon, passive: boolean, simulated: boolean, cancelled: Utils.BooleanHolder, args: [Utils.NumberHolder, ...any]): void {
|
||||||
|
(args[0] as Utils.NumberHolder).value += 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1340,8 +1340,9 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Retrieves the critical-hit stage considering the move used and the Pokemon
|
* Calculate the critical-hit stage of a move used against this pokemon by
|
||||||
* who used it.
|
* the given source
|
||||||
|
*
|
||||||
* @param source the {@linkcode Pokemon} who using the move
|
* @param source the {@linkcode Pokemon} who using the move
|
||||||
* @param move the {@linkcode Move} being used
|
* @param move the {@linkcode Move} being used
|
||||||
* @returns the final critical-hit stage value
|
* @returns the final critical-hit stage value
|
||||||
@ -1360,14 +1361,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container {
|
|||||||
source.isPlayer(),
|
source.isPlayer(),
|
||||||
critStage,
|
critStage,
|
||||||
);
|
);
|
||||||
const bonusCrit = new Utils.BooleanHolder(false);
|
applyAbAttrs(BonusCritAbAttr, source, null, false, critStage)
|
||||||
//@ts-ignore
|
|
||||||
if (applyAbAttrs(BonusCritAbAttr, source, null, false, bonusCrit)) {
|
|
||||||
// TODO: resolve ts-ignore. This is a promise. Checking a promise is bogus.
|
|
||||||
if (bonusCrit.value) {
|
|
||||||
critStage.value += 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
const critBoostTag = source.getTag(CritBoostTag);
|
const critBoostTag = source.getTag(CritBoostTag);
|
||||||
if (critBoostTag) {
|
if (critBoostTag) {
|
||||||
if (critBoostTag instanceof DragonCheerTag) {
|
if (critBoostTag instanceof DragonCheerTag) {
|
||||||
|
43
test/abilities/super_luck.test.ts
Normal file
43
test/abilities/super_luck.test.ts
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
import { Abilities } from "#enums/abilities";
|
||||||
|
import { Moves } from "#enums/moves";
|
||||||
|
import { Species } from "#enums/species";
|
||||||
|
import GameManager from "#test/testUtils/gameManager";
|
||||||
|
import Phaser from "phaser";
|
||||||
|
import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest";
|
||||||
|
|
||||||
|
describe("Abilities - Super Luck", () => {
|
||||||
|
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.TACKLE])
|
||||||
|
.ability(Abilities.SUPER_LUCK)
|
||||||
|
.battleType("single")
|
||||||
|
.disableCrits()
|
||||||
|
.enemySpecies(Species.MAGIKARP)
|
||||||
|
.enemyAbility(Abilities.BALL_FETCH)
|
||||||
|
.enemyMoveset(Moves.SPLASH);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should increase the crit stage of a user by 1", async () => {
|
||||||
|
await game.classicMode.startBattle([Species.MAGIKARP]);
|
||||||
|
const enemy = game.scene.getEnemyPokemon()!;
|
||||||
|
const fn = vi.spyOn(enemy, "getCritStage");
|
||||||
|
game.move.select(Moves.TACKLE);
|
||||||
|
await game.phaseInterceptor.to("BerryPhase");
|
||||||
|
expect(fn).toHaveReturnedWith(1);
|
||||||
|
fn.mockRestore();
|
||||||
|
});
|
||||||
|
});
|
Loading…
Reference in New Issue
Block a user