Skip to main content
summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/org.eclipse.osee.ats.core.test/src/org/eclipse/osee/ats/core/validator/AtsXNumberValidatorTest.java')
-rw-r--r--plugins/org.eclipse.osee.ats.core.test/src/org/eclipse/osee/ats/core/validator/AtsXNumberValidatorTest.java104
1 files changed, 104 insertions, 0 deletions
diff --git a/plugins/org.eclipse.osee.ats.core.test/src/org/eclipse/osee/ats/core/validator/AtsXNumberValidatorTest.java b/plugins/org.eclipse.osee.ats.core.test/src/org/eclipse/osee/ats/core/validator/AtsXNumberValidatorTest.java
new file mode 100644
index 00000000000..2c7763da719
--- /dev/null
+++ b/plugins/org.eclipse.osee.ats.core.test/src/org/eclipse/osee/ats/core/validator/AtsXNumberValidatorTest.java
@@ -0,0 +1,104 @@
+/*******************************************************************************
+ * Copyright (c) 2011 Boeing.
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * which accompanies this distribution, and is available at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ * Boeing - initial API and implementation
+ *******************************************************************************/
+package org.eclipse.osee.ats.core.validator;
+
+import java.util.Arrays;
+import org.eclipse.osee.ats.api.IAtsServices;
+import org.eclipse.osee.ats.api.IAtsWorkItem;
+import org.eclipse.osee.ats.api.workdef.StateType;
+import org.eclipse.osee.ats.api.workdef.WidgetOption;
+import org.eclipse.osee.ats.api.workdef.WidgetResult;
+import org.eclipse.osee.ats.api.workdef.WidgetStatus;
+import org.eclipse.osee.ats.mocks.MockStateDefinition;
+import org.eclipse.osee.ats.mocks.MockValueProvider;
+import org.eclipse.osee.ats.mocks.MockWidgetDefinition;
+import org.eclipse.osee.framework.jdk.core.type.OseeCoreException;
+import org.junit.Assert;
+import org.mockito.Mock;
+
+/**
+ * @author Donald G. Dunne
+ */
+public class AtsXNumberValidatorTest {
+ private IAtsServices atsServices;
+ // @formatter:off
+ @Mock IAtsWorkItem workItem;
+ // @formatter:on
+
+ @org.junit.Test
+ public void testValidateTransition() throws OseeCoreException {
+ AtsXNumberValidator validator = new AtsXNumberValidator();
+
+ MockWidgetDefinition widgetDef = new MockWidgetDefinition("test");
+ widgetDef.setXWidgetName("xList");
+
+ MockStateDefinition fromStateDef = new MockStateDefinition("from");
+ fromStateDef.setStateType(StateType.Working);
+ MockStateDefinition toStateDef = new MockStateDefinition("to");
+ toStateDef.setStateType(StateType.Working);
+
+ // Valid for anything not XIntegerDam
+ WidgetResult result = validator.validateTransition(workItem, ValidatorTestUtil.emptyValueProvider, widgetDef,
+ fromStateDef, toStateDef, atsServices);
+ ValidatorTestUtil.assertValidResult(result);
+
+ widgetDef.setXWidgetName("XFloatDam");
+
+ result = validator.validateTransition(workItem, ValidatorTestUtil.emptyValueProvider, widgetDef, fromStateDef,
+ toStateDef, atsServices);
+ ValidatorTestUtil.assertValidResult(result);
+
+ widgetDef.getOptions().add(WidgetOption.REQUIRED_FOR_TRANSITION);
+
+ // Not valid if widgetDef required and no values set
+ result = validator.validateTransition(workItem, ValidatorTestUtil.emptyValueProvider, widgetDef, fromStateDef,
+ toStateDef, atsServices);
+ Assert.assertEquals(WidgetStatus.Invalid_Incompleted, result.getStatus());
+ }
+
+ @org.junit.Test
+ public void testValidateTransition_MinMaxConstraint() throws OseeCoreException {
+ AtsXNumberValidator validator = new AtsXNumberValidator();
+
+ MockWidgetDefinition widgetDef = new MockWidgetDefinition("test");
+ widgetDef.setXWidgetName("XFloatDam");
+ widgetDef.setConstraint(0.0, 0.0);
+
+ MockStateDefinition fromStateDef = new MockStateDefinition("from");
+ fromStateDef.setStateType(StateType.Working);
+ MockStateDefinition toStateDef = new MockStateDefinition("to");
+ toStateDef.setStateType(StateType.Working);
+
+ // Valid is nothing entered
+ WidgetResult result = validator.validateTransition(workItem, ValidatorTestUtil.emptyValueProvider, widgetDef,
+ fromStateDef, toStateDef, atsServices);
+ ValidatorTestUtil.assertValidResult(result);
+
+ //Invalid_Range if > than what should be
+ widgetDef.setConstraint(0.0, 2.0);
+ MockValueProvider provider = new MockValueProvider(Arrays.asList("0.0", "2.0", "3.0"));
+ result = validator.validateTransition(workItem, provider, widgetDef, fromStateDef, toStateDef, atsServices);
+ Assert.assertEquals(WidgetStatus.Invalid_Range, result.getStatus());
+
+ //Invalid_Range if less than supposed to
+ widgetDef.setConstraint(1.0, 2.0);
+ provider = new MockValueProvider(Arrays.asList("0.0"));
+ result = validator.validateTransition(workItem, provider, widgetDef, fromStateDef, toStateDef, atsServices);
+ Assert.assertEquals(WidgetStatus.Invalid_Range, result.getStatus());
+
+ //Valid if == what supposed to be
+ widgetDef.setConstraint(2.0, 2.0);
+ provider = new MockValueProvider(Arrays.asList("2.0", "2.0"));
+ result = validator.validateTransition(workItem, provider, widgetDef, fromStateDef, toStateDef, atsServices);
+ ValidatorTestUtil.assertValidResult(result);
+ }
+
+}

Back to the top