pokemon-showdown/test/random-battles/tools.js
2021-04-09 17:13:18 -07:00

101 lines
3.1 KiB
JavaScript

/**
* Tools for testing Random Battles.
*
* @author Annika
*/
'use strict';
const assert = require("../assert");
const Teams = require('./../../.sim-dist/teams').Teams;
/**
* Unit test helper for Pokemon sets
*
* @param {ID} pokemon the ID of the Pokemon whose set is to be tested
* @param {{format?: string, rounds?: number, isDoubles?: boolean, isLead?: boolean, isDynamax?: boolean}} options
* @param {(set: RandomTeamsTypes.RandomSet) => void} test a function called on each set
*/
function testSet(pokemon, options, test) {
const generator = Teams.getGenerator(options.format);
const rounds = options.rounds || 1000;
const isDoubles = options.isDoubles || (options.format && options.format.includes('doubles'));
const isDynamax = options.isDynamax || !(options.format && options.format.includes('nodmax'));
for (let i = 0; i < rounds; i++) {
const set = generator.randomSet(pokemon, {}, options.isLead, isDoubles, isDynamax);
test(set);
}
}
/**
* Tests that a Pokémon always gets STAB moves.
*
* @param {ID} pokemon
* @param {{format?: string, rounds?: number, isDoubles?: boolean, isLead?: boolean, isDynamax?: boolean}} options
*/
function testHasSTAB(pokemon, options) {
const dex = Dex.forFormat(options.format || 'gen8randombattle');
const types = dex.species.get(pokemon).types;
testSet(pokemon, options, set => {
assert(
set.moves.some(move => types.includes(dex.moves.get(move).type)),
`${pokemon} should have at least one STAB move (generated moveset: ${set.moves})`
);
});
}
/**
* Tests that a Pokémon does not get two moves together.
*
* @param {ID} pokemon the ID of the Pokemon whose set is to be tested
* @param {{format?: string, rounds?: number, isDoubles?: boolean, isLead?: boolean, isDynamax?: boolean}} options
* @param {ID} move1
* @param {ID} move2
*/
function testNotBothMoves(pokemon, options, move1, move2) {
testSet(pokemon, options, set => {
assert(
!(set.moves.includes(move1) && set.moves.includes(move2)),
`${pokemon} should not generate both "${move1}" and "${move2}" (generated moveset: ${set.moves})`
);
});
}
/**
* Tests that a Pokémon always gets a move.
*
* @param {ID} pokemon the ID of the Pokemon whose set is to be tested
* @param {{format?: string, rounds?: number, isDoubles?: boolean, isLead?: boolean, isDynamax?: boolean}} options
* @param {ID} move
*/
function testAlwaysHasMove(pokemon, options, move) {
testSet(pokemon, options, set => {
assert(
set.moves.includes(move),
`${pokemon} should always generate "${move}" (generated moveset: ${set.moves})`
);
});
}
/**
* Unit test helper for Pokemon teams
*
* @param {{format?: string, rounds?: number}} options
* @param {(team: RandomTeamsTypes.RandomSet[]) => void} test a function called on each team
*/
function testTeam(options, test) {
const generator = Teams.getGenerator(options.format);
const rounds = options.rounds || 1000;
for (let i = 0; i < rounds; i++) {
const team = generator.randomTeam();
test(team);
}
}
exports.testSet = testSet;
exports.testAlwaysHasMove = testAlwaysHasMove;
exports.testNotBothMoves = testNotBothMoves;
exports.testTeam = testTeam;
exports.testHasSTAB = testHasSTAB;