mirror of
https://github.com/correl/mage.git
synced 2024-11-15 11:09:30 +00:00
Added another test.
This commit is contained in:
parent
59a9a97910
commit
a5967d9b2a
4 changed files with 289 additions and 230 deletions
|
@ -1,119 +1,117 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
|
* Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without modification, are
|
* Redistribution and use in source and binary forms, with or without modification, are
|
||||||
* permitted provided that the following conditions are met:
|
* permitted provided that the following conditions are met:
|
||||||
*
|
*
|
||||||
* 1. Redistributions of source code must retain the above copyright notice, this list of
|
* 1. Redistributions of source code must retain the above copyright notice, this list of
|
||||||
* conditions and the following disclaimer.
|
* conditions and the following disclaimer.
|
||||||
*
|
*
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright notice, this list
|
* 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
|
* of conditions and the following disclaimer in the documentation and/or other materials
|
||||||
* provided with the distribution.
|
* provided with the distribution.
|
||||||
*
|
*
|
||||||
* THIS SOFTWARE IS PROVIDED BY BetaSteward_at_googlemail.com ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
* 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
|
* 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
|
* 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
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 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
|
* 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
|
* 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
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
||||||
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
*
|
*
|
||||||
* The views and conclusions contained in the software and documentation are those of the
|
* 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
|
* authors and should not be interpreted as representing official policies, either expressed
|
||||||
* or implied, of BetaSteward_at_googlemail.com.
|
* or implied, of BetaSteward_at_googlemail.com.
|
||||||
*/
|
*/
|
||||||
package mage.sets.gatecrash;
|
package mage.sets.gatecrash;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
import mage.constants.CardType;
|
import mage.constants.CardType;
|
||||||
import mage.constants.Outcome;
|
import mage.constants.Outcome;
|
||||||
import mage.constants.Rarity;
|
import mage.constants.Rarity;
|
||||||
import mage.MageInt;
|
import mage.MageInt;
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.Ability;
|
||||||
import mage.abilities.effects.OneShotEffect;
|
import mage.abilities.effects.OneShotEffect;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
import mage.game.permanent.Permanent;
|
import mage.game.permanent.Permanent;
|
||||||
import mage.game.permanent.token.Token;
|
import mage.game.permanent.token.Token;
|
||||||
import mage.players.Player;
|
import mage.players.Player;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author LevelX2
|
* @author LevelX2
|
||||||
*/
|
*/
|
||||||
public class MimingSlime extends CardImpl {
|
public class MimingSlime extends CardImpl {
|
||||||
|
|
||||||
public MimingSlime(UUID ownerId) {
|
public MimingSlime(UUID ownerId) {
|
||||||
super(ownerId, 126, "Miming Slime", Rarity.UNCOMMON, new CardType[]{CardType.SORCERY}, "{2}{G}");
|
super(ownerId, 126, "Miming Slime", Rarity.UNCOMMON, new CardType[]{CardType.SORCERY}, "{2}{G}");
|
||||||
this.expansionSetCode = "GTC";
|
this.expansionSetCode = "GTC";
|
||||||
|
|
||||||
this.color.setGreen(true);
|
// Put an X/X green Ooze creature token onto the battlefield, where X is the greatest power among creatures you control.
|
||||||
|
this.getSpellAbility().addEffect(new MimingSlimeEffect());
|
||||||
// Put an X/X green Ooze creature token onto the battlefield, where X is the greatest power among creatures you control.
|
}
|
||||||
this.getSpellAbility().addEffect(new MimingSlimeEffect());
|
|
||||||
}
|
public MimingSlime(final MimingSlime card) {
|
||||||
|
super(card);
|
||||||
public MimingSlime(final MimingSlime card) {
|
}
|
||||||
super(card);
|
|
||||||
}
|
@Override
|
||||||
|
public MimingSlime copy() {
|
||||||
@Override
|
return new MimingSlime(this);
|
||||||
public MimingSlime copy() {
|
}
|
||||||
return new MimingSlime(this);
|
}
|
||||||
}
|
|
||||||
}
|
class MimingSlimeEffect extends OneShotEffect {
|
||||||
|
|
||||||
class MimingSlimeEffect extends OneShotEffect {
|
public MimingSlimeEffect() {
|
||||||
|
super(Outcome.PutCreatureInPlay);
|
||||||
public MimingSlimeEffect() {
|
staticText = "Put an X/X green Ooze creature token onto the battlefield, where X is the greatest power among creatures you control";
|
||||||
super(Outcome.PutCreatureInPlay);
|
}
|
||||||
staticText = "Put an X/X green Ooze creature token onto the battlefield, where X is the greatest power among creatures you control";
|
|
||||||
}
|
public MimingSlimeEffect(final MimingSlimeEffect effect) {
|
||||||
|
super(effect);
|
||||||
public MimingSlimeEffect(final MimingSlimeEffect effect) {
|
}
|
||||||
super(effect);
|
|
||||||
}
|
@Override
|
||||||
|
public MimingSlimeEffect copy() {
|
||||||
@Override
|
return new MimingSlimeEffect(this);
|
||||||
public MimingSlimeEffect copy() {
|
}
|
||||||
return new MimingSlimeEffect(this);
|
|
||||||
}
|
@Override
|
||||||
|
public boolean apply(Game game, Ability source) {
|
||||||
@Override
|
Player player = game.getPlayer(source.getControllerId());
|
||||||
public boolean apply(Game game, Ability source) {
|
if (player != null) {
|
||||||
Player player = game.getPlayer(source.getControllerId());
|
List<Permanent> creatures = game.getBattlefield().getAllActivePermanents(new FilterCreaturePermanent(), player.getId(), game);
|
||||||
if (player != null) {
|
int amount = 0;
|
||||||
List<Permanent> creatures = game.getBattlefield().getAllActivePermanents(new FilterCreaturePermanent(), player.getId(), game);
|
for (Permanent creature : creatures) {
|
||||||
int amount = 0;
|
int power = creature.getPower().getValue();
|
||||||
for (Permanent creature : creatures) {
|
if (amount < power) {
|
||||||
int power = creature.getPower().getValue();
|
amount = power;
|
||||||
if (amount < power) {
|
}
|
||||||
amount = power;
|
}
|
||||||
}
|
OozeToken oozeToken = new OozeToken();
|
||||||
}
|
oozeToken.getPower().initValue(amount);
|
||||||
OozeToken oozeToken = new OozeToken();
|
oozeToken.getToughness().initValue(amount);
|
||||||
oozeToken.getPower().initValue(amount);
|
oozeToken.putOntoBattlefield(1, game, source.getSourceId(), source.getControllerId());
|
||||||
oozeToken.getToughness().initValue(amount);
|
return true;
|
||||||
oozeToken.putOntoBattlefield(1, game, source.getSourceId(), source.getControllerId());
|
}
|
||||||
return true;
|
return false;
|
||||||
}
|
}
|
||||||
return false;
|
}
|
||||||
}
|
|
||||||
}
|
class OozeToken extends Token {
|
||||||
|
public OozeToken() {
|
||||||
class OozeToken extends Token {
|
super("Ooze", "X/X green Ooze creature token");
|
||||||
public OozeToken() {
|
cardType.add(CardType.CREATURE);
|
||||||
super("Ooze", "X/X green Ooze creature token");
|
subtype.add("Ooze");
|
||||||
cardType.add(CardType.CREATURE);
|
color.setGreen(true);
|
||||||
subtype.add("Ooze");
|
power = new MageInt(0);
|
||||||
color.setGreen(true);
|
toughness = new MageInt(0);
|
||||||
power = new MageInt(0);
|
setOriginalExpansionSetCode("RTR");
|
||||||
toughness = new MageInt(0);
|
}
|
||||||
setOriginalExpansionSetCode("RTR");
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,111 +1,109 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
|
* Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without modification, are
|
* Redistribution and use in source and binary forms, with or without modification, are
|
||||||
* permitted provided that the following conditions are met:
|
* permitted provided that the following conditions are met:
|
||||||
*
|
*
|
||||||
* 1. Redistributions of source code must retain the above copyright notice, this list of
|
* 1. Redistributions of source code must retain the above copyright notice, this list of
|
||||||
* conditions and the following disclaimer.
|
* conditions and the following disclaimer.
|
||||||
*
|
*
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright notice, this list
|
* 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
|
* of conditions and the following disclaimer in the documentation and/or other materials
|
||||||
* provided with the distribution.
|
* provided with the distribution.
|
||||||
*
|
*
|
||||||
* THIS SOFTWARE IS PROVIDED BY BetaSteward_at_googlemail.com ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
* 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
|
* 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
|
* 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
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 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
|
* 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
|
* 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
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
||||||
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
*
|
*
|
||||||
* The views and conclusions contained in the software and documentation are those of the
|
* 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
|
* authors and should not be interpreted as representing official policies, either expressed
|
||||||
* or implied, of BetaSteward_at_googlemail.com.
|
* or implied, of BetaSteward_at_googlemail.com.
|
||||||
*/
|
*/
|
||||||
package mage.sets.gatecrash;
|
package mage.sets.gatecrash;
|
||||||
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
import mage.constants.CardType;
|
import mage.constants.CardType;
|
||||||
import mage.constants.Outcome;
|
import mage.constants.Outcome;
|
||||||
import mage.constants.Rarity;
|
import mage.constants.Rarity;
|
||||||
import mage.constants.Zone;
|
import mage.constants.Zone;
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.Ability;
|
||||||
import mage.abilities.common.SimpleActivatedAbility;
|
import mage.abilities.common.SimpleActivatedAbility;
|
||||||
import mage.abilities.costs.Cost;
|
import mage.abilities.costs.Cost;
|
||||||
import mage.abilities.costs.common.RemoveVariableCountersTargetCost;
|
import mage.abilities.costs.common.RemoveVariableCountersTargetCost;
|
||||||
import mage.abilities.costs.mana.ManaCostsImpl;
|
import mage.abilities.costs.mana.ManaCostsImpl;
|
||||||
import mage.abilities.effects.OneShotEffect;
|
import mage.abilities.effects.OneShotEffect;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.counters.CounterType;
|
import mage.counters.CounterType;
|
||||||
import mage.filter.common.FilterControlledCreaturePermanent;
|
import mage.filter.common.FilterControlledCreaturePermanent;
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
import mage.game.permanent.token.Token;
|
import mage.game.permanent.token.Token;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author LevelX2
|
* @author LevelX2
|
||||||
*/
|
*/
|
||||||
public class OozeFlux extends CardImpl {
|
public class OozeFlux extends CardImpl {
|
||||||
|
|
||||||
public OozeFlux(UUID ownerId) {
|
public OozeFlux(UUID ownerId) {
|
||||||
super(ownerId, 128, "Ooze Flux", Rarity.RARE, new CardType[]{CardType.ENCHANTMENT}, "{3}{G}");
|
super(ownerId, 128, "Ooze Flux", Rarity.RARE, new CardType[]{CardType.ENCHANTMENT}, "{3}{G}");
|
||||||
this.expansionSetCode = "GTC";
|
this.expansionSetCode = "GTC";
|
||||||
|
|
||||||
this.color.setGreen(true);
|
// {1}{G}, Remove one or more +1/+1 counters from among creatures you control: Put an X/X green Ooze creature token onto the battlefield, where X is the number of +1/+1 counters removed this way.
|
||||||
|
Ability ability = new SimpleActivatedAbility(Zone.BATTLEFIELD, new OozeFluxCreateTokenEffect(new OozeToken()),new ManaCostsImpl("{1}{G}"));
|
||||||
// {1}{G}, Remove one or more +1/+1 counters from among creatures you control: Put an X/X green Ooze creature token onto the battlefield, where X is the number of +1/+1 counters removed this way.
|
ability.addCost(new RemoveVariableCountersTargetCost(new FilterControlledCreaturePermanent("creatures you control"), CounterType.P1P1, "one or more", 1));
|
||||||
Ability ability = new SimpleActivatedAbility(Zone.BATTLEFIELD, new OozeFluxCreateTokenEffect(new OozeToken()),new ManaCostsImpl("{1}{G}"));
|
this.addAbility(ability);
|
||||||
ability.addCost(new RemoveVariableCountersTargetCost(new FilterControlledCreaturePermanent("creatures you control"), CounterType.P1P1, "one or more", 1));
|
}
|
||||||
this.addAbility(ability);
|
|
||||||
}
|
public OozeFlux(final OozeFlux card) {
|
||||||
|
super(card);
|
||||||
public OozeFlux(final OozeFlux card) {
|
}
|
||||||
super(card);
|
|
||||||
}
|
@Override
|
||||||
|
public OozeFlux copy() {
|
||||||
@Override
|
return new OozeFlux(this);
|
||||||
public OozeFlux copy() {
|
}
|
||||||
return new OozeFlux(this);
|
}
|
||||||
}
|
|
||||||
}
|
class OozeFluxCreateTokenEffect extends OneShotEffect {
|
||||||
|
|
||||||
class OozeFluxCreateTokenEffect extends OneShotEffect {
|
private final Token token;
|
||||||
|
|
||||||
private Token token;
|
public OozeFluxCreateTokenEffect(Token token) {
|
||||||
|
super(Outcome.PutCreatureInPlay);
|
||||||
public OozeFluxCreateTokenEffect(Token token) {
|
this.token = token;
|
||||||
super(Outcome.PutCreatureInPlay);
|
staticText = "Put an X/X green Ooze creature token onto the battlefield, where X is the number of +1/+1 counters removed this way";
|
||||||
this.token = token;
|
}
|
||||||
staticText = "Put an X/X green Ooze creature token onto the battlefield, where X is the number of +1/+1 counters removed this way";
|
|
||||||
}
|
public OozeFluxCreateTokenEffect(final OozeFluxCreateTokenEffect effect) {
|
||||||
|
super(effect);
|
||||||
public OozeFluxCreateTokenEffect(final OozeFluxCreateTokenEffect effect) {
|
this.token = effect.token.copy();
|
||||||
super(effect);
|
}
|
||||||
this.token = effect.token.copy();
|
|
||||||
}
|
@Override
|
||||||
|
public OozeFluxCreateTokenEffect copy() {
|
||||||
@Override
|
return new OozeFluxCreateTokenEffect(this);
|
||||||
public OozeFluxCreateTokenEffect copy() {
|
}
|
||||||
return new OozeFluxCreateTokenEffect(this);
|
|
||||||
}
|
@Override
|
||||||
|
public boolean apply(Game game, Ability source) {
|
||||||
@Override
|
int xValue = 0;
|
||||||
public boolean apply(Game game, Ability source) {
|
for (Cost cost : source.getCosts()) {
|
||||||
int xValue = 0;
|
if (cost instanceof RemoveVariableCountersTargetCost) {
|
||||||
for (Cost cost : source.getCosts()) {
|
xValue = ((RemoveVariableCountersTargetCost) cost).getAmount();
|
||||||
if (cost instanceof RemoveVariableCountersTargetCost) {
|
break;
|
||||||
xValue = ((RemoveVariableCountersTargetCost) cost).getAmount();
|
}
|
||||||
break;
|
}
|
||||||
}
|
Token tokenCopy = token.copy();
|
||||||
}
|
tokenCopy.getAbilities().newId();
|
||||||
Token tokenCopy = token.copy();
|
tokenCopy.getPower().initValue(xValue);
|
||||||
tokenCopy.getAbilities().newId();
|
tokenCopy.getToughness().initValue(xValue);
|
||||||
tokenCopy.getPower().initValue(xValue);
|
tokenCopy.putOntoBattlefield(1, game, source.getSourceId(), source.getControllerId());
|
||||||
tokenCopy.getToughness().initValue(xValue);
|
return true;
|
||||||
tokenCopy.putOntoBattlefield(1, game, source.getSourceId(), source.getControllerId());
|
}
|
||||||
return true;
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -0,0 +1,51 @@
|
||||||
|
/*
|
||||||
|
* To change this license header, choose License Headers in Project Properties.
|
||||||
|
* To change this template file, choose Tools | Templates
|
||||||
|
* and open the template in the editor.
|
||||||
|
*/
|
||||||
|
package org.mage.test.cards.abilities.activated;
|
||||||
|
|
||||||
|
import mage.constants.PhaseStep;
|
||||||
|
import mage.constants.Zone;
|
||||||
|
import mage.game.permanent.Permanent;
|
||||||
|
import org.junit.Assert;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.mage.test.serverside.base.CardTestPlayerBase;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author LevelX2
|
||||||
|
*/
|
||||||
|
|
||||||
|
public class PutOntoBattlefieldTest extends CardTestPlayerBase {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests to put a token onto the battlefield
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testOozeFlux() {
|
||||||
|
// Enchantment
|
||||||
|
// {1}{G}, Remove one or more +1/+1 counters from among creatures you control: Put an X/X green Ooze creature token onto the battlefield, where X is the number of +1/+1 counters removed this way.
|
||||||
|
addCard(Zone.BATTLEFIELD, playerA, "Ooze Flux");
|
||||||
|
// Trample
|
||||||
|
// Kalonian Hydra enters the battlefield with four +1/+1 counters on it.
|
||||||
|
// Whenever Kalonian Hydra attacks, double the number of +1/+1 counters on each creature you control.
|
||||||
|
addCard(Zone.BATTLEFIELD, playerA, "Kalonian Hydra");
|
||||||
|
addCard(Zone.BATTLEFIELD, playerA, "Forest", 2);
|
||||||
|
|
||||||
|
activateAbility(1, PhaseStep.PRECOMBAT_MAIN, playerA, "{1}{G},");
|
||||||
|
setChoice(playerA, "X=2"); // Remove how many
|
||||||
|
setChoice(playerA,"Kalonian Hydra");
|
||||||
|
setChoice(playerA, "X=2"); // Remove from Hydra
|
||||||
|
|
||||||
|
setStopAt(1, PhaseStep.BEGIN_COMBAT);
|
||||||
|
execute();
|
||||||
|
|
||||||
|
assertPowerToughness(playerA, "Kalonian Hydra", 2, 2);
|
||||||
|
assertPermanentCount(playerA, "Ooze", 1);
|
||||||
|
assertPowerToughness(playerA, "Ooze", 2, 2);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -502,6 +502,18 @@ public class TestPlayer extends ComputerPlayer {
|
||||||
return super.announceXCost(min, max, message, game, ability, null);
|
return super.announceXCost(min, max, message, game, ability, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getAmount(int min, int max, String message, Game game) {
|
||||||
|
if (!choices.isEmpty()) {
|
||||||
|
if (choices.get(0).startsWith("X=")) {
|
||||||
|
int xValue = Integer.parseInt(choices.get(0).substring(2));
|
||||||
|
choices.remove(0);
|
||||||
|
return xValue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return super.getAmount(min, max, message, game);
|
||||||
|
}
|
||||||
|
|
||||||
protected Permanent findPermanent(FilterPermanent filter, UUID controllerId, Game game) {
|
protected Permanent findPermanent(FilterPermanent filter, UUID controllerId, Game game) {
|
||||||
List<Permanent> permanents = game.getBattlefield().getAllActivePermanents(filter, controllerId, game);
|
List<Permanent> permanents = game.getBattlefield().getAllActivePermanents(filter, controllerId, game);
|
||||||
if (permanents.size() > 0) {
|
if (permanents.size() > 0) {
|
||||||
|
|
Loading…
Reference in a new issue