pokemon-showdown/test/simulator/misc/statusmoves.js
Kevin Lau dd80e38322 Upgrade tests
- Improve the wording on tests for status moves to be more clear
- Add a test for Stealth Rocks
2015-05-10 15:40:52 -07:00

83 lines
3.4 KiB
JavaScript

var assert = require('assert');
var battle;
describe('Most status moves', function () {
afterEach(function () {
battle.destroy();
});
it('should ignore natural type immunities', function () {
battle = BattleEngine.Battle.construct();
battle.join('p1', 'Guest 1', 1, [{species: "Smeargle", ability: 'prankster', item: 'leftovers', moves: ['gastroacid', 'glare', 'confuseray', 'sandattack']}]);
battle.join('p2', 'Guest 2', 1, [
{species: "Klefki", ability: 'magician', happiness: 0, moves: ['return']},
{species: "Dusknoir", ability: 'frisk', moves: ['shadowpunch']},
{species: "Slaking", ability: 'truant', moves: ['shadowclaw']},
{species: "Tornadus", ability: 'prankster', moves: ['tailwind']},
{species: "Unown", ability: 'levitate', moves: ['hiddenpower']}
]);
battle.commitDecisions();
assert.strictEqual(battle.p2.active[0].item, '');
battle.choose('p1', 'move 2');
battle.choose('p2', 'switch 2');
assert.strictEqual(battle.p2.active[0].status, 'par');
battle.choose('p1', 'move 3');
battle.choose('p2', 'switch 3');
assert.ok(battle.p2.active[0].volatiles['confusion']);
battle.choose('p1', 'move 4');
battle.choose('p2', 'switch 4');
assert.strictEqual(battle.p2.active[0].boosts['accuracy'], -1);
battle.choose('p1', 'move 4');
battle.choose('p2', 'switch 5');
assert.strictEqual(battle.p2.active[0].boosts['accuracy'], -1);
});
it('should fail when the opposing Pokemon is immune to the status effect it sets', function () {
battle = BattleEngine.Battle.construct();
battle.join('p1', 'Guest 1', 1, [{species: "Smeargle", ability: 'noguard', moves: ['thunderwave', 'willowisp', 'poisongas', 'toxic']}]);
battle.join('p2', 'Guest 2', 1, [
{species: "Zapdos", ability: 'pressure', moves: ['charge']},
{species: "Emboar", ability: 'blaze', moves: ['sleeptalk']},
{species: "Muk", ability: 'stench', moves: ['shadowsneak']}
]);
battle.commitDecisions();
assert.strictEqual(battle.p2.active[0].status, '');
assert.ok(battle.log[battle.lastMoveLine + 1].startsWith('|-immune|'));
battle.choose('p1', 'move 2');
battle.choose('p2', 'switch 2');
assert.strictEqual(battle.p2.active[0].status, '');
assert.ok(battle.log[battle.lastMoveLine + 1].startsWith('|-immune|'));
battle.choose('p1', 'move 3');
battle.choose('p2', 'switch 3');
assert.strictEqual(battle.p2.active[0].status, '');
assert.ok(battle.log[battle.lastMoveLine + 1].startsWith('|-immune|'));
battle.choose('p1', 'move 4');
battle.commitDecisions();
assert.strictEqual(battle.p2.active[0].status, '');
assert.ok(battle.log[battle.lastMoveLine + 1].startsWith('|-immune|'));
});
});
describe('Thunder Wave, poison-inflicting status moves', function () {
afterEach(function () {
battle.destroy();
});
it('should not ignore type immunities', function () {
battle = BattleEngine.Battle.construct();
battle.join('p1', 'Guest 1', 1, [{species: "Smeargle", ability: 'noguard', moves: ['thunderwave', 'poisongas', 'toxic']}]);
battle.join('p2', 'Guest 2', 1, [
{species: "Hippowdon", ability: 'sandforce', moves: ['slackoff']},
{species: "Registeel", ability: 'clearbody', moves: ['sleeptalk']}
]);
battle.commitDecisions();
assert.strictEqual(battle.p2.active[0].status, '');
battle.choose('p1', 'move 2');
battle.choose('p2', 'switch 2');
assert.strictEqual(battle.p2.active[0].status, '');
battle.choose('p1', 'move 2');
battle.commitDecisions();
assert.strictEqual(battle.p2.active[0].status, '');
});
});