forked from External/mage
Test and fix Ravenous Slime not exiling when it dies simultaneously
This commit is contained in:
parent
0254fc0d2a
commit
186d4a5f23
2 changed files with 39 additions and 5 deletions
|
|
@ -68,8 +68,7 @@ class RavenousSlimeEffect extends ReplacementEffectImpl {
|
||||||
@Override
|
@Override
|
||||||
public boolean replaceEvent(GameEvent event, Ability source, Game game) {
|
public boolean replaceEvent(GameEvent event, Ability source, Game game) {
|
||||||
Player controller = game.getPlayer(source.getControllerId());
|
Player controller = game.getPlayer(source.getControllerId());
|
||||||
Permanent sourceCreature = game.getPermanent(source.getSourceId());
|
if (controller == null) {
|
||||||
if (controller == null || sourceCreature == null) {
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (((ZoneChangeEvent) event).getFromZone() != Zone.BATTLEFIELD) {
|
if (((ZoneChangeEvent) event).getFromZone() != Zone.BATTLEFIELD) {
|
||||||
|
|
@ -81,9 +80,8 @@ class RavenousSlimeEffect extends ReplacementEffectImpl {
|
||||||
}
|
}
|
||||||
int power = permanent.getPower().getValue();
|
int power = permanent.getPower().getValue();
|
||||||
controller.moveCards(permanent, Zone.EXILED, source, game);
|
controller.moveCards(permanent, Zone.EXILED, source, game);
|
||||||
return new AddCountersSourceEffect(
|
new AddCountersSourceEffect(CounterType.P1P1.createInstance(power)).apply(game, source);
|
||||||
CounterType.P1P1.createInstance(power)
|
return true;
|
||||||
).apply(game, source);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,36 @@
|
||||||
|
|
||||||
|
package org.mage.test.cards.single.c18;
|
||||||
|
|
||||||
|
import mage.constants.PhaseStep;
|
||||||
|
import mage.constants.Zone;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.mage.test.serverside.base.CardTestPlayerBase;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author notgreat
|
||||||
|
*/
|
||||||
|
public class RavenousSlimeTest extends CardTestPlayerBase {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testRavenousSlime() {
|
||||||
|
addCustomEffect_TargetDestroy(playerA);
|
||||||
|
addCard(Zone.BATTLEFIELD, playerA, "Ravenous Slime");
|
||||||
|
addCard(Zone.BATTLEFIELD, playerB, "Runeclaw Bear");
|
||||||
|
addCard(Zone.BATTLEFIELD, playerB, "Centaur Courser");
|
||||||
|
|
||||||
|
activateAbility(1, PhaseStep.PRECOMBAT_MAIN, playerA, "target destroy", "Runeclaw Bear");
|
||||||
|
checkPT("Ravenous Slime ate Runeclaw Bear", 1, PhaseStep.BEGIN_COMBAT, playerA, "Ravenous Slime", 3, 3);
|
||||||
|
|
||||||
|
attack(1, playerA, "Ravenous Slime");
|
||||||
|
block(1, playerB, "Centaur Courser", "Ravenous Slime");
|
||||||
|
|
||||||
|
setStrictChooseMode(true);
|
||||||
|
setStopAt(1, PhaseStep.POSTCOMBAT_MAIN);
|
||||||
|
execute();
|
||||||
|
|
||||||
|
assertExileCount(playerB, "Runeclaw Bear", 1);
|
||||||
|
assertExileCount(playerB, "Centaur Courser", 1);
|
||||||
|
assertGraveyardCount(playerA, "Ravenous Slime", 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue