#include "global.h" #include "test/battle.h" ASSUMPTIONS { ASSUME(gItemsInfo[ITEM_CHOICE_SPECS].holdEffect == HOLD_EFFECT_CHOICE_SPECS); ASSUME(gItemsInfo[ITEM_CHOICE_BAND].holdEffect == HOLD_EFFECT_CHOICE_BAND); ASSUME(gItemsInfo[ITEM_CHOICE_SCARF].holdEffect == HOLD_EFFECT_CHOICE_SCARF); } AI_SINGLE_BATTLE_TEST("Choiced Pokémon switch out after using a status move once") { u32 j, ability = ABILITY_NONE, heldItem = ITEM_NONE; static const u32 choiceItems[] = { ITEM_CHOICE_SPECS, ITEM_CHOICE_BAND, ITEM_CHOICE_SCARF, }; for (j = 0; j < ARRAY_COUNT(choiceItems); j++) { PARAMETRIZE { ability = ABILITY_NONE; heldItem = choiceItems[j]; } PARAMETRIZE { ability = ABILITY_KLUTZ; heldItem = choiceItems[j]; } } GIVEN { ASSUME(GetMoveCategory(MOVE_YAWN) == DAMAGE_CATEGORY_STATUS); ASSUME(GetMoveEffect(MOVE_YAWN) == EFFECT_YAWN); AI_FLAGS(AI_FLAG_CHECK_BAD_MOVE | AI_FLAG_CHECK_VIABILITY | AI_FLAG_TRY_TO_FAINT); PLAYER(SPECIES_RHYDON) OPPONENT(SPECIES_LOPUNNY) { Moves(MOVE_YAWN, MOVE_TACKLE); Item(heldItem); Ability(ability); } OPPONENT(SPECIES_SWAMPERT) { Moves(MOVE_WATERFALL); } } WHEN { TURN { EXPECT_MOVE(opponent, MOVE_YAWN); } if (ability == ABILITY_KLUTZ) { // Klutz ignores item TURN { EXPECT_MOVE(opponent, MOVE_TACKLE); } } else { TURN { EXPECT_SWITCH(opponent, 1); } } } } AI_SINGLE_BATTLE_TEST("Choiced Pokémon won't use stat boosting moves") { // Moves defined by MOVE_TARGET_USER (with exceptions?) u32 j, ability = ABILITY_NONE, heldItem = ITEM_NONE; static const u32 choiceItems[] = { ITEM_CHOICE_SPECS, ITEM_CHOICE_BAND, ITEM_CHOICE_SCARF, }; for (j = 0; j < ARRAY_COUNT(choiceItems); j++) { PARAMETRIZE { ability = ABILITY_NONE; heldItem = choiceItems[j]; } PARAMETRIZE { ability = ABILITY_KLUTZ; heldItem = choiceItems[j]; } } GIVEN { ASSUME(GetMoveTarget(MOVE_SWORDS_DANCE) == MOVE_TARGET_USER); AI_FLAGS(AI_FLAG_CHECK_BAD_MOVE | AI_FLAG_CHECK_VIABILITY | AI_FLAG_TRY_TO_FAINT); PLAYER(SPECIES_RHYDON) OPPONENT(SPECIES_LOPUNNY) { Moves(MOVE_SWORDS_DANCE, MOVE_TACKLE); Item(heldItem); Ability(ability); } OPPONENT(SPECIES_SWAMPERT) { Moves(MOVE_WATERFALL); } } WHEN { if (ability == ABILITY_KLUTZ) { // Klutz ignores item TURN { EXPECT_MOVE(opponent, MOVE_SWORDS_DANCE); } } else { TURN { EXPECT_MOVE(opponent, MOVE_TACKLE); } } } } AI_SINGLE_BATTLE_TEST("Choiced Pokémon won't use status move if they are the only party member") { u32 j, ability = ABILITY_NONE, isAlive = 0, heldItem = ITEM_NONE; static const u32 choiceItems[] = { ITEM_CHOICE_SPECS, ITEM_CHOICE_BAND, ITEM_CHOICE_SCARF, }; for (j = 0; j < ARRAY_COUNT(choiceItems); j++) { PARAMETRIZE { ability = ABILITY_NONE; heldItem = choiceItems[j]; isAlive = 0; } PARAMETRIZE { ability = ABILITY_KLUTZ; heldItem = choiceItems[j]; isAlive = 0; } PARAMETRIZE { ability = ABILITY_NONE; heldItem = choiceItems[j]; isAlive = 1; } PARAMETRIZE { ability = ABILITY_KLUTZ; heldItem = choiceItems[j]; isAlive = 1; } } GIVEN { ASSUME(GetMoveCategory(MOVE_YAWN) == DAMAGE_CATEGORY_STATUS); ASSUME(GetMoveEffect(MOVE_YAWN) == EFFECT_YAWN); AI_FLAGS(AI_FLAG_CHECK_BAD_MOVE | AI_FLAG_CHECK_VIABILITY | AI_FLAG_TRY_TO_FAINT); PLAYER(SPECIES_RHYDON) OPPONENT(SPECIES_LOPUNNY) { Moves(MOVE_YAWN, MOVE_TACKLE); Item(heldItem); Ability(ability); } OPPONENT(SPECIES_SWAMPERT) { HP(isAlive); Moves(MOVE_WATERFALL); } } WHEN { if (isAlive == 1 || ability == ABILITY_KLUTZ) { TURN { EXPECT_MOVE(opponent, MOVE_YAWN); } } else { TURN { EXPECT_MOVE(opponent, MOVE_TACKLE); } } } } AI_SINGLE_BATTLE_TEST("Choiced Pokémon won't use status move if they don't have a good switchin") { u32 j, ability = ABILITY_NONE, move = MOVE_NONE, species = SPECIES_NONE, heldItem = ITEM_NONE; static const u32 choiceItems[] = { ITEM_CHOICE_SPECS, ITEM_CHOICE_BAND, ITEM_CHOICE_SCARF, }; for (j = 0; j < ARRAY_COUNT(choiceItems); j++) { PARAMETRIZE { ability = ABILITY_NONE; heldItem = choiceItems[j]; species = SPECIES_SWAMPERT; move = MOVE_WATERFALL; } PARAMETRIZE { ability = ABILITY_KLUTZ; heldItem = choiceItems[j]; species = SPECIES_SWAMPERT; move = MOVE_WATERFALL; } PARAMETRIZE { ability = ABILITY_NONE; heldItem = choiceItems[j]; species = SPECIES_ELEKID; move = MOVE_THUNDER_WAVE; } PARAMETRIZE { ability = ABILITY_KLUTZ; heldItem = choiceItems[j]; species = SPECIES_ELEKID; move = MOVE_THUNDER_WAVE; } } GIVEN { ASSUME(GetMoveCategory(MOVE_YAWN) == DAMAGE_CATEGORY_STATUS); ASSUME(GetMoveEffect(MOVE_YAWN) == EFFECT_YAWN); AI_FLAGS(AI_FLAG_CHECK_BAD_MOVE | AI_FLAG_CHECK_VIABILITY | AI_FLAG_TRY_TO_FAINT); PLAYER(SPECIES_RHYDON) OPPONENT(SPECIES_LOPUNNY) { Moves(MOVE_YAWN, MOVE_TACKLE); Item(heldItem); Ability(ability); } OPPONENT(species) { Moves(move); } } WHEN { if (species == SPECIES_SWAMPERT || ability == ABILITY_KLUTZ) { TURN { EXPECT_MOVE(opponent, MOVE_YAWN); } } else { TURN { EXPECT_MOVE(opponent, MOVE_TACKLE); } } } } AI_SINGLE_BATTLE_TEST("Choiced Pokémon won't use status move if they are trapped") { u32 j, aiAbility = ABILITY_NONE, playerAbility = MOVE_NONE, species = SPECIES_NONE, heldItem = ITEM_NONE; static const u32 choiceItems[] = { ITEM_CHOICE_SPECS, ITEM_CHOICE_BAND, ITEM_CHOICE_SCARF, }; for (j = 0; j < ARRAY_COUNT(choiceItems); j++) { PARAMETRIZE { aiAbility = ABILITY_NONE; heldItem = choiceItems[j]; species = SPECIES_RHYDON; playerAbility = ABILITY_LIGHTNING_ROD; } PARAMETRIZE { aiAbility = ABILITY_KLUTZ; heldItem = choiceItems[j]; species = SPECIES_RHYDON; playerAbility = ABILITY_LIGHTNING_ROD; } PARAMETRIZE { aiAbility = ABILITY_NONE; heldItem = choiceItems[j]; species = SPECIES_DUGTRIO; playerAbility = ABILITY_ARENA_TRAP; } PARAMETRIZE { aiAbility = ABILITY_KLUTZ; heldItem = choiceItems[j]; species = SPECIES_DUGTRIO; playerAbility = ABILITY_ARENA_TRAP; } } GIVEN { ASSUME(GetMoveCategory(MOVE_YAWN) == DAMAGE_CATEGORY_STATUS); ASSUME(GetMoveEffect(MOVE_YAWN) == EFFECT_YAWN); AI_FLAGS(AI_FLAG_CHECK_BAD_MOVE | AI_FLAG_CHECK_VIABILITY | AI_FLAG_TRY_TO_FAINT); PLAYER(species) { Ability(playerAbility); } OPPONENT(SPECIES_LOPUNNY) { Moves(MOVE_YAWN, MOVE_TACKLE); Item(heldItem); Ability(aiAbility); } OPPONENT(SPECIES_SWAMPERT) { Moves(MOVE_WATERFALL); } } WHEN { if (playerAbility != ABILITY_ARENA_TRAP || aiAbility == ABILITY_KLUTZ) { TURN { EXPECT_MOVE(opponent, MOVE_YAWN); } } else { TURN { EXPECT_MOVE(opponent, MOVE_TACKLE); } } } }