mirror of
				https://github.com/pagefaultgames/pokerogue.git
				synced 2025-10-26 14:05:51 +01:00 
			
		
		
		
	* Add enum for hit check result Co-authored-by: innerthunder <brandonerickson98@gmail.com> * Refactor parameter list for pokemon#getBaseDamage and pokemon#getAttackDamage * Rewrite move phase Co-authored-by: innerthunder <brandonerickson98@gmail.com> * Update tests to reflect move effect phase changes Co-authored-by: innerthunder <brandonerickson98@gmail.com> * Fix pluck / bug bite Co-authored-by: innerthunder <brandonerickson98@gmail.com> * Fix reviver seed ohko, remove leftover dead code Co-authored-by: innerthunder <brandonerickson98@gmail.com> * Cleanup jsdoc comments * Remove hitsSubstitute check from postDefend abilities * Fix improper i18nkey in moveEffectPhase#applyToTargets * Cleanup comments * Fix type issue with substitute test * Move MYSTERY_ENCOUNTER_WAVES to constants.ts * Update linkcode in damageparams to use proper tsdoc syntax --------- Co-authored-by: innerthunder <brandonerickson98@gmail.com>
		
			
				
	
	
		
			64 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			64 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { BattlerIndex } from "#app/battle";
 | |
| import { MoveEffectPhase } from "#app/phases/move-effect-phase";
 | |
| import { MoveEndPhase } from "#app/phases/move-end-phase";
 | |
| import { Abilities } from "#enums/abilities";
 | |
| import { Moves } from "#enums/moves";
 | |
| import { Species } from "#enums/species";
 | |
| import { HitCheckResult } from "#enums/hit-check-result";
 | |
| import GameManager from "#test/testUtils/gameManager";
 | |
| import Phaser from "phaser";
 | |
| import { afterEach, beforeAll, beforeEach, describe, it, expect, vi } from "vitest";
 | |
| 
 | |
| describe("Abilities - No Guard", () => {
 | |
|   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.ZAP_CANNON)
 | |
|       .ability(Abilities.NO_GUARD)
 | |
|       .enemyLevel(200)
 | |
|       .enemySpecies(Species.SNORLAX)
 | |
|       .enemyAbility(Abilities.BALL_FETCH)
 | |
|       .enemyMoveset(Moves.SPLASH);
 | |
|   });
 | |
| 
 | |
|   it("should make moves always hit regardless of move accuracy", async () => {
 | |
|     game.override.battleStyle("single");
 | |
| 
 | |
|     await game.classicMode.startBattle([Species.REGIELEKI]);
 | |
| 
 | |
|     game.move.select(Moves.ZAP_CANNON);
 | |
| 
 | |
|     await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]);
 | |
| 
 | |
|     await game.phaseInterceptor.to(MoveEffectPhase, false);
 | |
| 
 | |
|     const moveEffectPhase = game.scene.getCurrentPhase() as MoveEffectPhase;
 | |
|     vi.spyOn(moveEffectPhase, "hitCheck");
 | |
| 
 | |
|     await game.phaseInterceptor.to(MoveEndPhase);
 | |
| 
 | |
|     expect(moveEffectPhase.hitCheck).toHaveReturnedWith([HitCheckResult.HIT, 1]);
 | |
|   });
 | |
| 
 | |
|   it("should guarantee double battle with any one LURE", async () => {
 | |
|     game.override.startingModifier([{ name: "LURE" }]).startingWave(2);
 | |
| 
 | |
|     await game.classicMode.startBattle();
 | |
| 
 | |
|     expect(game.scene.getEnemyField().length).toBe(2);
 | |
|   });
 | |
| });
 |