mirror of
https://github.com/correl/mage.git
synced 2025-01-12 19:25:44 +00:00
* Gitrog Monster - Fixed that triggered ability was not handled correctly after a control change (fixes #3251).
This commit is contained in:
parent
795218b030
commit
afb7de2fbb
3 changed files with 80 additions and 7 deletions
|
@ -0,0 +1,74 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without modification, are
|
||||||
|
* permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice, this list of
|
||||||
|
* conditions and the following disclaimer.
|
||||||
|
*
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice, this list
|
||||||
|
* of conditions and the following disclaimer in the documentation and/or other materials
|
||||||
|
* provided with the distribution.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY BetaSteward_at_googlemail.com ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
||||||
|
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BetaSteward_at_googlemail.com OR
|
||||||
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
||||||
|
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||||
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
||||||
|
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* The views and conclusions contained in the software and documentation are those of the
|
||||||
|
* authors and should not be interpreted as representing official policies, either expressed
|
||||||
|
* or implied, of BetaSteward_at_googlemail.com.
|
||||||
|
*/
|
||||||
|
package org.mage.test.cards.control;
|
||||||
|
|
||||||
|
import mage.constants.PhaseStep;
|
||||||
|
import mage.constants.Zone;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.mage.test.serverside.base.CardTestPlayerBase;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author LevelX2
|
||||||
|
*/
|
||||||
|
public class VengefulPharaohTest extends CardTestPlayerBase {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void controlledByOtherBeforeGraveyardTriggerTest() {
|
||||||
|
addCard(Zone.BATTLEFIELD, playerA, "Swamp", 3);
|
||||||
|
addCard(Zone.BATTLEFIELD, playerA, "Plains", 2);
|
||||||
|
// Deathtouch (Any amount of damage this deals to a creature is enough to destroy it.)
|
||||||
|
// Whenever combat damage is dealt to you or a planeswalker you control, if Vengeful Pharaoh is in your graveyard, destroy target attacking creature, then put Vengeful Pharaoh on top of your library.
|
||||||
|
addCard(Zone.HAND, playerA, "Vengeful Pharaoh", 1); // Creature 5/4 {2}{B}{B}{B}
|
||||||
|
// Destroy target permanent.
|
||||||
|
addCard(Zone.HAND, playerA, "Vindicate", 1); // Sorcery {1}{W}{B}
|
||||||
|
|
||||||
|
addCard(Zone.HAND, playerB, "Control Magic", 1); // Enchantment
|
||||||
|
addCard(Zone.BATTLEFIELD, playerB, "Island", 4);
|
||||||
|
addCard(Zone.BATTLEFIELD, playerB, "Silvercoat Lion", 1);
|
||||||
|
|
||||||
|
castSpell(1, PhaseStep.PRECOMBAT_MAIN, playerA, "Vengeful Pharaoh");
|
||||||
|
|
||||||
|
castSpell(2, PhaseStep.PRECOMBAT_MAIN, playerB, "Control Magic", "Vengeful Pharaoh");
|
||||||
|
|
||||||
|
castSpell(3, PhaseStep.PRECOMBAT_MAIN, playerA, "Vindicate", "Vengeful Pharaoh");
|
||||||
|
|
||||||
|
attack(4, playerB, "Silvercoat Lion");
|
||||||
|
|
||||||
|
setStopAt(4, PhaseStep.POSTCOMBAT_MAIN);
|
||||||
|
execute();
|
||||||
|
|
||||||
|
assertGraveyardCount(playerA, "Vindicate", 1);
|
||||||
|
assertGraveyardCount(playerB, "Control Magic", 1);
|
||||||
|
assertGraveyardCount(playerB, "Silvercoat Lion", 1);
|
||||||
|
assertGraveyardCount(playerA, "Vengeful Pharaoh", 0);
|
||||||
|
assertLibraryCount(playerA, "Vengeful Pharaoh", 1);
|
||||||
|
|
||||||
|
assertLife(playerA, 18);
|
||||||
|
}
|
||||||
|
}
|
|
@ -97,8 +97,8 @@ public class TheGitrogMonsterTest extends CardTestPlayerBase {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* NOTE: As of 05/05/2017 this test is failing due to a bug in code.
|
* NOTE: As of 05/05/2017 this test is failing due to a bug in code. See
|
||||||
* See issue #3251
|
* issue #3251
|
||||||
*
|
*
|
||||||
* I took control of a Gitrog Monster, while the Gitrog Monster's owner
|
* I took control of a Gitrog Monster, while the Gitrog Monster's owner
|
||||||
* controlled a Dryad Arbor and cast Toxic Deluge for 6.
|
* controlled a Dryad Arbor and cast Toxic Deluge for 6.
|
||||||
|
@ -110,6 +110,8 @@ public class TheGitrogMonsterTest extends CardTestPlayerBase {
|
||||||
// You may play an additional land on each of your turns.
|
// You may play an additional land on each of your turns.
|
||||||
// Whenever one or more land cards are put into your graveyard from anywhere, draw a card.
|
// Whenever one or more land cards are put into your graveyard from anywhere, draw a card.
|
||||||
addCard(Zone.HAND, playerA, "The Gitrog Monster", 1); // Creature 6/6 {3}{B}{G}
|
addCard(Zone.HAND, playerA, "The Gitrog Monster", 1); // Creature 6/6 {3}{B}{G}
|
||||||
|
// As an additional cost to cast Toxic Deluge, pay X life.
|
||||||
|
// All creatures get -X/-X until end of turn.
|
||||||
addCard(Zone.HAND, playerA, "Toxic Deluge", 1); // Sorcery {2}{B}
|
addCard(Zone.HAND, playerA, "Toxic Deluge", 1); // Sorcery {2}{B}
|
||||||
// (Dryad Arbor isn't a spell, it's affected by summoning sickness, and it has "{T}: Add {G} to your mana pool.")
|
// (Dryad Arbor isn't a spell, it's affected by summoning sickness, and it has "{T}: Add {G} to your mana pool.")
|
||||||
addCard(Zone.HAND, playerA, "Dryad Arbor", 1); // Land Creature 1/1
|
addCard(Zone.HAND, playerA, "Dryad Arbor", 1); // Land Creature 1/1
|
||||||
|
@ -147,8 +149,8 @@ public class TheGitrogMonsterTest extends CardTestPlayerBase {
|
||||||
assertGraveyardCount(playerA, "The Gitrog Monster", 1);
|
assertGraveyardCount(playerA, "The Gitrog Monster", 1);
|
||||||
assertGraveyardCount(playerA, "Dryad Arbor", 1);
|
assertGraveyardCount(playerA, "Dryad Arbor", 1);
|
||||||
|
|
||||||
assertHandCount(playerB, 1); // 1 drawn in draw of turn 2
|
assertHandCount(playerB, 1); // 1 drawn in draw step of turn 2
|
||||||
assertHandCount(playerA, 1); // 1 drawn in draw of turn 3 - no card sfro Gitrog
|
assertHandCount(playerA, 1); // 1 drawn in draw step of turn 3 - no card from Gitrog
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,7 +37,6 @@ import java.util.Map;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
import mage.MageObject;
|
import mage.MageObject;
|
||||||
import mage.cards.Card;
|
|
||||||
import mage.constants.Zone;
|
import mage.constants.Zone;
|
||||||
import mage.designations.Designation;
|
import mage.designations.Designation;
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
|
@ -119,8 +118,6 @@ public class TriggeredAbilities extends ConcurrentHashMap<String, TriggeredAbili
|
||||||
} else if (object instanceof Spell) {
|
} else if (object instanceof Spell) {
|
||||||
// needed so that cast triggered abilities have to correct controller (e.g. Ulamog, the Infinite Gyre).
|
// needed so that cast triggered abilities have to correct controller (e.g. Ulamog, the Infinite Gyre).
|
||||||
ability.setControllerId(((Spell) object).getControllerId());
|
ability.setControllerId(((Spell) object).getControllerId());
|
||||||
} else if (object instanceof Card) {
|
|
||||||
ability.setControllerId(((Card) object).getOwnerId());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue