2014-06-12 16:29:47 -04:00
|
|
|
/*----------------------------------------------------------------------------*/
|
2016-01-02 03:02:34 -08:00
|
|
|
/* Copyright (c) FIRST 2014-2016. All Rights Reserved. */
|
2014-06-12 16:29:47 -04:00
|
|
|
/* 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. */
|
|
|
|
|
/*----------------------------------------------------------------------------*/
|
|
|
|
|
|
Replaced WPILib.h includes in integration tests with the minimum required subheaders to improve compilation times
I ran the benchmark in a tmpfs with an Intel Core i5-2430M. I ran it three times for each combination of build invokation and source tree.
First, I tested "make". For master (eb7d55f), I measured an average of 42.751s with a standard deviation of 0.372s. For this commit, I measured an average of 33.394s with a standard deviation of 0.140s. There was a 9.356s, or 22%, improvement with a total error of 1.3%.
Second, I tested "make -j4". For master (eb7d55f), I measured an average of 21.723s with a standard deviation of 0.158s. For this commit, I measured an average of 16.823s with a standard deviation of 0.340s. There was a 4.900s, or 23%, improvement with a total error of 2.7%.
Change-Id: Idb3adce62ed8ef449360c6583896b6da3565cf58
2015-07-22 02:34:12 -07:00
|
|
|
#include <Counter.h>
|
|
|
|
|
#include <Jaguar.h>
|
|
|
|
|
#include <Talon.h>
|
|
|
|
|
#include <Timer.h>
|
|
|
|
|
#include <Victor.h>
|
2014-06-12 16:29:47 -04:00
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
#include "TestBench.h"
|
|
|
|
|
|
2014-07-01 14:06:26 -04:00
|
|
|
static const double kMotorDelay = 2.5;
|
2014-06-12 16:29:47 -04:00
|
|
|
|
2014-07-01 14:06:26 -04:00
|
|
|
static const double kMaxPeriod = 2.0;
|
2014-06-12 16:29:47 -04:00
|
|
|
|
2014-07-01 14:06:26 -04:00
|
|
|
class CounterTest : public testing::Test {
|
2015-06-25 15:07:55 -04:00
|
|
|
protected:
|
2014-07-01 14:06:26 -04:00
|
|
|
Counter *m_talonCounter;
|
|
|
|
|
Counter *m_victorCounter;
|
|
|
|
|
Counter *m_jaguarCounter;
|
|
|
|
|
Talon *m_talon;
|
|
|
|
|
Victor *m_victor;
|
|
|
|
|
Jaguar *m_jaguar;
|
|
|
|
|
|
2015-06-19 17:23:54 -07:00
|
|
|
virtual void SetUp() override {
|
2014-07-01 14:06:26 -04:00
|
|
|
m_talonCounter = new Counter(TestBench::kTalonEncoderChannelA);
|
|
|
|
|
m_victorCounter = new Counter(TestBench::kVictorEncoderChannelA);
|
|
|
|
|
m_jaguarCounter = new Counter(TestBench::kJaguarEncoderChannelA);
|
|
|
|
|
m_victor = new Victor(TestBench::kVictorChannel);
|
|
|
|
|
m_talon = new Talon(TestBench::kTalonChannel);
|
|
|
|
|
m_jaguar = new Jaguar(TestBench::kJaguarChannel);
|
|
|
|
|
}
|
|
|
|
|
|
2015-06-19 17:23:54 -07:00
|
|
|
virtual void TearDown() override {
|
2014-07-01 14:06:26 -04:00
|
|
|
delete m_talonCounter;
|
|
|
|
|
delete m_victorCounter;
|
|
|
|
|
delete m_jaguarCounter;
|
|
|
|
|
delete m_victor;
|
|
|
|
|
delete m_talon;
|
|
|
|
|
delete m_jaguar;
|
2015-06-25 15:07:55 -04:00
|
|
|
}
|
2014-07-01 14:06:26 -04:00
|
|
|
|
2015-06-25 15:07:55 -04:00
|
|
|
void Reset() {
|
|
|
|
|
m_talonCounter->Reset();
|
|
|
|
|
m_victorCounter->Reset();
|
|
|
|
|
m_jaguarCounter->Reset();
|
|
|
|
|
m_talon->Set(0.0f);
|
|
|
|
|
m_victor->Set(0.0f);
|
|
|
|
|
m_jaguar->Set(0.0f);
|
|
|
|
|
}
|
2014-07-01 14:06:26 -04:00
|
|
|
};
|
2014-06-12 16:29:47 -04:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Tests the counter by moving the motor and determining if the
|
2014-07-01 14:06:26 -04:00
|
|
|
* counter is counting.
|
2014-06-12 16:29:47 -04:00
|
|
|
*/
|
2014-07-01 14:06:26 -04:00
|
|
|
TEST_F(CounterTest, CountTalon) {
|
|
|
|
|
Reset();
|
|
|
|
|
/* Run the motor forward and determine if the counter is counting. */
|
|
|
|
|
m_talon->Set(1.0f);
|
|
|
|
|
Wait(0.5);
|
2015-06-25 15:07:55 -04:00
|
|
|
EXPECT_NE(0.0f, m_talonCounter->Get()) << "The counter did not count (talon)";
|
2014-07-01 14:06:26 -04:00
|
|
|
/* Set the motor to 0 and determine if the counter resets to 0. */
|
|
|
|
|
m_talon->Set(0.0f);
|
|
|
|
|
Wait(0.5);
|
|
|
|
|
m_talonCounter->Reset();
|
|
|
|
|
EXPECT_FLOAT_EQ(0.0f, m_talonCounter->Get())
|
2015-06-25 15:07:55 -04:00
|
|
|
<< "The counter did not restart to 0 (talon)";
|
2014-07-01 14:06:26 -04:00
|
|
|
}
|
2014-06-12 16:29:47 -04:00
|
|
|
|
2014-07-01 14:06:26 -04:00
|
|
|
TEST_F(CounterTest, CountVictor) {
|
|
|
|
|
Reset();
|
|
|
|
|
/* Run the motor forward and determine if the counter is counting. */
|
|
|
|
|
m_victor->Set(1.0f);
|
|
|
|
|
Wait(0.5);
|
|
|
|
|
EXPECT_NE(0.0f, m_victorCounter->Get())
|
2015-06-25 15:07:55 -04:00
|
|
|
<< "The counter did not count (victor)";
|
2014-07-01 14:06:26 -04:00
|
|
|
/* Set the motor to 0 and determine if the counter resets to 0. */
|
|
|
|
|
m_victor->Set(0.0f);
|
|
|
|
|
Wait(0.5);
|
|
|
|
|
m_victorCounter->Reset();
|
|
|
|
|
EXPECT_FLOAT_EQ(0.0f, m_victorCounter->Get())
|
2015-06-25 15:07:55 -04:00
|
|
|
<< "The counter did not restart to 0 (jaguar)";
|
2014-07-01 14:06:26 -04:00
|
|
|
}
|
2014-06-12 16:29:47 -04:00
|
|
|
|
2014-07-01 14:06:26 -04:00
|
|
|
TEST_F(CounterTest, CountJaguar) {
|
|
|
|
|
Reset();
|
|
|
|
|
/* Run the motor forward and determine if the counter is counting. */
|
|
|
|
|
m_jaguar->Set(1.0f);
|
|
|
|
|
Wait(0.5);
|
|
|
|
|
EXPECT_NE(0.0f, m_jaguarCounter->Get())
|
2015-06-25 15:07:55 -04:00
|
|
|
<< "The counter did not count (jaguar)";
|
2014-07-01 14:06:26 -04:00
|
|
|
/* Set the motor to 0 and determine if the counter resets to 0. */
|
|
|
|
|
m_jaguar->Set(0.0f);
|
|
|
|
|
Wait(0.5);
|
|
|
|
|
m_jaguarCounter->Reset();
|
|
|
|
|
EXPECT_FLOAT_EQ(0.0f, m_jaguarCounter->Get())
|
2015-06-25 15:07:55 -04:00
|
|
|
<< "The counter did not restart to 0 (jaguar)";
|
2014-07-01 14:06:26 -04:00
|
|
|
}
|
2014-06-12 16:29:47 -04:00
|
|
|
|
2014-07-01 14:06:26 -04:00
|
|
|
/**
|
|
|
|
|
* Tests the GetStopped and SetMaxPeriod methods by setting the Max Period and
|
|
|
|
|
* getting the value after a period of time.
|
|
|
|
|
*/
|
|
|
|
|
TEST_F(CounterTest, TalonGetStopped) {
|
|
|
|
|
Reset();
|
|
|
|
|
/* Set the Max Period of the counter and run the motor */
|
|
|
|
|
m_talonCounter->SetMaxPeriod(kMaxPeriod);
|
|
|
|
|
m_talon->Set(1.0f);
|
|
|
|
|
Wait(0.5);
|
2015-06-25 15:07:55 -04:00
|
|
|
EXPECT_FALSE(m_talonCounter->GetStopped()) << "The counter did not count.";
|
2014-07-01 14:06:26 -04:00
|
|
|
/* Stop the motor and wait until the Max Period is exceeded */
|
|
|
|
|
m_talon->Set(0.0f);
|
|
|
|
|
Wait(kMotorDelay);
|
|
|
|
|
EXPECT_TRUE(m_talonCounter->GetStopped())
|
2015-06-25 15:07:55 -04:00
|
|
|
<< "The counter did not stop counting.";
|
2014-07-01 14:06:26 -04:00
|
|
|
}
|
2014-06-12 16:29:47 -04:00
|
|
|
|
2014-07-01 14:06:26 -04:00
|
|
|
TEST_F(CounterTest, VictorGetStopped) {
|
|
|
|
|
Reset();
|
|
|
|
|
/* Set the Max Period of the counter and run the motor */
|
|
|
|
|
m_victorCounter->SetMaxPeriod(kMaxPeriod);
|
|
|
|
|
m_victor->Set(1.0f);
|
|
|
|
|
Wait(0.5);
|
2015-06-25 15:07:55 -04:00
|
|
|
EXPECT_FALSE(m_victorCounter->GetStopped()) << "The counter did not count.";
|
2014-07-01 14:06:26 -04:00
|
|
|
/* Stop the motor and wait until the Max Period is exceeded */
|
|
|
|
|
m_victor->Set(0.0f);
|
|
|
|
|
Wait(kMotorDelay);
|
|
|
|
|
EXPECT_TRUE(m_victorCounter->GetStopped())
|
2015-06-25 15:07:55 -04:00
|
|
|
<< "The counter did not stop counting.";
|
2014-07-01 14:06:26 -04:00
|
|
|
}
|
2014-06-12 16:29:47 -04:00
|
|
|
|
2014-07-01 14:06:26 -04:00
|
|
|
TEST_F(CounterTest, JaguarGetStopped) {
|
|
|
|
|
Reset();
|
|
|
|
|
/* Set the Max Period of the counter and run the motor */
|
|
|
|
|
m_jaguarCounter->SetMaxPeriod(kMaxPeriod);
|
|
|
|
|
m_jaguar->Set(1.0f);
|
|
|
|
|
Wait(0.5);
|
2015-06-25 15:07:55 -04:00
|
|
|
EXPECT_FALSE(m_jaguarCounter->GetStopped()) << "The counter did not count.";
|
2014-07-01 14:06:26 -04:00
|
|
|
/* Stop the motor and wait until the Max Period is exceeded */
|
|
|
|
|
m_jaguar->Set(0.0f);
|
|
|
|
|
Wait(kMotorDelay);
|
|
|
|
|
EXPECT_TRUE(m_jaguarCounter->GetStopped())
|
2015-06-25 15:07:55 -04:00
|
|
|
<< "The counter did not stop counting.";
|
2014-07-01 14:06:26 -04:00
|
|
|
}
|