mirror of
https://github.com/pagefaultgames/pokerogue.git
synced 2025-06-20 16:42:45 +02:00
Compare commits
2 Commits
59152d0c6c
...
fa0da8438a
Author | SHA1 | Date | |
---|---|---|---|
|
fa0da8438a | ||
|
c310df3a66 |
@ -3,7 +3,7 @@ import { MoveId } from "#enums/move-id";
|
|||||||
import { SpeciesId } from "#enums/species-id";
|
import { SpeciesId } from "#enums/species-id";
|
||||||
import GameManager from "#test/testUtils/gameManager";
|
import GameManager from "#test/testUtils/gameManager";
|
||||||
import Phaser from "phaser";
|
import Phaser from "phaser";
|
||||||
import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest";
|
import { beforeAll, beforeEach, describe, expect, it } from "vitest";
|
||||||
|
|
||||||
describe("{{description}}", () => {
|
describe("{{description}}", () => {
|
||||||
let phaserGame: Phaser.Game;
|
let phaserGame: Phaser.Game;
|
||||||
@ -15,10 +15,6 @@ describe("{{description}}", () => {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
afterEach(() => {
|
|
||||||
game.phaseInterceptor.restoreOg();
|
|
||||||
});
|
|
||||||
|
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
game = new GameManager(phaserGame);
|
game = new GameManager(phaserGame);
|
||||||
game.override
|
game.override
|
||||||
|
@ -253,7 +253,9 @@ export class PhaseManager {
|
|||||||
constructor() {
|
constructor() {
|
||||||
this.dynamicPhaseQueues = [new PostSummonPhasePriorityQueue()];
|
this.dynamicPhaseQueues = [new PostSummonPhasePriorityQueue()];
|
||||||
this.dynamicPhaseTypes = [PostSummonPhase];
|
this.dynamicPhaseTypes = [PostSummonPhase];
|
||||||
} /* Phase Functions */
|
}
|
||||||
|
|
||||||
|
/* Phase Functions */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Getter function to return the currently-in-progess {@linkcode Phase}.
|
* Getter function to return the currently-in-progess {@linkcode Phase}.
|
||||||
@ -358,10 +360,9 @@ export class PhaseManager {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.phaseQueuePrependSpliceIndex > -1) {
|
this.clearPhaseQueueSplice();
|
||||||
this.clearPhaseQueueSplice();
|
|
||||||
}
|
|
||||||
this.phaseQueue.unshift(...this.phaseQueuePrepend);
|
this.phaseQueue.unshift(...this.phaseQueuePrepend);
|
||||||
|
this.phaseQueuePrepend = [];
|
||||||
|
|
||||||
if (!this.phaseQueue.length) {
|
if (!this.phaseQueue.length) {
|
||||||
this.populatePhaseQueue();
|
this.populatePhaseQueue();
|
||||||
@ -372,22 +373,17 @@ export class PhaseManager {
|
|||||||
this.currentPhase = this.phaseQueue.shift() ?? null;
|
this.currentPhase = this.phaseQueue.shift() ?? null;
|
||||||
|
|
||||||
const unactivatedConditionalPhases: [() => boolean, Phase][] = [];
|
const unactivatedConditionalPhases: [() => boolean, Phase][] = [];
|
||||||
// Check if there are any conditional phases queued
|
// Check each queued conditional phase, either adding it to the end of the queue (if met)
|
||||||
while (this.conditionalQueue?.length) {
|
// or keeping it on (if not).
|
||||||
// Retrieve the first conditional phase from the queue
|
for (const [condition, phase] of this.conditionalQueue) {
|
||||||
const conditionalPhase = this.conditionalQueue.shift();
|
if (condition()) {
|
||||||
// Evaluate the condition associated with the phase
|
this.pushPhase(phase);
|
||||||
if (conditionalPhase?.[0]()) {
|
|
||||||
// If the condition is met, add the phase to the phase queue
|
|
||||||
this.pushPhase(conditionalPhase[1]);
|
|
||||||
} else if (conditionalPhase) {
|
|
||||||
// If the condition is not met, re-add the phase back to the front of the conditional queue
|
|
||||||
unactivatedConditionalPhases.push(conditionalPhase);
|
|
||||||
} else {
|
} else {
|
||||||
console.warn("condition phase is undefined/null!", conditionalPhase);
|
unactivatedConditionalPhases.push([condition, phase]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this.conditionalQueue.push(...unactivatedConditionalPhases);
|
this.conditionalQueue = unactivatedConditionalPhases;
|
||||||
|
|
||||||
this.startCurrentPhase();
|
this.startCurrentPhase();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -407,6 +403,7 @@ export class PhaseManager {
|
|||||||
this.currentPhase.start();
|
this.currentPhase.start();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO: Review if we can remove this
|
||||||
overridePhase(phase: Phase): boolean {
|
overridePhase(phase: Phase): boolean {
|
||||||
if (this.standbyPhase) {
|
if (this.standbyPhase) {
|
||||||
return false;
|
return false;
|
||||||
@ -481,9 +478,9 @@ export class PhaseManager {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Tries to add the input phase(s) to index after target phase in the {@linkcode phaseQueue}, else simply calls {@linkcode unshiftPhase()}
|
* Tries to add the input phase(s) to index after target phase in the {@linkcode phaseQueue}, else simply calls {@linkcode unshiftPhase()}
|
||||||
* @param phase {@linkcode Phase} the phase(s) to be added
|
* @param phase - One or more {@linkcode Phase}s to be added
|
||||||
* @param targetPhase {@linkcode Phase} the type of phase to search for in {@linkcode phaseQueue}
|
* @param targetPhase - The type of target {@linkcode Phase} phase to search for in {@linkcode phaseQueue}
|
||||||
* @param condition Condition the target phase must meet to be appended to
|
* @param condition - If provided, will only consider target phases passing the condition.
|
||||||
* @returns `true` if a `targetPhase` was found to append to
|
* @returns `true` if a `targetPhase` was found to append to
|
||||||
*/
|
*/
|
||||||
appendToPhase(phase: Phase | Phase[], targetPhase: PhaseString, condition?: (p: Phase) => boolean): boolean {
|
appendToPhase(phase: Phase | Phase[], targetPhase: PhaseString, condition?: (p: Phase) => boolean): boolean {
|
||||||
@ -501,7 +498,7 @@ export class PhaseManager {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Checks a phase and returns the matching {@linkcode DynamicPhaseType}, or undefined if it does not match one
|
* Checks a phase and returns the matching {@linkcode DynamicPhaseType}, or undefined if it does not match one
|
||||||
* @param phase The phase to check
|
* @param phase - The {@linkcode Phase} to check
|
||||||
* @returns The corresponding {@linkcode DynamicPhaseType} or `undefined`
|
* @returns The corresponding {@linkcode DynamicPhaseType} or `undefined`
|
||||||
*/
|
*/
|
||||||
public getDynamicPhaseType(phase: Phase | null): DynamicPhaseType | undefined {
|
public getDynamicPhaseType(phase: Phase | null): DynamicPhaseType | undefined {
|
||||||
@ -519,7 +516,7 @@ export class PhaseManager {
|
|||||||
* Pushes a phase onto its corresponding dynamic queue and marks the activation point in {@linkcode phaseQueue}
|
* Pushes a phase onto its corresponding dynamic queue and marks the activation point in {@linkcode phaseQueue}
|
||||||
*
|
*
|
||||||
* The {@linkcode ActivatePriorityQueuePhase} will run the top phase in the dynamic queue (not necessarily {@linkcode phase})
|
* The {@linkcode ActivatePriorityQueuePhase} will run the top phase in the dynamic queue (not necessarily {@linkcode phase})
|
||||||
* @param phase The phase to push
|
* @param phase The {@linkcode Phase} to push
|
||||||
*/
|
*/
|
||||||
public pushDynamicPhase(phase: Phase): void {
|
public pushDynamicPhase(phase: Phase): void {
|
||||||
const type = this.getDynamicPhaseType(phase);
|
const type = this.getDynamicPhaseType(phase);
|
||||||
@ -533,7 +530,7 @@ export class PhaseManager {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Unshifts the top phase from the corresponding dynamic queue onto {@linkcode phaseQueue}
|
* Unshifts the top phase from the corresponding dynamic queue onto {@linkcode phaseQueue}
|
||||||
* @param type {@linkcode DynamicPhaseType} The type of dynamic phase to start
|
* @param type - The {@linkcode DynamicPhaseType} corresponding to the dynamic phase being started.
|
||||||
*/
|
*/
|
||||||
public startDynamicPhaseType(type: DynamicPhaseType): void {
|
public startDynamicPhaseType(type: DynamicPhaseType): void {
|
||||||
const phase = this.dynamicPhaseQueues[type].pop();
|
const phase = this.dynamicPhaseQueues[type].pop();
|
||||||
@ -548,8 +545,7 @@ export class PhaseManager {
|
|||||||
* This is the same as {@linkcode pushDynamicPhase}, except the activation phase is unshifted
|
* This is the same as {@linkcode pushDynamicPhase}, except the activation phase is unshifted
|
||||||
*
|
*
|
||||||
* {@linkcode phase} is not guaranteed to be the next phase from the queue to run (if the queue is not empty)
|
* {@linkcode phase} is not guaranteed to be the next phase from the queue to run (if the queue is not empty)
|
||||||
* @param phase The phase to add
|
* @param phase - The {@linkcode Phase} to add
|
||||||
* @returns
|
|
||||||
*/
|
*/
|
||||||
public startDynamicPhase(phase: Phase): void {
|
public startDynamicPhase(phase: Phase): void {
|
||||||
const type = this.getDynamicPhaseType(phase);
|
const type = this.getDynamicPhaseType(phase);
|
||||||
@ -571,7 +567,7 @@ export class PhaseManager {
|
|||||||
*
|
*
|
||||||
* @see {@linkcode MessagePhase} for more details on the parameters
|
* @see {@linkcode MessagePhase} for more details on the parameters
|
||||||
*/
|
*/
|
||||||
queueMessage(
|
public queueMessage(
|
||||||
message: string,
|
message: string,
|
||||||
callbackDelay?: number | null,
|
callbackDelay?: number | null,
|
||||||
prompt?: boolean | null,
|
prompt?: boolean | null,
|
||||||
@ -596,7 +592,7 @@ export class PhaseManager {
|
|||||||
*/
|
*/
|
||||||
public queueAbilityDisplay(pokemon: Pokemon, passive: boolean, show: boolean): void {
|
public queueAbilityDisplay(pokemon: Pokemon, passive: boolean, show: boolean): void {
|
||||||
this.unshiftPhase(show ? new ShowAbilityPhase(pokemon.getBattlerIndex(), passive) : new HideAbilityPhase());
|
this.unshiftPhase(show ? new ShowAbilityPhase(pokemon.getBattlerIndex(), passive) : new HideAbilityPhase());
|
||||||
this.clearPhaseQueueSplice();
|
this.clearPhaseQueueSplice(); // TODO: Is this necessary?
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -609,7 +605,8 @@ export class PhaseManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Moves everything from nextCommandPhaseQueue to phaseQueue (keeping order)
|
* Moves everything from nextCommandPhaseQueue to phaseQueue (keeping order),
|
||||||
|
* then adds a new {@linkcode TurnInitPhase} to start a new turn.
|
||||||
*/
|
*/
|
||||||
private populatePhaseQueue(): void {
|
private populatePhaseQueue(): void {
|
||||||
if (this.nextCommandPhaseQueue.length) {
|
if (this.nextCommandPhaseQueue.length) {
|
||||||
|
@ -197,11 +197,5 @@ export default class PhaseInterceptor {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
restoreOg() {}
|
||||||
* Restores the original state of phases and clears intervals.
|
|
||||||
*/
|
|
||||||
restoreOg() {
|
|
||||||
// clearInterval(this.promptInterval);
|
|
||||||
// clearInterval(this.intervalRun);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -16,8 +16,8 @@ abstract class mockPhase extends Phase {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class normalPhase extends mockPhase {
|
class bananaPhase extends mockPhase {
|
||||||
public readonly phaseName = "normalPhase";
|
public readonly phaseName = "bananaPhase";
|
||||||
}
|
}
|
||||||
|
|
||||||
class applePhase extends mockPhase {
|
class applePhase extends mockPhase {
|
||||||
@ -36,7 +36,7 @@ class oneSecTimerPhase extends mockPhase {
|
|||||||
class unshifterPhase extends mockPhase {
|
class unshifterPhase extends mockPhase {
|
||||||
public readonly phaseName = "unshifterPhase";
|
public readonly phaseName = "unshifterPhase";
|
||||||
override start() {
|
override start() {
|
||||||
game.scene.phaseManager.unshiftPhase(new normalPhase() as unknown as Phase);
|
game.scene.phaseManager.unshiftPhase(new bananaPhase() as unknown as Phase);
|
||||||
game.scene.phaseManager.unshiftPhase(new applePhase() as unknown as Phase);
|
game.scene.phaseManager.unshiftPhase(new applePhase() as unknown as Phase);
|
||||||
super.start();
|
super.start();
|
||||||
}
|
}
|
||||||
@ -52,7 +52,7 @@ describe("Utils - Phase Interceptor", { timeout: 4000 }, () => {
|
|||||||
|
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
game = new GameManager(phaserGame);
|
game = new GameManager(phaserGame);
|
||||||
setPhases(normalPhase, applePhase, oneSecTimerPhase, unshifterPhase, normalPhase);
|
setPhases(bananaPhase, applePhase, oneSecTimerPhase, unshifterPhase, bananaPhase);
|
||||||
});
|
});
|
||||||
|
|
||||||
function setPhases(...phases: Constructor<mockPhase>[]) {
|
function setPhases(...phases: Constructor<mockPhase>[]) {
|
||||||
@ -78,29 +78,29 @@ describe("Utils - Phase Interceptor", { timeout: 4000 }, () => {
|
|||||||
|
|
||||||
describe("to", () => {
|
describe("to", () => {
|
||||||
it("should run the specified phase and halt after it ends", async () => {
|
it("should run the specified phase and halt after it ends", async () => {
|
||||||
await to("normalPhase");
|
await to("bananaPhase");
|
||||||
expect(getCurrentPhaseName()).toBe("applePhase");
|
expect(getCurrentPhaseName()).toBe("applePhase");
|
||||||
expect(getQueuedPhases()).toEqual(["oneSecTimerPhase", "unshifterPhase", "normalPhase"]);
|
expect(getQueuedPhases()).toEqual(["oneSecTimerPhase", "unshifterPhase", "bananaPhase"]);
|
||||||
expect(game.phaseInterceptor.log).toEqual(["normalPhase"]);
|
expect(game.phaseInterceptor.log).toEqual(["bananaPhase"]);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should run to the specified phase without starting/logging", async () => {
|
it("should run to the specified phase without starting/logging", async () => {
|
||||||
await to("normalPhase", false);
|
await to("bananaPhase", false);
|
||||||
expect(getCurrentPhaseName()).toBe("normalPhase");
|
expect(getCurrentPhaseName()).toBe("bananaPhase");
|
||||||
expect(getQueuedPhases()).toEqual(["applePhase", "oneSecTimerPhase", "unshifterPhase", "normalPhase"]);
|
expect(getQueuedPhases()).toEqual(["applePhase", "oneSecTimerPhase", "unshifterPhase", "bananaPhase"]);
|
||||||
expect(game.phaseInterceptor.log).toHaveLength(0);
|
expect(game.phaseInterceptor.log).toHaveLength(0);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should start all phases between start and target", async () => {
|
it("should start all phases between start and target", async () => {
|
||||||
await to("oneSecTimerPhase");
|
await to("oneSecTimerPhase");
|
||||||
expect(getQueuedPhases()).toEqual(["unshifterPhase", "normalPhase"]);
|
expect(getQueuedPhases()).toEqual(["unshifterPhase", "bananaPhase"]);
|
||||||
expect(game.phaseInterceptor.log).toEqual(["normalPhase", "applePhase", "oneSecTimerPhase"]);
|
expect(game.phaseInterceptor.log).toEqual(["bananaPhase", "applePhase", "oneSecTimerPhase"]);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should work on newly unshifted phases", async () => {
|
it("should work on newly unshifted phases", async () => {
|
||||||
setPhases(unshifterPhase); // adds normalPhase and applePhase to queue
|
setPhases(unshifterPhase); // adds bananaPhase and applePhase to queue
|
||||||
await to("applePhase");
|
await to("applePhase");
|
||||||
expect(game.phaseInterceptor.log).toEqual(["unshifterPhase", "normalPhase", "applePhase"]);
|
expect(game.phaseInterceptor.log).toEqual(["unshifterPhase", "bananaPhase", "applePhase"]);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should wait until phase finishes before starting next", async () => {
|
it("should wait until phase finishes before starting next", async () => {
|
||||||
@ -112,13 +112,13 @@ describe("Utils - Phase Interceptor", { timeout: 4000 }, () => {
|
|||||||
|
|
||||||
describe("shift", () => {
|
describe("shift", () => {
|
||||||
it("should skip the next phase without starting", async () => {
|
it("should skip the next phase without starting", async () => {
|
||||||
expect(getCurrentPhaseName()).toBe("normalPhase");
|
expect(getCurrentPhaseName()).toBe("bananaPhase");
|
||||||
expect(getQueuedPhases()).toEqual(["applePhase", "oneSecTimerPhase", "unshifterPhase", "normalPhase"]);
|
expect(getQueuedPhases()).toEqual(["applePhase", "oneSecTimerPhase", "unshifterPhase", "bananaPhase"]);
|
||||||
|
|
||||||
game.phaseInterceptor.shiftPhase();
|
game.phaseInterceptor.shiftPhase();
|
||||||
|
|
||||||
expect(getCurrentPhaseName()).toBe("applePhase");
|
expect(getCurrentPhaseName()).toBe("applePhase");
|
||||||
expect(getQueuedPhases()).toEqual(["oneSecTimerPhase", "unshifterPhase", "normalPhase"]);
|
expect(getQueuedPhases()).toEqual(["oneSecTimerPhase", "unshifterPhase", "bananaPhase"]);
|
||||||
expect(game.phaseInterceptor.log).toEqual([]);
|
expect(game.phaseInterceptor.log).toEqual([]);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user