package jmri.jmrit.operations.automation.actions; import org.junit.Assert; import org.junit.jupiter.api.*; import jmri.InstanceManager; import jmri.jmrit.operations.OperationsTestCase; import jmri.jmrit.operations.automation.AutomationItem; import jmri.jmrit.operations.trains.Train; import jmri.jmrit.operations.trains.TrainManager; import jmri.util.JUnitOperationsUtil; /** * * @author Paul Bender Copyright (C) 2017 */ public class ResetTrainActionTest extends OperationsTestCase { @Test public void testCTor() { ResetTrainAction t = new ResetTrainAction(); Assert.assertNotNull("exists",t); } @Test public void testActionNoAutomationItem() { ResetTrainAction action = new ResetTrainAction(); Assert.assertNotNull("exists",action); // does nothing, no automationItem action.doAction(); } @Test public void testGetActionName() { ResetTrainAction action = new ResetTrainAction(); Assert.assertEquals("name", Bundle.getMessage("ResetTrain"), action.getName()); } @Test public void testAction() { JUnitOperationsUtil.initOperationsData(); TrainManager tmanager = InstanceManager.getDefault(TrainManager.class); Train train1 = tmanager.getTrainById("1"); Assert.assertNotNull(train1); train1.build(); ResetTrainAction action = new ResetTrainAction(); Assert.assertNotNull("exists",action); AutomationItem automationItem = new AutomationItem("TestId"); automationItem.setAction(action); Assert.assertEquals("confirm registered", automationItem, action.getAutomationItem()); // does nothing, no train assignment action.doAction(); Assert.assertTrue(train1.isBuilt()); Assert.assertFalse(automationItem.isActionSuccessful()); automationItem.setTrain(train1); action.doAction(); Assert.assertFalse(train1.isBuilt()); Assert.assertTrue(automationItem.isActionSuccessful()); //try again action.doAction(); Assert.assertTrue(automationItem.isActionSuccessful()); // can't reset a train en-route train1.build(); train1.move(); action.doAction(); Assert.assertTrue(train1.isBuilt()); Assert.assertTrue(train1.isTrainEnRoute()); Assert.assertFalse(automationItem.isActionSuccessful()); JUnitOperationsUtil.checkOperationsShutDownTask(); } // private static final Logger log = LoggerFactory.getLogger(ResetTrainActionTest.class); }