Merge remote-tracking branch 'rhh/upcoming' into battlemove_refactored

This commit is contained in:
Nephrite 2024-02-27 13:03:26 +09:00
commit b1f0fbdf89
4 changed files with 86 additions and 1 deletions

View file

@ -8553,6 +8553,7 @@ BattleScript_GooeyActivates::
call BattleScript_AbilityPopUp call BattleScript_AbilityPopUp
swapattackerwithtarget @ for defiant, mirror armor swapattackerwithtarget @ for defiant, mirror armor
seteffectsecondary seteffectsecondary
swapattackerwithtarget
return return
BattleScript_AbilityStatusEffect:: BattleScript_AbilityStatusEffect::

View file

@ -195,3 +195,20 @@ DOUBLE_BATTLE_TEST("Mirror Armor lowers Speed of the partner Pokemon after Court
MESSAGE("Wobbuffet's Speed fell!"); MESSAGE("Wobbuffet's Speed fell!");
} }
} }
SINGLE_BATTLE_TEST("Mirror Armor reflects Tangling Hair speed drop")
{
KNOWN_FAILING;
GIVEN {
PLAYER(SPECIES_DUGTRIO) { Ability(ABILITY_TANGLING_HAIR); }
OPPONENT(SPECIES_CORVIKNIGHT) { Ability(ABILITY_MIRROR_ARMOR); }
} WHEN {
TURN { MOVE(opponent, MOVE_TACKLE); }
} SCENE {
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
ABILITY_POPUP(player, ABILITY_TANGLING_HAIR);
NOT ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
ABILITY_POPUP(opponent, ABILITY_MIRROR_ARMOR);
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
}
}

View file

@ -0,0 +1,68 @@
#include "global.h"
#include "test/battle.h"
ASSUMPTIONS
{
ASSUME(gMovesInfo[MOVE_TACKLE].effect == EFFECT_HIT);
ASSUME(gMovesInfo[MOVE_TACKLE].power > 0);
ASSUME(gMovesInfo[MOVE_TACKLE].makesContact == TRUE);
}
SINGLE_BATTLE_TEST("Tangling Hair drops opposing mon's speed if ability user got hit by a contact move")
{
u32 move;
PARAMETRIZE { move = MOVE_TACKLE; }
PARAMETRIZE { move = MOVE_SWIFT; }
GIVEN {
ASSUME(gMovesInfo[MOVE_SWIFT].makesContact == FALSE);
PLAYER(SPECIES_DUGTRIO) { Ability(ABILITY_TANGLING_HAIR); }
OPPONENT(SPECIES_WYNAUT);
} WHEN {
TURN { MOVE(opponent, move); }
} SCENE {
ANIMATION(ANIM_TYPE_MOVE, move, opponent);
if (move == MOVE_TACKLE) {
ABILITY_POPUP(player, ABILITY_TANGLING_HAIR);
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
MESSAGE("Foe Wynaut's Speed fell!");
}
}
}
SINGLE_BATTLE_TEST("Tangling Hair does not cause Rocky Helmet miss activation")
{
GIVEN {
ASSUME(gItemsInfo[ITEM_ROCKY_HELMET].holdEffect == HOLD_EFFECT_ROCKY_HELMET);
PLAYER(SPECIES_DUGTRIO) { Ability(ABILITY_TANGLING_HAIR); Item(ITEM_ROCKY_HELMET); }
OPPONENT(SPECIES_WYNAUT);
} WHEN {
TURN { MOVE(opponent, MOVE_TACKLE); }
} SCENE {
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
ABILITY_POPUP(player, ABILITY_TANGLING_HAIR);
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
MESSAGE("Foe Wynaut's Speed fell!");
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_HELD_ITEM_EFFECT, player);
MESSAGE("Foe Wynaut was hurt by Dugtrio's Rocky Helmet!");
}
}
SINGLE_BATTLE_TEST("Tangling Hair Speed stat drop triggers defiant")
{
GIVEN {
PLAYER(SPECIES_DUGTRIO) { Ability(ABILITY_TANGLING_HAIR); }
OPPONENT(SPECIES_PAWNIARD) { Ability(ABILITY_DEFIANT); }
} WHEN {
TURN { MOVE(opponent, MOVE_TACKLE); }
} SCENE {
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
ABILITY_POPUP(player, ABILITY_TANGLING_HAIR);
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
MESSAGE("Foe Pawniard's Speed fell!");
ABILITY_POPUP(opponent, ABILITY_DEFIANT);
MESSAGE("Foe Pawniard's Attack sharply rose!");
}
}

View file

@ -275,7 +275,6 @@ SINGLE_BATTLE_TEST("Rage Fist number of hits is copied by Transform")
{ {
s16 timesGotHit[2]; s16 timesGotHit[2];
// KNOWN_FAILING; // After Transform , wrong move is used by transformed mon
GIVEN { GIVEN {
PLAYER(SPECIES_REGIROCK); PLAYER(SPECIES_REGIROCK);
OPPONENT(SPECIES_REGIROCK) { Moves(MOVE_RAGE_FIST, MOVE_CELEBRATE); } OPPONENT(SPECIES_REGIROCK) { Moves(MOVE_RAGE_FIST, MOVE_CELEBRATE); }