Files
JIMRI/java/test/jmri/jmrit/logixng/implementation/DefaultMaleAnalogExpressionSocketTest.java
T
2026-06-17 14:00:51 +02:00

328 lines
12 KiB
Java

package jmri.jmrit.logixng.implementation;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertNotNull;
import edu.umd.cs.findbugs.annotations.SuppressFBWarnings;
import java.beans.PropertyChangeEvent;
import java.beans.PropertyVetoException;
import java.util.Locale;
import java.util.Map;
import jmri.InstanceManager;
import jmri.JmriException;
import jmri.jmrit.logixng.*;
import jmri.util.JUnitUtil;
import jmri.jmrit.logixng.expressions.AbstractAnalogExpression;
import jmri.jmrit.logixng.expressions.AnalogExpressionMemory;
import jmri.jmrit.logixng.implementation.DefaultMaleAnalogExpressionSocket.AnalogExpressionDebugConfig;
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import static org.assertj.core.api.Assertions.assertThat;
import static org.assertj.core.api.Assertions.catchThrowable;
/**
* Test ExpressionTimer
*
* @author Daniel Bergqvist 2018
*/
public class DefaultMaleAnalogExpressionSocketTest extends MaleSocketTestBase {
@Override
protected String getNewSystemName() {
return InstanceManager.getDefault(AnalogExpressionManager.class)
.getAutoSystemName();
}
@Test
public void testCtor() {
AnalogExpressionBean expression = new AnalogExpressionMemory("IQAE321", null);
MaleSocket maleSocket = ((AnalogExpressionManager)manager).registerExpression(expression);
assertNotNull( maleSocket, "object exists");
}
@Test
public void testEvaluate() throws JmriException {
ConditionalNG conditionalNG = new DefaultConditionalNGScaffold("IQC1", "A conditionalNG"); // NOI18N;
MyAnalogExpression expression = new MyAnalogExpression("IQAE321");
expression.setParent(conditionalNG);
DefaultMaleAnalogExpressionSocket socket = new DefaultMaleAnalogExpressionSocket(manager, expression);
assertNotNull( socket, "exists");
socket.setParent(conditionalNG);
socket.setEnabled(true);
socket.setErrorHandlingType(MaleSocket.ErrorHandlingType.ThrowException);
expression.je = null;
expression.re = null;
expression.result = 94.27;
assertEquals( 94.27, socket.evaluate(), 0);
expression.result = 12.92;
assertEquals( 12.92, socket.evaluate(), 0);
expression.result = 0.0;
assertEquals( 0.0, socket.evaluate(), 0);
expression.je = new JmriException("Test JmriException");
expression.re = null;
Throwable thrown = catchThrowable( () -> socket.evaluate());
assertThat(thrown)
.withFailMessage("Evaluate throws an exception")
.isNotNull()
.isInstanceOf(JmriException.class)
.hasMessage("Test JmriException");
expression.je = null;
expression.re = new RuntimeException("Test RuntimeException");
thrown = catchThrowable( () -> socket.evaluate());
assertThat(thrown)
.withFailMessage("Evaluate throws an exception")
.isNotNull()
.isInstanceOf(RuntimeException.class)
.hasMessage("Test RuntimeException");
// If the socket is not enabled, it shouldn't do anything
socket.setEnabled(false);
expression.re = new RuntimeException("Test RuntimeException");
thrown = catchThrowable( () -> socket.evaluate());
assertThat(thrown)
.withFailMessage("Evaluate does nothing")
.isNull();
// Test debug config
socket.setEnabled(true);
AnalogExpressionDebugConfig config = new AnalogExpressionDebugConfig();
socket.setDebugConfig(config);
expression.je = null;
expression.re = null;
config._forceResult = true;
config._result = 12.34;
expression.result = 93.23;
assertEquals( 12.34, socket.evaluate(), 0);
config._forceResult = false;
assertEquals( 93.23, socket.evaluate(), 0);
}
@Test
public void testEvaluateErrors() {
ConditionalNG conditionalNG = new DefaultConditionalNGScaffold("IQC1", "A conditionalNG"); // NOI18N;
MyAnalogExpression expression = new MyAnalogExpression("IQAE321");
expression.setParent(conditionalNG);
DefaultMaleAnalogExpressionSocket socket = new DefaultMaleAnalogExpressionSocket(manager, expression);
assertNotNull( socket, "exists");
socket.setParent(conditionalNG);
socket.setEnabled(true);
socket.setErrorHandlingType(MaleSocket.ErrorHandlingType.ThrowException);
expression.result = Double.NaN;
Throwable thrown = catchThrowable( () -> socket.evaluate());
assertThat(thrown)
.withFailMessage("Evaluate throws an exception")
.isNotNull()
.isInstanceOf(IllegalArgumentException.class)
.hasMessage("The result is NaN");
expression.result = Double.NEGATIVE_INFINITY;
thrown = catchThrowable( () -> socket.evaluate());
assertThat(thrown)
.withFailMessage("Evaluate throws an exception")
.isNotNull()
.isInstanceOf(IllegalArgumentException.class)
.hasMessage("The result is negative infinity");
expression.result = Double.POSITIVE_INFINITY;
thrown = catchThrowable( () -> socket.evaluate());
assertThat(thrown)
.withFailMessage("Evaluate throws an exception")
.isNotNull()
.isInstanceOf(IllegalArgumentException.class)
.hasMessage("The result is positive infinity");
}
@Test
public void testVetoableChange() {
ConditionalNG conditionalNG = new DefaultConditionalNGScaffold("IQC1", "A conditionalNG"); // NOI18N;
MyAnalogExpression expression = new MyAnalogExpression("IQAE321");
expression.setParent(conditionalNG);
MaleSocket socket = ((AnalogExpressionManager)manager).registerExpression(expression);
assertNotNull( socket, "exists");
PropertyChangeEvent evt = new PropertyChangeEvent("Source", "Prop", null, null);
expression._vetoChange = true;
Throwable thrown = catchThrowable( () -> socket.vetoableChange(evt));
assertThat(thrown)
.withFailMessage("vetoableChange() does throw")
.isNotNull()
.isInstanceOf(PropertyVetoException.class)
.hasMessage("Veto change");
expression._vetoChange = false;
thrown = catchThrowable( () -> socket.vetoableChange(evt));
assertThat(thrown)
.withFailMessage("vetoableChange() does not throw")
.isNull();
}
@Test
public void testCompareSystemNameSuffix() {
MyAnalogExpression expression1 = new MyAnalogExpression("IQAE1");
MaleAnalogExpressionSocket socket1 = ((AnalogExpressionManager)manager).registerExpression(expression1);
MyAnalogExpression expression2 = new MyAnalogExpression("IQAE01");
MaleAnalogExpressionSocket socket2 = ((AnalogExpressionManager)manager).registerExpression(expression2);
assertEquals( -1, socket1.compareSystemNameSuffix("01", "1", socket2),
"compareSystemNameSuffix returns correct value");
assertEquals( 0, socket1.compareSystemNameSuffix("1", "1", socket2),
"compareSystemNameSuffix returns correct value");
assertEquals( 0, socket1.compareSystemNameSuffix("01", "01", socket2),
"compareSystemNameSuffix returns correct value");
assertEquals( +1, socket1.compareSystemNameSuffix("1", "01", socket2),
"compareSystemNameSuffix returns correct value");
}
// The minimal setup for log4J
@BeforeEach
@Override
public void setUp() {
JUnitUtil.setUp();
JUnitUtil.resetInstanceManager();
JUnitUtil.resetProfileManager();
JUnitUtil.initConfigureManager();
JUnitUtil.initInternalSensorManager();
JUnitUtil.initInternalTurnoutManager();
JUnitUtil.initLogixNGManager();
AnalogExpressionBean expressionA = new AnalogExpressionMemory("IQAE999", null);
assertNotNull( expressionA, "exists");
AnalogExpressionBean expressionB = new MyAnalogExpression("IQAE322");
assertNotNull( expressionB, "exists");
manager = InstanceManager.getDefault(AnalogExpressionManager.class);
maleSocketA =
InstanceManager.getDefault(AnalogExpressionManager.class)
.registerExpression(expressionA);
assertNotNull( maleSocketA, "exists");
maleSocketB =
InstanceManager.getDefault(AnalogExpressionManager.class)
.registerExpression(expressionB);
assertNotNull( maleSocketB, "exists");
}
@AfterEach
@Override
public void tearDown() {
jmri.jmrit.logixng.util.LogixNG_Thread.stopAllLogixNGThreads();
JUnitUtil.deregisterBlockManagerShutdownTask();
JUnitUtil.tearDown();
}
/**
* This action is different from AnalogExpressionMemory and is used to test the
* male socket.
*/
private static class MyAnalogExpression extends AbstractAnalogExpression {
JmriException je = null;
RuntimeException re = null;
double result = 0.0;
boolean _vetoChange = false;
MyAnalogExpression(String sysName) {
super(sysName, null);
}
@Override
protected void registerListenersForThisClass() {
// Do nothing
}
@Override
protected void unregisterListenersForThisClass() {
// Do nothing
}
@Override
protected void disposeMe() {
throw new UnsupportedOperationException("Not supported.");
}
@Override
public String getShortDescription(Locale locale) {
return "My short description";
}
@Override
public String getLongDescription(Locale locale) {
return "My long description";
}
@Override
public FemaleSocket getChild(int index) throws IllegalArgumentException, UnsupportedOperationException {
throw new UnsupportedOperationException("Not supported.");
}
@Override
public int getChildCount() {
return 0;
}
@Override
public LogixNG_Category getCategory() {
return LogixNG_Category.COMMON;
}
@Override
public void setup() {
throw new UnsupportedOperationException("Not supported.");
}
@Override
@SuppressFBWarnings( value = "THROWS_METHOD_THROWS_RUNTIMEEXCEPTION",
justification="testing exception types")
public double evaluate() throws JmriException {
if (je != null) {
throw je;
}
if (re != null) {
throw re;
}
return result;
}
@Override
public void vetoableChange(PropertyChangeEvent evt) throws PropertyVetoException {
if (_vetoChange) {
throw new java.beans.PropertyVetoException("Veto change", evt);
}
}
@Override
public Base getDeepCopy(Map<String, String> map, Map<String, String> map1) throws JmriException {
throw new UnsupportedOperationException("Not supported");
}
@Override
public Base deepCopyChildren(Base base, Map<String, String> map, Map<String, String> map1) throws JmriException {
throw new UnsupportedOperationException("Not supported");
}
}
}