* Goblin Gaveleer - Added missing Trample ability.

This commit is contained in:
LevelX2 2016-08-08 17:10:28 +02:00
parent c84180b0f7
commit 7f8f4bc034
2 changed files with 80 additions and 37 deletions

View file

@ -28,16 +28,17 @@
package mage.sets.scarsofmirrodin; package mage.sets.scarsofmirrodin;
import java.util.UUID; import java.util.UUID;
import mage.constants.CardType;
import mage.constants.Duration;
import mage.constants.Rarity;
import mage.constants.Zone;
import mage.MageInt; import mage.MageInt;
import mage.abilities.common.SimpleStaticAbility; import mage.abilities.common.SimpleStaticAbility;
import mage.abilities.dynamicvalue.common.EquipmentAttachedCount; import mage.abilities.dynamicvalue.common.EquipmentAttachedCount;
import mage.abilities.dynamicvalue.common.StaticValue; import mage.abilities.dynamicvalue.common.StaticValue;
import mage.abilities.effects.common.continuous.BoostSourceEffect; import mage.abilities.effects.common.continuous.BoostSourceEffect;
import mage.abilities.keyword.TrampleAbility;
import mage.cards.CardImpl; import mage.cards.CardImpl;
import mage.constants.CardType;
import mage.constants.Duration;
import mage.constants.Rarity;
import mage.constants.Zone;
/** /**
* *
@ -54,6 +55,9 @@ public class GoblinGaveleer extends CardImpl {
this.power = new MageInt(1); this.power = new MageInt(1);
this.toughness = new MageInt(1); this.toughness = new MageInt(1);
// Trample
this.addAbility(TrampleAbility.getInstance());
// Goblin Gaveleer gets +2/+0 for each Equipment attached to it.
this.addAbility(new SimpleStaticAbility(Zone.BATTLEFIELD, new BoostSourceEffect(new EquipmentAttachedCount(2), this.addAbility(new SimpleStaticAbility(Zone.BATTLEFIELD, new BoostSourceEffect(new EquipmentAttachedCount(2),
new StaticValue(0), Duration.WhileOnBattlefield))); new StaticValue(0), Duration.WhileOnBattlefield)));
} }

View file

@ -92,9 +92,9 @@ public class TamiyoTest extends CardTestPlayerBase {
addCard(Zone.HAND, playerA, "Tamiyo, Field Researcher", 1); addCard(Zone.HAND, playerA, "Tamiyo, Field Researcher", 1);
addCard(Zone.BATTLEFIELD, playerA, "Forest", 1); addCard(Zone.BATTLEFIELD, playerA, "Forest", 1);
addCard(Zone.BATTLEFIELD, playerA, "Plains", 1); addCard(Zone.BATTLEFIELD, playerA, "Plains", 1);
addCard(Zone.BATTLEFIELD, playerA, "Island", 2); addCard(Zone.BATTLEFIELD, playerA, "Island", 2);
addCard(Zone.BATTLEFIELD, playerA, "Bronze Sable", 1); // 2/1 addCard(Zone.BATTLEFIELD, playerA, "Bronze Sable", 1); // 2/1
castSpell(1, PhaseStep.PRECOMBAT_MAIN, playerA, "Tamiyo, Field Researcher"); castSpell(1, PhaseStep.PRECOMBAT_MAIN, playerA, "Tamiyo, Field Researcher");
activateAbility(1, PhaseStep.PRECOMBAT_MAIN, playerA, "+1: Choose up to two"); activateAbility(1, PhaseStep.PRECOMBAT_MAIN, playerA, "+1: Choose up to two");
@ -121,10 +121,10 @@ public class TamiyoTest extends CardTestPlayerBase {
addCard(Zone.HAND, playerA, "Tamiyo, Field Researcher", 1); addCard(Zone.HAND, playerA, "Tamiyo, Field Researcher", 1);
addCard(Zone.BATTLEFIELD, playerA, "Forest", 1); addCard(Zone.BATTLEFIELD, playerA, "Forest", 1);
addCard(Zone.BATTLEFIELD, playerA, "Plains", 1); addCard(Zone.BATTLEFIELD, playerA, "Plains", 1);
addCard(Zone.BATTLEFIELD, playerA, "Island", 2); addCard(Zone.BATTLEFIELD, playerA, "Island", 2);
addCard(Zone.BATTLEFIELD, playerA, "Bronze Sable", 1); // 2/1 addCard(Zone.BATTLEFIELD, playerA, "Bronze Sable", 1); // 2/1
addCard(Zone.BATTLEFIELD, playerA, "Sylvan Advocate", 1); // 2/3 addCard(Zone.BATTLEFIELD, playerA, "Sylvan Advocate", 1); // 2/3
castSpell(1, PhaseStep.PRECOMBAT_MAIN, playerA, "Tamiyo, Field Researcher"); castSpell(1, PhaseStep.PRECOMBAT_MAIN, playerA, "Tamiyo, Field Researcher");
activateAbility(1, PhaseStep.PRECOMBAT_MAIN, playerA, "+1: Choose up to two"); activateAbility(1, PhaseStep.PRECOMBAT_MAIN, playerA, "+1: Choose up to two");
@ -152,10 +152,10 @@ public class TamiyoTest extends CardTestPlayerBase {
addCard(Zone.HAND, playerA, "Tamiyo, Field Researcher", 1); addCard(Zone.HAND, playerA, "Tamiyo, Field Researcher", 1);
addCard(Zone.BATTLEFIELD, playerA, "Forest", 1); addCard(Zone.BATTLEFIELD, playerA, "Forest", 1);
addCard(Zone.BATTLEFIELD, playerA, "Plains", 1); addCard(Zone.BATTLEFIELD, playerA, "Plains", 1);
addCard(Zone.BATTLEFIELD, playerA, "Island", 2); addCard(Zone.BATTLEFIELD, playerA, "Island", 2);
addCard(Zone.BATTLEFIELD, playerA, "Sylvan Advocate", 1); // 2/3 addCard(Zone.BATTLEFIELD, playerA, "Sylvan Advocate", 1); // 2/3
addCard(Zone.BATTLEFIELD, playerB, "Memnite", 1); addCard(Zone.BATTLEFIELD, playerB, "Memnite", 1);
castSpell(1, PhaseStep.PRECOMBAT_MAIN, playerA, "Tamiyo, Field Researcher"); castSpell(1, PhaseStep.PRECOMBAT_MAIN, playerA, "Tamiyo, Field Researcher");
activateAbility(1, PhaseStep.PRECOMBAT_MAIN, playerA, "+1: Choose up to two"); activateAbility(1, PhaseStep.PRECOMBAT_MAIN, playerA, "+1: Choose up to two");
@ -171,41 +171,41 @@ public class TamiyoTest extends CardTestPlayerBase {
assertLife(playerB, 18); assertLife(playerB, 18);
assertHandCount(playerA, 2); // Sylvan Advocate dealt combat damage twice assertHandCount(playerA, 2); // Sylvan Advocate dealt combat damage twice
} }
/* /*
* Reported bug: Tamiyo's +1 ability remains on the creature for the entirety of the game. * Reported bug: Tamiyo's +1 ability remains on the creature for the entirety of the game.
*/ */
@Test @Test
public void testFieldResearcherFirstEffectOnlyPersistsUntilYourNextTurn() { public void testFieldResearcherFirstEffectOnlyPersistsUntilYourNextTurn() {
/* /*
// Tamiyo, Field Researcher {1}{G}{W}{U} - 4 loyalty // Tamiyo, Field Researcher {1}{G}{W}{U} - 4 loyalty
+1: Choose up to two target creatures. Until your next turn, whenever either of those creatures deals combat damage, you draw a card. +1: Choose up to two target creatures. Until your next turn, whenever either of those creatures deals combat damage, you draw a card.
2: Tap up to two target nonland permanents. They don't untap during their controller's next untap step. 2: Tap up to two target nonland permanents. They don't untap during their controller's next untap step.
7: Draw three cards. You get an emblem with "You may cast nonland cards from your hand without paying their mana costs." 7: Draw three cards. You get an emblem with "You may cast nonland cards from your hand without paying their mana costs."
*/ */
addCard(Zone.HAND, playerA, "Tamiyo, Field Researcher", 1); addCard(Zone.HAND, playerA, "Tamiyo, Field Researcher", 1);
addCard(Zone.BATTLEFIELD, playerA, "Forest", 1); addCard(Zone.BATTLEFIELD, playerA, "Forest", 1);
addCard(Zone.BATTLEFIELD, playerA, "Plains", 1); addCard(Zone.BATTLEFIELD, playerA, "Plains", 1);
addCard(Zone.BATTLEFIELD, playerA, "Island", 2); addCard(Zone.BATTLEFIELD, playerA, "Island", 2);
addCard(Zone.BATTLEFIELD, playerA, "Sylvan Advocate", 1); // 2/3 addCard(Zone.BATTLEFIELD, playerA, "Sylvan Advocate", 1); // 2/3
addCard(Zone.HAND, playerB, "Hero's Downfall", 1); addCard(Zone.HAND, playerB, "Hero's Downfall", 1);
addCard(Zone.BATTLEFIELD, playerB, "Memnite", 1); addCard(Zone.BATTLEFIELD, playerB, "Memnite", 1);
addCard(Zone.BATTLEFIELD, playerB, "Swamp", 3); addCard(Zone.BATTLEFIELD, playerB, "Swamp", 3);
castSpell(1, PhaseStep.PRECOMBAT_MAIN, playerA, "Tamiyo, Field Researcher"); castSpell(1, PhaseStep.PRECOMBAT_MAIN, playerA, "Tamiyo, Field Researcher");
activateAbility(1, PhaseStep.PRECOMBAT_MAIN, playerA, "+1: Choose up to two"); activateAbility(1, PhaseStep.PRECOMBAT_MAIN, playerA, "+1: Choose up to two");
addTarget(playerA, "Sylvan Advocate"); addTarget(playerA, "Sylvan Advocate");
attack(1, playerA, "Sylvan Advocate"); attack(1, playerA, "Sylvan Advocate");
attack(2, playerB, "Memnite"); attack(2, playerB, "Memnite");
block(2, playerA, "Sylvan Advocate", "Memnite"); block(2, playerA, "Sylvan Advocate", "Memnite");
castSpell(3, PhaseStep.UPKEEP, playerB, "Hero's Downfall"); castSpell(3, PhaseStep.UPKEEP, playerB, "Hero's Downfall");
addTarget(playerB, "Tamiyo, Field Researcher"); addTarget(playerB, "Tamiyo, Field Researcher");
attack(3, playerA, "Sylvan Advocate"); // should not get extra card attack(3, playerA, "Sylvan Advocate"); // should not get extra card
setStopAt(3, PhaseStep.END_COMBAT); setStopAt(3, PhaseStep.END_COMBAT);
@ -216,61 +216,100 @@ public class TamiyoTest extends CardTestPlayerBase {
assertLife(playerB, 16); assertLife(playerB, 16);
assertHandCount(playerA, 3); // 2 cards drawn from Advocate + 1 card during T3 draw step. assertHandCount(playerA, 3); // 2 cards drawn from Advocate + 1 card during T3 draw step.
} }
/*
* I activated his +1 ability once. then, the next turn, i activated it one more time, and then
* i get to draw 3 cards of three creatures. So i think the first activation wasn't away.
*/
@Test @Test
public void testFieldResearcherFirstAbilityTargetOpponentCreature() { public void testDrawEffectGetsRemoved() {
/*
/*
// Tamiyo, Field Researcher {1}{G}{W}{U} - 4 loyalty // Tamiyo, Field Researcher {1}{G}{W}{U} - 4 loyalty
+1: Choose up to two target creatures. Until your next turn, whenever either of those creatures deals combat damage, you draw a card. +1: Choose up to two target creatures. Until your next turn, whenever either of those creatures deals combat damage, you draw a card.
2: Tap up to two target nonland permanents. They don't untap during their controller's next untap step. 2: Tap up to two target nonland permanents. They don't untap during their controller's next untap step.
7: Draw three cards. You get an emblem with "You may cast nonland cards from your hand without paying their mana costs." 7: Draw three cards. You get an emblem with "You may cast nonland cards from your hand without paying their mana costs."
*/ */
addCard(Zone.HAND, playerA, "Tamiyo, Field Researcher", 1); addCard(Zone.HAND, playerA, "Tamiyo, Field Researcher", 1);
addCard(Zone.BATTLEFIELD, playerA, "Forest", 1); addCard(Zone.BATTLEFIELD, playerA, "Forest", 1);
addCard(Zone.BATTLEFIELD, playerA, "Plains", 1); addCard(Zone.BATTLEFIELD, playerA, "Plains", 1);
addCard(Zone.BATTLEFIELD, playerA, "Island", 2); addCard(Zone.BATTLEFIELD, playerA, "Island", 2);
addCard(Zone.BATTLEFIELD, playerA, "Sylvan Advocate", 1); // 2/3
addCard(Zone.BATTLEFIELD, playerA, "Silvercoat Lion", 1); // 2/2
addCard(Zone.BATTLEFIELD, playerA, "Pillarfield Ox", 1); // 2/4
castSpell(1, PhaseStep.PRECOMBAT_MAIN, playerA, "Tamiyo, Field Researcher");
activateAbility(1, PhaseStep.PRECOMBAT_MAIN, playerA, "+1: Choose up to two", "Sylvan Advocate");
attack(1, playerA, "Sylvan Advocate");
activateAbility(3, PhaseStep.PRECOMBAT_MAIN, playerA, "+1: Choose up to two", "Pillarfield Ox^Silvercoat Lion");
attack(3, playerA, "Pillarfield Ox");
attack(3, playerA, "Silvercoat Lion");
setStopAt(3, PhaseStep.END_COMBAT);
execute();
assertPermanentCount(playerA, "Tamiyo, Field Researcher", 1);
assertLife(playerB, 14);
assertHandCount(playerA, 4); // 3 cards drawn from attackers + 1 card during T3 draw step.
}
@Test
public void testFieldResearcherFirstAbilityTargetOpponentCreature() {
/*
// Tamiyo, Field Researcher {1}{G}{W}{U} - 4 loyalty
+1: Choose up to two target creatures. Until your next turn, whenever either of those creatures deals combat damage, you draw a card.
2: Tap up to two target nonland permanents. They don't untap during their controller's next untap step.
7: Draw three cards. You get an emblem with "You may cast nonland cards from your hand without paying their mana costs."
*/
addCard(Zone.HAND, playerA, "Tamiyo, Field Researcher", 1);
addCard(Zone.BATTLEFIELD, playerA, "Forest", 1);
addCard(Zone.BATTLEFIELD, playerA, "Plains", 1);
addCard(Zone.BATTLEFIELD, playerA, "Island", 2);
addCard(Zone.BATTLEFIELD, playerB, "Bronze Sable", 1); addCard(Zone.BATTLEFIELD, playerB, "Bronze Sable", 1);
castSpell(1, PhaseStep.PRECOMBAT_MAIN, playerA, "Tamiyo, Field Researcher"); castSpell(1, PhaseStep.PRECOMBAT_MAIN, playerA, "Tamiyo, Field Researcher");
activateAbility(1, PhaseStep.PRECOMBAT_MAIN, playerA, "+1: Choose up to two"); activateAbility(1, PhaseStep.PRECOMBAT_MAIN, playerA, "+1: Choose up to two");
addTarget(playerA, "Bronze Sable"); addTarget(playerA, "Bronze Sable");
attack(2, playerB, "Bronze Sable"); attack(2, playerB, "Bronze Sable");
setStopAt(2, PhaseStep.END_COMBAT); setStopAt(2, PhaseStep.END_COMBAT);
execute(); execute();
assertLife(playerA, 18); assertLife(playerA, 18);
assertHandCount(playerA, 1); assertHandCount(playerA, 1);
} }
@Test @Test
public void testFieldResearcherFirstAbilityTargetOpponentCreatures() { public void testFieldResearcherFirstAbilityTargetOpponentCreatures() {
/* /*
// Tamiyo, Field Researcher {1}{G}{W}{U} - 4 loyalty // Tamiyo, Field Researcher {1}{G}{W}{U} - 4 loyalty
+1: Choose up to two target creatures. Until your next turn, whenever either of those creatures deals combat damage, you draw a card. +1: Choose up to two target creatures. Until your next turn, whenever either of those creatures deals combat damage, you draw a card.
2: Tap up to two target nonland permanents. They don't untap during their controller's next untap step. 2: Tap up to two target nonland permanents. They don't untap during their controller's next untap step.
7: Draw three cards. You get an emblem with "You may cast nonland cards from your hand without paying their mana costs." 7: Draw three cards. You get an emblem with "You may cast nonland cards from your hand without paying their mana costs."
*/ */
addCard(Zone.HAND, playerA, "Tamiyo, Field Researcher", 1); addCard(Zone.HAND, playerA, "Tamiyo, Field Researcher", 1);
addCard(Zone.BATTLEFIELD, playerA, "Forest", 1); addCard(Zone.BATTLEFIELD, playerA, "Forest", 1);
addCard(Zone.BATTLEFIELD, playerA, "Plains", 1); addCard(Zone.BATTLEFIELD, playerA, "Plains", 1);
addCard(Zone.BATTLEFIELD, playerA, "Island", 2); addCard(Zone.BATTLEFIELD, playerA, "Island", 2);
addCard(Zone.BATTLEFIELD, playerB, "Bronze Sable", 1); addCard(Zone.BATTLEFIELD, playerB, "Bronze Sable", 1);
addCard(Zone.BATTLEFIELD, playerB, "Memnite", 1); addCard(Zone.BATTLEFIELD, playerB, "Memnite", 1);
castSpell(1, PhaseStep.PRECOMBAT_MAIN, playerA, "Tamiyo, Field Researcher"); castSpell(1, PhaseStep.PRECOMBAT_MAIN, playerA, "Tamiyo, Field Researcher");
activateAbility(1, PhaseStep.PRECOMBAT_MAIN, playerA, "+1: Choose up to two"); activateAbility(1, PhaseStep.PRECOMBAT_MAIN, playerA, "+1: Choose up to two");
addTarget(playerA, "Bronze Sable^Memnite"); addTarget(playerA, "Bronze Sable^Memnite");
attack(2, playerB, "Bronze Sable"); attack(2, playerB, "Bronze Sable");
attack(2, playerB, "Memnite"); attack(2, playerB, "Memnite");
setStopAt(2, PhaseStep.END_COMBAT); setStopAt(2, PhaseStep.END_COMBAT);
execute(); execute();
assertLife(playerA, 17); assertLife(playerA, 17);
assertHandCount(playerA, 2); assertHandCount(playerA, 2);
} }