From e330ed6c7b5ae614269c5a48293c436ccfaa4b72 Mon Sep 17 00:00:00 2001 From: Oleg Agafonov Date: Wed, 21 Jul 2021 20:15:47 +0400 Subject: [PATCH] Test framework: improves logs in choices errors; --- Mage.Sets/src/mage/cards/g/GuidingVoice.java | 2 +- .../KaradorGhostChieftainTest.java | 35 ++++++++++--------- .../java/org/mage/test/player/TestPlayer.java | 9 ++++- 3 files changed, 27 insertions(+), 19 deletions(-) diff --git a/Mage.Sets/src/mage/cards/g/GuidingVoice.java b/Mage.Sets/src/mage/cards/g/GuidingVoice.java index 70097043a0..6c0dce88a9 100644 --- a/Mage.Sets/src/mage/cards/g/GuidingVoice.java +++ b/Mage.Sets/src/mage/cards/g/GuidingVoice.java @@ -22,7 +22,7 @@ public final class GuidingVoice extends CardImpl { this.getSpellAbility().addEffect(new AddCountersTargetEffect(CounterType.P1P1.createInstance())); this.getSpellAbility().addTarget(new TargetCreaturePermanent()); - // Learn (You may reveal a Lesson card you own from outside the game and p + // Learn (You may reveal a Lesson card you own from outside the game and put it into your hand, or discard a card to draw a card.) this.getSpellAbility().addEffect(new LearnEffect().concatBy("
")); } diff --git a/Mage.Tests/src/test/java/org/mage/test/cards/cost/modification/KaradorGhostChieftainTest.java b/Mage.Tests/src/test/java/org/mage/test/cards/cost/modification/KaradorGhostChieftainTest.java index a791be9331..0a77d8d8ae 100644 --- a/Mage.Tests/src/test/java/org/mage/test/cards/cost/modification/KaradorGhostChieftainTest.java +++ b/Mage.Tests/src/test/java/org/mage/test/cards/cost/modification/KaradorGhostChieftainTest.java @@ -94,47 +94,48 @@ public class KaradorGhostChieftainTest extends CardTestPlayerBase { } @Test - // @Ignore // It's not possible yet to select which ability to use to allow a asThoughtAs effect public void test_castFromGraveyardWithDifferentApprovers() { - setStrictChooseMode(true); + skipInitShuffling(); addCard(Zone.BATTLEFIELD, playerA, "Plains", 4); addCard(Zone.BATTLEFIELD, playerA, "Forest", 1); addCard(Zone.BATTLEFIELD, playerA, "Swamp", 2); addCard(Zone.BATTLEFIELD, playerA, "Island", 3); - + // // {1}{B}: Target attacking Zombie gains indestructible until end of turn. addCard(Zone.LIBRARY, playerA, "Accursed Horde", 1); // Creature Zombie {3}{B} - skipInitShuffling(); - - addCard(Zone.GRAVEYARD, playerA, "Silvercoat Lion", 5); - + // + addCard(Zone.GRAVEYARD, playerA, "Silvercoat Lion", 5); // Creature {1}{W} + // // Karador, Ghost Chieftain costs {1} less to cast for each creature card in your graveyard. // During each of your turns, you may cast one creature card from your graveyard. addCard(Zone.HAND, playerA, "Karador, Ghost Chieftain");// {5}{B}{G}{W} - + // // When Gisa and Geralf enters the battlefield, put the top four cards of your library into your graveyard. // During each of your turns, you may cast a Zombie creature card from your graveyard. addCard(Zone.HAND, playerA, "Gisa and Geralf"); // CREATURE {2}{U}{B} (4/4) + // prepare spels with same AsThough effects and puts creature to graveyard castSpell(1, PhaseStep.PRECOMBAT_MAIN, playerA, "Karador, Ghost Chieftain"); castSpell(1, PhaseStep.PRECOMBAT_MAIN, playerA, "Gisa and Geralf"); + // you play any creatures due to two approve objects + checkPlayableAbility("before", 3, PhaseStep.PRECOMBAT_MAIN, playerA, "Cast Silvercoat Lion", true); + checkPlayableAbility("before", 3, PhaseStep.PRECOMBAT_MAIN, playerA, "Cast Accursed Horde", true); + + // cast zombie creature and approves by Karagar castSpell(3, PhaseStep.PRECOMBAT_MAIN, playerA, "Accursed Horde"); - setChoice(playerA, "During each of your turns, you may cast a Zombie creature card from your graveyard"); // Choose the permitting object + setChoice(playerA, "Karador, Ghost Chieftain"); // choose the permitting object + waitStackResolved(1, PhaseStep.PRECOMBAT_MAIN); - castSpell(3, PhaseStep.PRECOMBAT_MAIN, playerA, "Silvercoat Lion"); + // you can't cast lion due to approving object (Gisa needs zombie) + checkPlayableAbility("after", 3, PhaseStep.PRECOMBAT_MAIN, playerA, "Cast Silvercoat Lion", false); + checkPlayableAbility("after", 3, PhaseStep.PRECOMBAT_MAIN, playerA, "Cast Accursed Horde", false); + setStrictChooseMode(true); setStopAt(3, PhaseStep.BEGIN_COMBAT); execute(); - assertAllCommandsUsed(); - - assertPermanentCount(playerA, "Karador, Ghost Chieftain", 1); - assertPermanentCount(playerA, "Gisa and Geralf", 1); - - assertPermanentCount(playerA, "Silvercoat Lion", 1); - assertPermanentCount(playerA, "Accursed Horde", 1); } } diff --git a/Mage.Tests/src/test/java/org/mage/test/player/TestPlayer.java b/Mage.Tests/src/test/java/org/mage/test/player/TestPlayer.java index 96e0636487..7d1aeeccbd 100644 --- a/Mage.Tests/src/test/java/org/mage/test/player/TestPlayer.java +++ b/Mage.Tests/src/test/java/org/mage/test/player/TestPlayer.java @@ -1977,7 +1977,14 @@ public class TestPlayer implements Player { //Assert.fail("Wrong choice"); } - this.chooseStrictModeFailed("choice", game, choice.getMessage()); + String choicesInfo; + if (choice.isKeyChoice()) { + choicesInfo = String.join("\n", choice.getKeyChoices().values()); + } else { + choicesInfo = String.join("\n", choice.getChoices()); + } + this.chooseStrictModeFailed("choice", game, + "Message: " + choice.getMessage() + "\nPossible choices:\n" + choicesInfo); return computerPlayer.choose(outcome, choice, game); }