2015-03-24 15:01:17 -04:00
|
|
|
/*----------------------------------------------------------------------------*/
|
|
|
|
|
/* Copyright (c) FIRST 2014. 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. */
|
|
|
|
|
/*----------------------------------------------------------------------------*/
|
|
|
|
|
|
|
|
|
|
#include "WPILib.h"
|
|
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
#include "TestBench.h"
|
|
|
|
|
|
|
|
|
|
enum MotorInvertingTestType { TEST_VICTOR, TEST_JAGUAR, TEST_TALON };
|
|
|
|
|
static const double motorSpeed = 0.25;
|
|
|
|
|
static const double delayTime = 0.5;
|
|
|
|
|
std::ostream &operator<<(std::ostream &os, MotorInvertingTestType const &type) {
|
2015-06-25 15:07:55 -04:00
|
|
|
switch (type) {
|
|
|
|
|
case TEST_VICTOR:
|
|
|
|
|
os << "Victor";
|
|
|
|
|
break;
|
|
|
|
|
case TEST_JAGUAR:
|
|
|
|
|
os << "Jaguar";
|
|
|
|
|
break;
|
|
|
|
|
case TEST_TALON:
|
|
|
|
|
os << "Talon";
|
|
|
|
|
break;
|
|
|
|
|
}
|
2015-03-24 15:01:17 -04:00
|
|
|
|
2015-06-25 15:07:55 -04:00
|
|
|
return os;
|
2015-03-24 15:01:17 -04:00
|
|
|
}
|
2015-06-25 15:07:55 -04:00
|
|
|
class MotorInvertingTest
|
|
|
|
|
: public testing::TestWithParam<MotorInvertingTestType> {
|
|
|
|
|
protected:
|
|
|
|
|
SpeedController *m_speedController;
|
|
|
|
|
Encoder *m_encoder;
|
|
|
|
|
virtual void SetUp() {
|
|
|
|
|
switch (GetParam()) {
|
|
|
|
|
case TEST_VICTOR:
|
|
|
|
|
m_speedController = new Victor(TestBench::kVictorChannel);
|
|
|
|
|
m_encoder = new Encoder(TestBench::kVictorEncoderChannelA,
|
|
|
|
|
TestBench::kVictorEncoderChannelB);
|
|
|
|
|
break;
|
2015-03-24 15:01:17 -04:00
|
|
|
|
2015-06-25 15:07:55 -04:00
|
|
|
case TEST_JAGUAR:
|
|
|
|
|
m_speedController = new Jaguar(TestBench::kJaguarChannel);
|
|
|
|
|
m_encoder = new Encoder(TestBench::kJaguarEncoderChannelA,
|
|
|
|
|
TestBench::kJaguarEncoderChannelB);
|
|
|
|
|
break;
|
2015-03-24 15:01:17 -04:00
|
|
|
|
2015-06-25 15:07:55 -04:00
|
|
|
case TEST_TALON:
|
|
|
|
|
m_speedController = new Talon(TestBench::kTalonChannel);
|
|
|
|
|
m_encoder = new Encoder(TestBench::kTalonEncoderChannelA,
|
|
|
|
|
TestBench::kTalonEncoderChannelB);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
virtual void TearDown() {
|
|
|
|
|
delete m_speedController;
|
|
|
|
|
delete m_encoder;
|
|
|
|
|
}
|
2015-03-24 15:01:17 -04:00
|
|
|
|
2015-06-25 15:07:55 -04:00
|
|
|
void Reset() {
|
|
|
|
|
m_speedController->SetInverted(false);
|
|
|
|
|
m_speedController->Set(0.0f);
|
|
|
|
|
m_encoder->Reset();
|
|
|
|
|
}
|
2015-03-24 15:01:17 -04:00
|
|
|
};
|
|
|
|
|
|
2015-06-25 15:07:55 -04:00
|
|
|
TEST_P(MotorInvertingTest, InvertingPositive) {
|
|
|
|
|
Reset();
|
|
|
|
|
m_speedController->Set(motorSpeed);
|
|
|
|
|
Wait(delayTime);
|
|
|
|
|
bool initDirection = m_encoder->GetDirection();
|
|
|
|
|
m_speedController->SetInverted(true);
|
|
|
|
|
m_speedController->Set(motorSpeed);
|
|
|
|
|
Wait(delayTime);
|
|
|
|
|
EXPECT_TRUE(m_encoder->GetDirection() != initDirection)
|
|
|
|
|
<< "Inverting with Positive value does not change direction";
|
|
|
|
|
Reset();
|
2015-03-24 15:01:17 -04:00
|
|
|
}
|
2015-06-25 15:07:55 -04:00
|
|
|
TEST_P(MotorInvertingTest, InvertingNegative) {
|
|
|
|
|
Reset();
|
|
|
|
|
m_speedController->SetInverted(false);
|
|
|
|
|
m_speedController->Set(-motorSpeed);
|
|
|
|
|
Wait(delayTime);
|
|
|
|
|
bool initDirection = m_encoder->GetDirection();
|
|
|
|
|
m_speedController->SetInverted(true);
|
|
|
|
|
m_speedController->Set(-motorSpeed);
|
|
|
|
|
Wait(delayTime);
|
|
|
|
|
EXPECT_TRUE(m_encoder->GetDirection() != initDirection)
|
|
|
|
|
<< "Inverting with Negative value does not change direction";
|
|
|
|
|
Reset();
|
2015-03-24 15:01:17 -04:00
|
|
|
}
|
2015-06-25 15:07:55 -04:00
|
|
|
TEST_P(MotorInvertingTest, InvertingSwitchingPosToNeg) {
|
|
|
|
|
Reset();
|
|
|
|
|
m_speedController->SetInverted(false);
|
|
|
|
|
m_speedController->Set(motorSpeed);
|
|
|
|
|
Wait(delayTime);
|
|
|
|
|
bool initDirection = m_encoder->GetDirection();
|
|
|
|
|
m_speedController->SetInverted(true);
|
|
|
|
|
m_speedController->Set(-motorSpeed);
|
|
|
|
|
Wait(delayTime);
|
|
|
|
|
EXPECT_TRUE(m_encoder->GetDirection() == initDirection)
|
|
|
|
|
<< "Inverting with Switching value does change direction";
|
|
|
|
|
Reset();
|
2015-03-24 15:01:17 -04:00
|
|
|
}
|
2015-06-25 15:07:55 -04:00
|
|
|
TEST_P(MotorInvertingTest, InvertingSwitchingNegToPos) {
|
|
|
|
|
Reset();
|
|
|
|
|
m_speedController->SetInverted(false);
|
|
|
|
|
m_speedController->Set(-motorSpeed);
|
|
|
|
|
Wait(delayTime);
|
|
|
|
|
bool initDirection = m_encoder->GetDirection();
|
|
|
|
|
m_speedController->SetInverted(true);
|
|
|
|
|
m_speedController->Set(motorSpeed);
|
|
|
|
|
Wait(delayTime);
|
|
|
|
|
EXPECT_TRUE(m_encoder->GetDirection() == initDirection)
|
|
|
|
|
<< "Inverting with Switching value does change direction";
|
|
|
|
|
Reset();
|
2015-03-24 15:01:17 -04:00
|
|
|
}
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Test, MotorInvertingTest,
|
2015-06-25 15:07:55 -04:00
|
|
|
testing::Values(TEST_VICTOR, TEST_JAGUAR, TEST_TALON));
|