/*
* Copyright (c) 2012 Tom Parker <thpr@users.sourceforge.net>
*
* This program is free software; you can redistribute it and/or modify it under
* the terms of the GNU Lesser General Public License as published by the Free
* Software Foundation; either version 2.1 of the License, or (at your option)
* any later version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
* details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this library; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
*/
package tokencontent;
import pcgen.cdom.base.CDOMObject;
import pcgen.cdom.base.FormulaFactory;
import pcgen.cdom.content.DamageReduction;
import pcgen.cdom.facet.DamageReductionFacet;
import pcgen.cdom.facet.FacetLibrary;
import pcgen.core.Race;
import pcgen.rules.persistence.token.CDOMToken;
import pcgen.rules.persistence.token.ParseResult;
import plugin.lsttokens.DrLst;
import tokencontent.testsupport.AbstractContentTokenTest;
public class GlobalDrTest extends AbstractContentTokenTest
{
private static DrLst token = new DrLst();
private DamageReductionFacet drFacet;
@Override
protected void setUp() throws Exception
{
super.setUp();
drFacet = FacetLibrary.getFacet(DamageReductionFacet.class);
create(Race.class, "Ape");
}
@Override
public void processToken(CDOMObject source)
{
ParseResult result = token.parseToken(context, source, "5/Light");
if (result != ParseResult.SUCCESS)
{
result.printMessages();
fail("Test Setup Failed");
}
finishLoad();
}
@Override
public CDOMToken<?> getToken()
{
return token;
}
@Override
protected boolean containsExpected()
{
DamageReduction dr = drFacet.getSet(id).iterator().next();
boolean bypassMatches = dr.getBypass().equals("Light");
boolean reductionMatches =
dr.getReduction().equals(FormulaFactory.getFormulaFor("5"));
return bypassMatches && reductionMatches;
}
@Override
protected int targetFacetCount()
{
return drFacet.getCount(id);
}
@Override
protected int baseCount()
{
return 0;
}
}