/*
* Copyright (c) 2010 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 plugin.qualifier.skill;
import java.net.URISyntaxException;
import java.util.Collection;
import pcgen.cdom.base.CDOMObject;
import pcgen.cdom.base.ChooseInformation;
import pcgen.cdom.enumeration.ObjectKey;
import pcgen.cdom.enumeration.SkillCost;
import pcgen.core.PCClass;
import pcgen.core.Skill;
import pcgen.persistence.PersistenceLayerException;
import pcgen.persistence.lst.LstToken;
import pcgen.rules.persistence.CDOMLoader;
import pcgen.rules.persistence.token.CDOMPrimaryToken;
import pcgen.rules.persistence.token.CDOMSecondaryToken;
import pcgen.rules.persistence.token.QualifierToken;
import org.junit.Test;
import plugin.lsttokens.ChooseLst;
import plugin.lsttokens.choose.SkillToken;
import plugin.lsttokens.testsupport.AbstractQualifierTokenTestCase;
import plugin.lsttokens.testsupport.CDOMTokenLoader;
import plugin.lsttokens.testsupport.TokenRegistration;
import plugin.lsttokens.testsupport.TransparentPlayerCharacter;
public class ClassQualifierTokenTest extends
AbstractQualifierTokenTestCase<CDOMObject, Skill>
{
private static final ChooseLst token = new ChooseLst();
private static final SkillToken subtoken = new SkillToken();
private static final CDOMTokenLoader<CDOMObject> loader =
new CDOMTokenLoader<>();
private Skill s1, s2, s3;
private PCClass cl1;
private static final LstToken CLASS_TOKEN = new ClassToken();
public ClassQualifierTokenTest()
{
super("CLASS", null);
}
@Override
public void setUp() throws PersistenceLayerException, URISyntaxException
{
super.setUp();
TokenRegistration.register(CLASS_TOKEN);
}
@Override
public CDOMSecondaryToken<?> getSubToken()
{
return subtoken;
}
@Override
public Class<Skill> getTargetClass()
{
return Skill.class;
}
@Override
public Class<Skill> getCDOMClass()
{
return Skill.class;
}
@Override
public CDOMLoader<CDOMObject> getLoader()
{
return loader;
}
@Override
public CDOMPrimaryToken<CDOMObject> getToken()
{
return token;
}
@Override
protected boolean allowsNotQualifier()
{
return true;
}
@Test
public void testGetSet() throws PersistenceLayerException
{
setUpPC();
initializeObjects();
assertTrue(parse(getSubTokenName() + "|CLASS[ALL]"));
finishLoad();
TransparentPlayerCharacter pc = new TransparentPlayerCharacter();
ChooseInformation<?> info = primaryProf.get(ObjectKey.CHOOSE_INFO);
pc.classMap.put(cl1, 1);
Collection<?> set = info.getSet(pc);
assertTrue(set.isEmpty());
pc.skillSet.put(s1, 2);
pc.skillSet.put(s2, 0);
set = info.getSet(pc);
assertTrue(set.isEmpty());
pc.skillCostMap.put(s2, cl1, SkillCost.CLASS);
pc.skillCostMap.put(s3, cl1, SkillCost.CLASS);
pc.skillCostMap.put(s1, cl1, SkillCost.CROSS_CLASS);
set = info.getSet(pc);
assertFalse(set.isEmpty());
assertEquals(2, set.size());
assertTrue(set.contains(s2));
assertTrue(set.contains(s3));
}
@Test
public void testGetSetFiltered() throws PersistenceLayerException
{
setUpPC();
initializeObjects();
assertTrue(parse(getSubTokenName() + "|CLASS[TYPE=Masterful]"));
finishLoad();
TransparentPlayerCharacter pc = new TransparentPlayerCharacter();
ChooseInformation<?> info = primaryProf.get(ObjectKey.CHOOSE_INFO);
pc.classMap.put(cl1, 1);
Collection<?> set = info.getSet(pc);
assertTrue(set.isEmpty());
pc.skillCostMap.put(s1, cl1, SkillCost.CLASS);
pc.skillCostMap.put(s2, cl1, SkillCost.CLASS);
pc.skillCostMap.put(s3, cl1, SkillCost.CROSS_CLASS);
set = info.getSet(pc);
assertFalse(set.isEmpty());
assertEquals(1, set.size());
assertTrue(set.contains(s2));
}
@Test
public void testGetSetNegated() throws PersistenceLayerException
{
setUpPC();
initializeObjects();
assertTrue(parse(getSubTokenName() + "|!CLASS[TYPE=Masterful]"));
finishLoad();
TransparentPlayerCharacter pc = new TransparentPlayerCharacter();
ChooseInformation<?> info = primaryProf.get(ObjectKey.CHOOSE_INFO);
pc.classMap.put(cl1, 1);
Collection<?> set = info.getSet(pc);
assertEquals(2, set.size());
assertTrue(set.contains(s2));
assertTrue(set.contains(s3));
pc.skillCostMap.put(s1, cl1, SkillCost.CLASS);
pc.skillCostMap.put(s2, cl1, SkillCost.CLASS);
pc.skillCostMap.put(s3, cl1, SkillCost.CROSS_CLASS);
set = info.getSet(pc);
assertFalse(set.isEmpty());
assertEquals(1, set.size());
assertTrue(set.contains(s3));
}
private void initializeObjects()
{
s1 = new Skill();
s1.setName("s1");
primaryContext.getReferenceContext().importObject(s1);
s2 = new Skill();
s2.setName("s2");
primaryContext.getReferenceContext().importObject(s2);
primaryContext.unconditionallyProcess(s2, "TYPE", "Masterful");
s3 = new Skill();
s3.setName("s3");
primaryContext.getReferenceContext().importObject(s3);
primaryContext.unconditionallyProcess(s3, "TYPE", "Masterful");
cl1 = new PCClass();
cl1.setName("MyClass");
primaryContext.getReferenceContext().importObject(cl1);
}
@Override
protected Class<? extends QualifierToken<?>> getQualifierClass()
{
return plugin.qualifier.skill.ClassToken.class;
}
}