package jmri.jmrix.lenz; import java.util.Vector; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** * Test scaffold implementation of XNetInterface. *

* Use an object of this type as a XNetTrafficController in tests. * * @author Bob Jacobsen Copyright (C) 2002, 2006 */ public class XNetInterfaceScaffold extends XNetTrafficController { public XNetInterfaceScaffold(LenzCommandStation pCommandStation) { super(pCommandStation); setSystemConnectionMemo(new XNetSystemConnectionMemo(this)); } // override some XNetTrafficController methods for test purposes @Override public boolean status() { return true; } /** * Record XNet messages sent, provide access for making sure they are OK. */ public Vector outbound = new Vector<>(); // public OK here, so long as this is a test class @Override public void sendXNetMessage(XNetMessage m, XNetListener replyTo) { log.debug("sendXNetMessage [{}]", m); // save a copy outbound.addElement(m); } @Override public synchronized void sendHighPriorityXNetMessage(XNetMessage m, XNetListener replyTo) { log.debug("sendXNetMessage [{}]", m); // save a copy outbound.addElement(m); } // test control member functions /** * Forward a message to the listeners, e.g. test receipt. */ public void sendTestMessage(XNetReply m) { // forward a test message to XNetListeners log.debug("sendTestMessage [{}]", m); notifyReply(m, null); return; } /* * Check number of listeners, used for testing dispose(). */ public int numListeners() { return cmdListeners.size(); } /** * Avoid error message, normal in parent. */ @Override protected void connectionWarn() { } /** * Avoid error message, normal in parent. */ @Override protected void portWarn(Exception e) { } @Override public void receiveLoop() { } /** * This is normal, don't log at ERROR level */ @Override protected void reportReceiveLoopException(Exception e) { log.debug("run: Exception: {} in {} (considered normal in testing)", e.toString(), this.getClass().toString(), e); jmri.jmrix.ConnectionStatus.instance().setConnectionState(controller.getSystemConnectionMemo(), jmri.jmrix.ConnectionStatus.CONNECTION_DOWN); if (controller instanceof jmri.jmrix.AbstractNetworkPortController) { portWarnTCP(e); } } private static final Logger log = LoggerFactory.getLogger(XNetInterfaceScaffold.class); }