use of jmri.jmrix.lenz.LenzCommandStation in project JMRI by JMRI.
the class LI100XNetProgrammerTest method testReadRegisterSequence.
public void testReadRegisterSequence() throws JmriException {
// infrastructure objects
XNetInterfaceScaffold t = new XNetInterfaceScaffold(new LenzCommandStation());
jmri.ProgListenerScaffold l = new jmri.ProgListenerScaffold();
LI100XNetProgrammer p = new LI100XNetProgrammer(t) {
@Override
protected synchronized void restartTimer(int delay) {
super.restartTimer(RESTART_TIME);
}
};
// set register mode
p.setMode(DefaultProgrammerManager.REGISTERMODE);
// and do the read
p.readCV(29, l);
// check "prog mode" message sent
Assert.assertEquals("mode message sent", 1, t.outbound.size());
Assert.assertEquals("read message contents", "22 11 05 36", t.outbound.elementAt(0).toString());
// send reply (enter service mode )
XNetReply mr1 = new XNetReply();
mr1.setElement(0, 0x61);
mr1.setElement(1, 0x02);
mr1.setElement(2, 0x63);
t.sendTestMessage(mr1);
Assert.assertEquals("inquire message sent", 2, t.outbound.size());
Assert.assertEquals("inquire message contents", "21 10 31", t.outbound.elementAt(1).toString());
// send a result string
XNetReply mr2 = new XNetReply();
mr2.setElement(0, 0x63);
mr2.setElement(1, 0x10);
mr2.setElement(2, 0x05);
mr2.setElement(3, 0x22);
mr2.setElement(4, 0x54);
t.sendTestMessage(mr2);
// At this point, the LI100 XPressNet programmer
// deviates from the standard XPressNet programmer.
// the LI100 version requests an exit from service
// before sending a result to the registered listeners.
//Assert.assertEquals("mode message sent", 3, t.outbound.size());
Assert.assertEquals("exit service mode message contents", "21 81 A0", t.outbound.elementAt(2).toString());
// send reply stating service mode has exited
XNetReply mr3 = new XNetReply();
mr3.setElement(0, 0x61);
mr3.setElement(1, 0x01);
mr3.setElement(2, 0x60);
t.sendTestMessage(mr3);
jmri.util.JUnitUtil.releaseThread(this);
//failure in this test occurs with the next line.
Assert.assertFalse("Receive Called by Programmer", l.getRcvdInvoked() == 0);
Assert.assertEquals("Register mode received value", 34, l.getRcvdValue());
}
use of jmri.jmrix.lenz.LenzCommandStation in project JMRI by JMRI.
the class LZV100FrameTest method testCtor.
@Test
public void testCtor() {
Assume.assumeFalse(GraphicsEnvironment.isHeadless());
// infrastructure objects
XNetInterfaceScaffold tc = new XNetInterfaceScaffold(new LenzCommandStation());
LZV100Frame f = new LZV100Frame(new XNetSystemConnectionMemo(tc));
Assert.assertNotNull(f);
f.dispose();
}
use of jmri.jmrix.lenz.LenzCommandStation in project JMRI by JMRI.
the class LZ100FrameTest method testCtor.
@Test
public void testCtor() {
Assume.assumeFalse(GraphicsEnvironment.isHeadless());
// infrastructure objects
XNetInterfaceScaffold tc = new XNetInterfaceScaffold(new LenzCommandStation());
LZ100Frame f = new LZ100Frame(new XNetSystemConnectionMemo(tc));
Assert.assertNotNull(f);
f.dispose();
}
use of jmri.jmrix.lenz.LenzCommandStation in project JMRI by JMRI.
the class LZ100InternalFrameTest method testCtor.
@Test
public void testCtor() {
Assume.assumeFalse(GraphicsEnvironment.isHeadless());
// infrastructure objects
XNetInterfaceScaffold tc = new XNetInterfaceScaffold(new LenzCommandStation());
LZ100InternalFrame f = new LZ100InternalFrame(new XNetSystemConnectionMemo(tc));
Assert.assertNotNull(f);
}
use of jmri.jmrix.lenz.LenzCommandStation in project JMRI by JMRI.
the class Z21XNetInitializationManagerTest method testCtor.
@Test
public void testCtor() {
// infrastructure objects
XNetInterfaceScaffold t = new XNetInterfaceScaffold(new LenzCommandStation());
XNetListenerScaffold l = new XNetListenerScaffold();
XNetSystemConnectionMemo memo = new XNetSystemConnectionMemo(t);
Z21XNetInitializationManager m = new Z21XNetInitializationManager(memo) {
@Override
protected int getInitTimeout() {
// shorten, because this will fail & delay test
return 50;
}
};
Assert.assertNotNull("exists", t);
Assert.assertNotNull("exists", l);
Assert.assertNotNull("exists", m);
Assert.assertNotNull("exists", memo);
}
Aggregations