2016-01-02 03:02:34 -08:00
|
|
|
/*----------------------------------------------------------------------------*/
|
|
|
|
|
/* Copyright (c) FIRST 2016. 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. */
|
|
|
|
|
/*----------------------------------------------------------------------------*/
|
|
|
|
|
|
2014-06-19 14:56:06 -04:00
|
|
|
package edu.wpi.first.wpilibj;
|
|
|
|
|
|
2014-07-29 17:57:29 -04:00
|
|
|
import static org.hamcrest.Matchers.greaterThan;
|
|
|
|
|
import static org.hamcrest.Matchers.is;
|
|
|
|
|
import static org.junit.Assert.assertEquals;
|
|
|
|
|
import static org.junit.Assert.assertThat;
|
2014-06-19 14:56:06 -04:00
|
|
|
|
2014-07-29 17:57:29 -04:00
|
|
|
import java.util.Arrays;
|
|
|
|
|
import java.util.Collection;
|
2014-06-19 14:56:06 -04:00
|
|
|
import java.util.logging.Logger;
|
|
|
|
|
|
|
|
|
|
import org.junit.After;
|
|
|
|
|
import org.junit.AfterClass;
|
|
|
|
|
import org.junit.BeforeClass;
|
|
|
|
|
import org.junit.Test;
|
2014-07-29 17:57:29 -04:00
|
|
|
import org.junit.runner.RunWith;
|
|
|
|
|
import org.junit.runners.Parameterized;
|
|
|
|
|
import org.junit.runners.Parameterized.Parameters;
|
2014-06-19 14:56:06 -04:00
|
|
|
|
2014-06-24 11:50:10 -04:00
|
|
|
import edu.wpi.first.wpilibj.can.CANMessageNotFoundException;
|
2014-07-29 17:57:29 -04:00
|
|
|
import edu.wpi.first.wpilibj.fixtures.MotorEncoderFixture;
|
2014-06-19 14:56:06 -04:00
|
|
|
import edu.wpi.first.wpilibj.test.AbstractComsSetup;
|
|
|
|
|
import edu.wpi.first.wpilibj.test.TestBench;
|
|
|
|
|
|
2014-07-29 17:57:29 -04:00
|
|
|
@RunWith(Parameterized.class)
|
2014-06-19 14:56:06 -04:00
|
|
|
public class PDPTest extends AbstractComsSetup {
|
2015-06-25 15:07:55 -04:00
|
|
|
private static final Logger logger = Logger.getLogger(PCMTest.class.getName());
|
|
|
|
|
|
|
|
|
|
private static PowerDistributionPanel pdp;
|
|
|
|
|
private static MotorEncoderFixture<?> me;
|
|
|
|
|
private final double expectedStoppedCurrentDraw;
|
|
|
|
|
|
|
|
|
|
@BeforeClass
|
|
|
|
|
public static void setUpBeforeClass() throws Exception {
|
|
|
|
|
pdp = new PowerDistributionPanel();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@AfterClass
|
|
|
|
|
public static void tearDownAfterClass() throws Exception {
|
|
|
|
|
pdp.free();
|
|
|
|
|
pdp = null;
|
|
|
|
|
me.teardown();
|
|
|
|
|
me = null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public PDPTest(MotorEncoderFixture<?> mef, Double expectedCurrentDraw) {
|
|
|
|
|
logger.fine("Constructor with: " + mef.getType());
|
|
|
|
|
if (me != null && !me.equals(mef))
|
|
|
|
|
me.teardown();
|
|
|
|
|
me = mef;
|
|
|
|
|
me.setup();
|
|
|
|
|
|
|
|
|
|
this.expectedStoppedCurrentDraw = expectedCurrentDraw;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Parameters(name = "{index}: {0}, Expected Stopped Current Draw: {1}")
|
|
|
|
|
public static Collection<Object[]> generateData() {
|
|
|
|
|
// logger.fine("Loading the MotorList");
|
|
|
|
|
return Arrays.asList(new Object[][] {
|
2016-01-29 14:25:19 -05:00
|
|
|
{TestBench.getInstance().getTalonPair(), new Double(0.0)}});
|
2015-06-25 15:07:55 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@After
|
|
|
|
|
public void tearDown() throws Exception {
|
|
|
|
|
me.reset();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Test if the current changes when the motor is driven using a talon
|
|
|
|
|
*/
|
|
|
|
|
@Test
|
|
|
|
|
public void CheckStoppedCurrentForSpeedController() throws CANMessageNotFoundException {
|
|
|
|
|
Timer.delay(0.25);
|
|
|
|
|
|
|
|
|
|
/* The Current should be 0 */
|
|
|
|
|
assertEquals("The low current was not within the expected range.", expectedStoppedCurrentDraw,
|
|
|
|
|
pdp.getCurrent(me.getPDPChannel()), 0.001);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Test if the current changes when the motor is driven using a talon
|
|
|
|
|
*/
|
|
|
|
|
@Test
|
|
|
|
|
public void CheckRunningCurrentForSpeedController() throws CANMessageNotFoundException {
|
|
|
|
|
|
|
|
|
|
/* Set the motor to full forward */
|
|
|
|
|
me.getMotor().set(1.0);
|
2016-01-29 14:25:19 -05:00
|
|
|
Timer.delay(2);
|
2015-06-25 15:07:55 -04:00
|
|
|
|
|
|
|
|
/* The current should now be greater than the low current */
|
|
|
|
|
assertThat("The driven current is not greater than the resting current.",
|
|
|
|
|
pdp.getCurrent(me.getPDPChannel()), is(greaterThan(expectedStoppedCurrentDraw)));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
protected Logger getClassLogger() {
|
|
|
|
|
return logger;
|
|
|
|
|
}
|
2014-06-19 14:56:06 -04:00
|
|
|
}
|