mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-06-20 00:51:42 +00:00
* Remove extra ';'s * Remove unnecessary conversions to String * Use StandardCharsets object * Replace infinite while with check for interrupted thread * Remove redundant local vars * Remove redundant throws clause * Remove redundant primitive wrapping * Fix malformed Nested class test * Remove unnecessary unboxing * Remove unnecessary explicit type argument * Replace lambdas with method references * Replace statement lambdas with expression lambdas * Replace null check with method call * Replace number comparison with method call * Fix broken javadoc comments * Replace Arrays.asList with singletonLists * Remove excessive lambda usage * Remove redundant string operation * Remove redundant type casts * Remove unnecessary returns * Remove redundant suppressions * Fix unresolved file reference * static analysis fixes
151 lines
5.6 KiB
Java
151 lines
5.6 KiB
Java
/*----------------------------------------------------------------------------*/
|
|
/* Copyright (c) 2008-2019 FIRST. All Rights Reserved. */
|
|
/* Open Source Software - may be modified and shared by FRC teams. The code */
|
|
/* must be accompanied by the FIRST BSD license file in the root directory of */
|
|
/* the project. */
|
|
/*----------------------------------------------------------------------------*/
|
|
|
|
package edu.wpi.first.wpilibj;
|
|
|
|
import java.util.logging.Logger;
|
|
|
|
import org.junit.After;
|
|
import org.junit.Before;
|
|
import org.junit.Test;
|
|
|
|
import edu.wpi.first.networktables.NetworkTable;
|
|
import edu.wpi.first.networktables.NetworkTableInstance;
|
|
import edu.wpi.first.wpilibj.Relay.Direction;
|
|
import edu.wpi.first.wpilibj.Relay.InvalidValueException;
|
|
import edu.wpi.first.wpilibj.Relay.Value;
|
|
import edu.wpi.first.wpilibj.fixtures.RelayCrossConnectFixture;
|
|
import edu.wpi.first.wpilibj.smartdashboard.SendableBuilderImpl;
|
|
import edu.wpi.first.wpilibj.test.AbstractComsSetup;
|
|
import edu.wpi.first.wpilibj.test.TestBench;
|
|
|
|
import static org.junit.Assert.assertEquals;
|
|
import static org.junit.Assert.assertFalse;
|
|
import static org.junit.Assert.assertTrue;
|
|
|
|
/**
|
|
* Tests the {@link RelayCrossConnectFixture}.
|
|
*/
|
|
public class RelayCrossConnectTest extends AbstractComsSetup {
|
|
private static final Logger logger = Logger.getLogger(RelayCrossConnectTest.class.getName());
|
|
private static final NetworkTable table =
|
|
NetworkTableInstance.getDefault().getTable("_RELAY_CROSS_CONNECT_TEST_");
|
|
private RelayCrossConnectFixture m_relayFixture;
|
|
private SendableBuilderImpl m_builder;
|
|
|
|
|
|
@Before
|
|
public void setUp() {
|
|
m_relayFixture = TestBench.getRelayCrossConnectFixture();
|
|
m_relayFixture.setup();
|
|
m_builder = new SendableBuilderImpl();
|
|
m_builder.setTable(table);
|
|
m_relayFixture.getRelay().initSendable(m_builder);
|
|
}
|
|
|
|
@After
|
|
public void tearDown() {
|
|
m_relayFixture.reset();
|
|
m_relayFixture.teardown();
|
|
}
|
|
|
|
@Test
|
|
public void testBothHigh() {
|
|
m_relayFixture.getRelay().setDirection(Direction.kBoth);
|
|
m_relayFixture.getRelay().set(Value.kOn);
|
|
m_builder.updateTable();
|
|
assertTrue("Input one was not high when relay set both high", m_relayFixture.getInputOne()
|
|
.get());
|
|
assertTrue("Input two was not high when relay set both high", m_relayFixture.getInputTwo()
|
|
.get());
|
|
assertEquals(Value.kOn, m_relayFixture.getRelay().get());
|
|
assertEquals("On", table.getEntry("Value").getString(""));
|
|
}
|
|
|
|
@Test
|
|
public void testFirstHigh() {
|
|
m_relayFixture.getRelay().setDirection(Direction.kBoth);
|
|
m_relayFixture.getRelay().set(Value.kForward);
|
|
m_builder.updateTable();
|
|
assertFalse("Input one was not low when relay set Value.kForward", m_relayFixture.getInputOne()
|
|
.get());
|
|
assertTrue("Input two was not high when relay set Value.kForward", m_relayFixture
|
|
.getInputTwo()
|
|
.get());
|
|
assertEquals(Value.kForward, m_relayFixture.getRelay().get());
|
|
assertEquals("Forward", table.getEntry("Value").getString(""));
|
|
}
|
|
|
|
@Test
|
|
public void testSecondHigh() {
|
|
m_relayFixture.getRelay().setDirection(Direction.kBoth);
|
|
m_relayFixture.getRelay().set(Value.kReverse);
|
|
m_builder.updateTable();
|
|
assertTrue("Input one was not high when relay set Value.kReverse", m_relayFixture.getInputOne()
|
|
.get());
|
|
assertFalse("Input two was not low when relay set Value.kReverse", m_relayFixture
|
|
.getInputTwo()
|
|
.get());
|
|
assertEquals(Value.kReverse, m_relayFixture.getRelay().get());
|
|
assertEquals("Reverse", table.getEntry("Value").getString(""));
|
|
}
|
|
|
|
@Test
|
|
public void testForwardDirection() {
|
|
m_relayFixture.getRelay().setDirection(Direction.kForward);
|
|
m_relayFixture.getRelay().set(Value.kOn);
|
|
m_builder.updateTable();
|
|
assertFalse("Input one was not low when relay set Value.kOn in kForward Direction",
|
|
m_relayFixture.getInputOne().get());
|
|
assertTrue("Input two was not high when relay set Value.kOn in kForward Direction",
|
|
m_relayFixture.getInputTwo().get());
|
|
assertEquals(Value.kOn, m_relayFixture.getRelay().get());
|
|
assertEquals("On", table.getEntry("Value").getString(""));
|
|
}
|
|
|
|
@Test
|
|
public void testReverseDirection() {
|
|
m_relayFixture.getRelay().setDirection(Direction.kReverse);
|
|
m_relayFixture.getRelay().set(Value.kOn);
|
|
m_builder.updateTable();
|
|
assertTrue("Input one was not high when relay set Value.kOn in kReverse Direction",
|
|
m_relayFixture.getInputOne().get());
|
|
assertFalse("Input two was not low when relay set Value.kOn in kReverse Direction",
|
|
m_relayFixture.getInputTwo().get());
|
|
assertEquals(Value.kOn, m_relayFixture.getRelay().get());
|
|
assertEquals("On", table.getEntry("Value").getString(""));
|
|
}
|
|
|
|
@Test(expected = InvalidValueException.class)
|
|
public void testSetValueForwardWithDirectionReverseThrowingException() {
|
|
m_relayFixture.getRelay().setDirection(Direction.kForward);
|
|
m_relayFixture.getRelay().set(Value.kReverse);
|
|
}
|
|
|
|
@Test(expected = InvalidValueException.class)
|
|
public void testSetValueReverseWithDirectionForwardThrowingException() {
|
|
m_relayFixture.getRelay().setDirection(Direction.kReverse);
|
|
m_relayFixture.getRelay().set(Value.kForward);
|
|
}
|
|
|
|
@Test
|
|
public void testInitialSettings() {
|
|
m_builder.updateTable();
|
|
assertEquals(Value.kOff, m_relayFixture.getRelay().get());
|
|
// Initially both outputs should be off
|
|
assertFalse(m_relayFixture.getInputOne().get());
|
|
assertFalse(m_relayFixture.getInputTwo().get());
|
|
assertEquals("Off", table.getEntry("Value").getString(""));
|
|
}
|
|
|
|
@Override
|
|
protected Logger getClassLogger() {
|
|
return logger;
|
|
}
|
|
|
|
}
|