/* * Copyright 2014 (C) Tom Parker <thpr@users.sourceforge.net> * * This library 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 library 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., * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ package plugin.modifier.number; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertSame; import static org.junit.Assert.fail; import org.junit.Test; import pcgen.base.format.NumberManager; import pcgen.base.formula.base.EvaluationManager; import pcgen.base.formula.base.LegalScope; import pcgen.base.formula.base.ManagerFactory; import pcgen.base.formula.inst.SimpleLegalScope; import pcgen.base.formula.inst.SimpleVariableStore; import pcgen.base.solver.IndividualSetup; import pcgen.base.solver.Modifier; import pcgen.base.solver.SplitFormulaSetup; import pcgen.base.util.FormatManager; import plugin.modifier.testsupport.EvalManagerUtilities; public class SetNumberModifierTest { private LegalScope varScope = new SimpleLegalScope(null, "Global"); FormatManager<Number> numManager = new NumberManager(); @Test public void testInvalidConstruction() { try { SetModifierFactory m = new SetModifierFactory(); m.getModifier(100, null, new ManagerFactory(){}, null, null, null); fail("Expected SetModifier with null set value to fail"); } catch (IllegalArgumentException | NullPointerException e) { //Yep! } } @Test public void testProcessNegative1() { SetModifierFactory modifier = new SetModifierFactory(); assertEquals(-3, modifier.process(-2, -3)); } @Test public void testProcessNegative2() { SetModifierFactory modifier = new SetModifierFactory(); assertEquals(-2, modifier.process(-4, -2)); } @Test public void testProcessPositive1() { SetModifierFactory modifier = new SetModifierFactory(); assertEquals(3, modifier.process(2, 3)); } @Test public void testProcessPositive2() { SetModifierFactory modifier = new SetModifierFactory(); assertEquals(3, modifier.process(4, 3)); } @Test public void testProcessZero1() { SetModifierFactory modifier = new SetModifierFactory(); assertEquals(3, modifier.process(0, 3)); } @Test public void testProcessZero2() { SetModifierFactory modifier = new SetModifierFactory(); assertEquals(0, modifier.process(4, 0)); } @Test public void testProcessZero3() { SetModifierFactory modifier = new SetModifierFactory(); assertEquals(-3, modifier.process(0, -3)); } @Test public void testProcessZero4() { SetModifierFactory modifier = new SetModifierFactory(); assertEquals(0, modifier.process(-4,0)); } @Test public void testProcessMixed1() { SetModifierFactory modifier = new SetModifierFactory(); assertEquals(-7, modifier.process(5,-7)); } @Test public void testProcessMixed2() { SetModifierFactory modifier = new SetModifierFactory(); assertEquals(3, modifier.process(-4,3)); } @Test public void testProcessDoubleNegative1() { SetModifierFactory modifier = new SetModifierFactory(); assertEquals(-3.4, modifier.process(-2.3, -3.4)); } @Test public void testProcessDoubleNegative2() { SetModifierFactory modifier = new SetModifierFactory(); assertEquals(-2.4, modifier.process(-4.3, -2.4)); } @Test public void testProcessDoublePositive1() { SetModifierFactory modifier = new SetModifierFactory(); assertEquals(3.5, modifier.process(2.6, 3.5)); } @Test public void testProcessDoublePositive2() { SetModifierFactory modifier = new SetModifierFactory(); assertEquals(3.1, modifier.process(4.4, 3.1)); } @Test public void testProcessDoubleZero1() { SetModifierFactory modifier = new SetModifierFactory(); assertEquals(3.1, modifier.process(0.0, 3.1)); } @Test public void testProcessDoubleZero2() { SetModifierFactory modifier = new SetModifierFactory(); assertEquals(0.0, modifier.process(4.2, 0.0)); } @Test public void testProcessDoubleZero3() { SetModifierFactory modifier = new SetModifierFactory(); assertEquals(-3.4, modifier.process(0.0, -3.4)); } @Test public void testProcessDoubleZero4() { SetModifierFactory modifier = new SetModifierFactory(); assertEquals(0.0, modifier.process(-4.3,0.0)); } @Test public void testProcessDoubleMixed1() { SetModifierFactory modifier = new SetModifierFactory(); assertEquals(-7.2, modifier.process(5.3,-7.2)); } @Test public void testProcessDoubleMixed2() { SetModifierFactory modifier = new SetModifierFactory(); assertEquals(3.1, modifier.process(-4.2,3.1)); } @Test public void testGetModifier() { SetModifierFactory factory = new SetModifierFactory(); Modifier<Number> modifier = factory.getModifier(35, "6.5", new ManagerFactory(){}, null, varScope, numManager); assertEquals((35L<<32)+factory.getInherentPriority(), modifier.getPriority()); assertSame(Number.class, modifier.getVariableFormat()); assertEquals(6.5, modifier.process(EvalManagerUtilities.getInputEM(4.3))); } @Test public void testGetFormulaModifier() { SplitFormulaSetup setup = new SplitFormulaSetup(); setup.loadBuiltIns(); setup.getLegalScopeLibrary().registerScope(varScope); IndividualSetup iSetup = new IndividualSetup(setup, "Global", new SimpleVariableStore()); SetModifierFactory factory = new SetModifierFactory(); Modifier<Number> modifier = factory.getModifier(35, "6+5", new ManagerFactory(){}, iSetup.getFormulaManager(), varScope, numManager); assertEquals((35L<<32)+factory.getInherentPriority(), modifier.getPriority()); assertSame(Number.class, modifier.getVariableFormat()); EvaluationManager evalManager = EvalManagerUtilities.getInputEM(4.3); assertEquals(11, modifier.process( evalManager.getWith(EvaluationManager.FMANAGER, iSetup.getFormulaManager()))); } }