Files
2026-06-17 14:00:51 +02:00

343 lines
15 KiB
Java

package jmri.jmrit.logixng.actions;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertFalse;
import static org.junit.jupiter.api.Assertions.assertNotNull;
import static org.junit.jupiter.api.Assertions.assertSame;
import static org.junit.jupiter.api.Assertions.assertThrows;
import static org.junit.jupiter.api.Assertions.assertTrue;
import java.util.ArrayList;
import jmri.jmrit.logixng.expressions.ExpressionSensor;
import jmri.jmrit.logixng.expressions.ExpressionMemory;
import jmri.jmrit.logixng.expressions.True;
import jmri.InstanceManager;
import jmri.NamedBean;
import jmri.jmrit.logixng.*;
import jmri.jmrit.logixng.implementation.DefaultConditionalNGScaffold;
import jmri.util.JUnitUtil;
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
/**
* Test Logix
*
* @author Daniel Bergqvist 2018
*/
public class LogixTest extends AbstractDigitalActionTestBase {
private LogixNG logixNG;
private ConditionalNG conditionalNG;
private Logix actionLogix;
@Override
public ConditionalNG getConditionalNG() {
return conditionalNG;
}
@Override
public LogixNG getLogixNG() {
return logixNG;
}
@Override
public MaleSocket getConnectableChild() {
DigitalExpressionBean childExpression = new True("IQDE999", null);
MaleSocket maleSocketChild =
InstanceManager.getDefault(DigitalExpressionManager.class).registerExpression(childExpression);
return maleSocketChild;
}
@Override
public String getExpectedPrintedTree() {
return String.format(
"Logix. Execute Actions on change of state only ::: Use default%n" +
" ? E%n" +
" Sensor '' is Active ::: Use default%n" +
" !b A%n" +
" Logix Action. Either ::: Use default%n" +
" ! A%n" +
" Socket not connected%n");
}
@Override
public String getExpectedPrintedTreeFromRoot() {
return String.format(
"LogixNG: A new logix for test%n" +
" ConditionalNG: A conditionalNG%n" +
" ! A%n" +
" Logix. Execute Actions on change of state only ::: Use default%n" +
" ? E%n" +
" Sensor '' is Active ::: Use default%n" +
" !b A%n" +
" Logix Action. Either ::: Use default%n" +
" ! A%n" +
" Socket not connected%n");
}
@Override
public NamedBean createNewBean(String systemName) {
return new Logix(systemName, null);
}
@Override
public boolean addNewSocket() {
return false;
}
@Test
public void testCtor() {
DigitalActionBean t = new Logix("IQDA321", null);
assertNotNull( t, "exists");
t = new Logix("IQDA321", null);
assertNotNull( t, "exists");
}
@Test
public void testCtorAndSetup1() {
Logix expression = new Logix("IQDA321", null);
assertNotNull( expression, "exists");
assertEquals( 2, expression.getChildCount(), "expression has 2 female sockets");
expression.getChild(0).setName("XYZ123");
expression.setExpressionSocketSystemName("IQDE52");
expression.getChild(1).setName("ZH12");
expression.setActionSocketSystemName("IQDB554");
assertEquals( "XYZ123", expression.getChild(0).getName(),
"expression female socket name is XYZ123");
assertEquals(
// "jmri.jmrit.logixng.implementation.DefaultFemaleGenericExpressionSocket$DigitalSocket",
"jmri.jmrit.logixng.implementation.DefaultFemaleDigitalExpressionSocket",
expression.getChild(0).getClass().getName(),
"expression female socket is of correct class");
assertFalse( expression.getChild(0).isConnected(),
"expression female socket is not connected");
assertEquals( "ZH12", expression.getChild(1).getName(),
"expression female socket name is ZH12");
assertEquals(
"jmri.jmrit.logixng.implementation.DefaultFemaleDigitalBooleanActionSocket",
expression.getChild(1).getClass().getName(),
"expression female socket is of correct class");
assertFalse( expression.getChild(1).isConnected(),
"expression female socket is not connected");
// Setup action. This connects the child actions to this action
expression.setup();
jmri.util.JUnitAppender.assertMessage("cannot load digital expression IQDE52");
jmri.util.JUnitAppender.assertMessage("cannot load digital boolean action IQDB554");
assertEquals( "XYZ123", expression.getChild(0).getName(),
"expression female socket name is XYZ123");
assertEquals(
// "jmri.jmrit.logixng.implementation.DefaultFemaleGenericExpressionSocket$DigitalSocket",
"jmri.jmrit.logixng.implementation.DefaultFemaleDigitalExpressionSocket",
expression.getChild(0).getClass().getName(),
"expression female socket is of correct class");
assertFalse( expression.getChild(0).isConnected(),
"expression female socket is not connected");
assertEquals( "ZH12", expression.getChild(1).getName(),
"expression female socket name is ZH12");
assertEquals( "jmri.jmrit.logixng.implementation.DefaultFemaleDigitalBooleanActionSocket",
expression.getChild(1).getClass().getName(),
"expression female socket is of correct class");
assertFalse( expression.getChild(1).isConnected(),
"expression female socket is not connected");
assertEquals( 2, expression.getChildCount(), "expression has 2 female sockets");
}
@Test
public void testCtorAndSetup2() {
Logix expression = new Logix("IQDA321", null);
assertNotNull( expression, "exists");
assertEquals( 2, expression.getChildCount(), "expression has 2 female sockets");
expression.getChild(0).setName("XYZ123");
expression.setExpressionSocketSystemName(null);
expression.getChild(1).setName("ZH12");
expression.setActionSocketSystemName(null);
assertEquals( "XYZ123", expression.getChild(0).getName(),
"expression female socket name is XYZ123");
assertEquals(
// "jmri.jmrit.logixng.implementation.DefaultFemaleGenericExpressionSocket$DigitalSocket",
"jmri.jmrit.logixng.implementation.DefaultFemaleDigitalExpressionSocket",
expression.getChild(0).getClass().getName(),
"expression female socket is of correct class");
assertFalse( expression.getChild(0).isConnected(),
"expression female socket is not connected");
assertEquals( "ZH12", expression.getChild(1).getName(),
"expression female socket name is ZH12");
assertEquals( "jmri.jmrit.logixng.implementation.DefaultFemaleDigitalBooleanActionSocket",
expression.getChild(1).getClass().getName(),
"expression female socket is of correct class");
assertFalse( expression.getChild(1).isConnected(),
"expression female socket is not connected");
// Setup action. This connects the child actions to this action
expression.setup();
assertEquals( "XYZ123", expression.getChild(0).getName(),
"expression female socket name is XYZ123");
assertEquals(
// "jmri.jmrit.logixng.implementation.DefaultFemaleGenericExpressionSocket$DigitalSocket",
"jmri.jmrit.logixng.implementation.DefaultFemaleDigitalExpressionSocket",
expression.getChild(0).getClass().getName(),
"expression female socket is of correct class");
assertFalse( expression.getChild(0).isConnected(),
"expression female socket is not connected");
assertEquals( "ZH12", expression.getChild(1).getName(),
"expression female socket name is ZH12");
assertEquals( "jmri.jmrit.logixng.implementation.DefaultFemaleDigitalBooleanActionSocket",
expression.getChild(1).getClass().getName(),
"expression female socket is of correct class");
assertFalse( expression.getChild(1).isConnected(),
"expression female socket is not connected");
assertEquals( 2, expression.getChildCount(), "expression has 2 female sockets");
}
@Test
public void testCtorAndSetup3() {
DigitalExpressionManager m0 = InstanceManager.getDefault(DigitalExpressionManager.class);
DigitalBooleanActionManager m1 = InstanceManager.getDefault(DigitalBooleanActionManager.class);
m0.registerExpression(new ExpressionMemory("IQDE52", null));
m1.registerAction(new DigitalBooleanLogixAction("IQDB554", null, DigitalBooleanLogixAction.When.Either));
Logix expression = new Logix("IQDA321", null);
assertNotNull( expression, "exists");
assertEquals( 2, expression.getChildCount(), "expression has 2 female sockets");
expression.getChild(0).setName("XYZ123");
expression.setExpressionSocketSystemName("IQDE52");
expression.getChild(1).setName("ZH12");
expression.setActionSocketSystemName("IQDB554");
assertEquals( "XYZ123", expression.getChild(0).getName(),
"expression female socket name is XYZ123");
assertEquals(
// "jmri.jmrit.logixng.implementation.DefaultFemaleGenericExpressionSocket$DigitalSocket",
"jmri.jmrit.logixng.implementation.DefaultFemaleDigitalExpressionSocket",
expression.getChild(0).getClass().getName(),
"expression female socket is of correct class");
assertFalse( expression.getChild(0).isConnected(),
"expression female socket is not connected");
assertEquals( "ZH12", expression.getChild(1).getName(),
"expression female socket name is ZH12");
assertEquals( "jmri.jmrit.logixng.implementation.DefaultFemaleDigitalBooleanActionSocket",
expression.getChild(1).getClass().getName(),
"expression female socket is of correct class");
assertFalse( expression.getChild(1).isConnected(),
"expression female socket is not connected");
// Setup action. This connects the child actions to this action
expression.setup();
assertTrue( expression.getChild(0).isConnected(),
"expression female socket is connected");
// Assert.assertEquals("child is correct bean",
// childSocket0,
// expression.getChild(0).getConnectedSocket());
assertEquals( 2, expression.getChildCount(), "expression has 2 female sockets");
assertTrue( expression.getChild(1).isConnected(), "expression female socket is connected");
// Assert.assertEquals("child is correct bean",
// childSocket1,
// expression.getChild(1).getConnectedSocket());
assertEquals( 2, expression.getChildCount(), "expression has 2 female sockets");
assertEquals( 2, expression.getChildCount(), "expression has 2 female sockets");
// Try run setup() again. That should not cause any problems.
expression.setup();
assertEquals( 2, expression.getChildCount(), "expression has 2 female sockets");
}
@Test
public void testGetChild() {
assertEquals( 2, actionLogix.getChildCount(), "getChildCount() returns 2");
assertNotNull( actionLogix.getChild(0),
"getChild(0) returns a non null value");
assertNotNull( actionLogix.getChild(1),
"getChild(1) returns a non null value");
IllegalArgumentException ex = assertThrows( IllegalArgumentException.class, () ->
actionLogix.getChild(2), "Exception is thrown");
assertEquals( "index has invalid value: 2", ex.getMessage(), "Error message is correct");
}
@Test
public void testToString() {
DigitalActionBean a1 = new Logix("IQDA321", null);
assertEquals( "Logix", a1.getShortDescription(), "strings are equal");
DigitalActionBean a2 = new Logix("IQDA321", null);
assertEquals( "Logix. Execute Actions on change of state only",
a2.getLongDescription(), "strings are equal");
}
@Test
public void testCategory() {
assertSame( LogixNG_Category.OTHER, _base.getCategory(), "Category matches");
}
@BeforeEach
public void setUp() throws SocketAlreadyConnectedException {
JUnitUtil.setUp();
JUnitUtil.resetInstanceManager();
JUnitUtil.resetProfileManager();
JUnitUtil.initConfigureManager();
JUnitUtil.initInternalSensorManager();
JUnitUtil.initInternalTurnoutManager();
JUnitUtil.initLogixNGManager();
_category = LogixNG_Category.COMMON;
_isExternal = false;
logixNG = InstanceManager.getDefault(LogixNG_Manager.class).createLogixNG("A new logix for test"); // NOI18N
conditionalNG = new DefaultConditionalNGScaffold("IQC1", "A conditionalNG"); // NOI18N;
InstanceManager.getDefault(ConditionalNG_Manager.class).register(conditionalNG);
conditionalNG.setEnabled(true);
conditionalNG.setRunDelayed(false);
logixNG.addConditionalNG(conditionalNG);
actionLogix = new Logix("IQDA321", null);
MaleSocket maleSocket =
InstanceManager.getDefault(DigitalActionManager.class).registerAction(actionLogix);
conditionalNG.getChild(0).connect(maleSocket);
ExpressionSensor expressionSensor = new ExpressionSensor("IQDE321", null);
MaleSocket maleSocket2 =
InstanceManager.getDefault(DigitalExpressionManager.class).registerExpression(expressionSensor);
actionLogix.getChild(0).connect(maleSocket2);
DigitalBooleanLogixAction actionOnChange = new DigitalBooleanLogixAction("IQDB4", null, DigitalBooleanLogixAction.When.Either);
maleSocket2 =
InstanceManager.getDefault(DigitalBooleanActionManager.class).registerAction(actionOnChange);
actionLogix.getChild(1).connect(maleSocket2);
_base = actionLogix;
_baseMaleSocket = maleSocket;
assertTrue( logixNG.setParentForAllChildren(new ArrayList<>()));
logixNG.activate();
logixNG.setEnabled(true);
}
@AfterEach
public void tearDown() {
jmri.jmrit.logixng.util.LogixNG_Thread.stopAllLogixNGThreads();
JUnitUtil.deregisterBlockManagerShutdownTask();
JUnitUtil.tearDown();
}
}