2014-06-02 17:34:10 -04:00
|
|
|
/*----------------------------------------------------------------------------*/
|
2016-01-02 03:02:34 -08:00
|
|
|
/* Copyright (c) FIRST 2014-2016. All Rights Reserved. */
|
2014-06-02 17:34:10 -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 <Timer.h>
|
2014-06-07 17:37:51 -04:00
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
#include "TestBench.h"
|
|
|
|
|
|
|
|
|
|
static const double kWaitTime = 0.5;
|
|
|
|
|
|
|
|
|
|
class TimerTest : public testing::Test {
|
2015-06-25 15:07:55 -04:00
|
|
|
protected:
|
|
|
|
|
Timer *m_timer;
|
|
|
|
|
|
|
|
|
|
virtual void SetUp() override { m_timer = new Timer; }
|
|
|
|
|
|
|
|
|
|
virtual void TearDown() override { delete m_timer; }
|
|
|
|
|
|
|
|
|
|
void Reset() { m_timer->Reset(); }
|
2014-06-07 17:37:51 -04:00
|
|
|
};
|
2014-06-02 17:34:10 -04:00
|
|
|
|
|
|
|
|
/**
|
2014-06-07 17:37:51 -04:00
|
|
|
* Test if the Wait function works
|
2014-06-02 17:34:10 -04:00
|
|
|
*/
|
2014-06-07 17:37:51 -04:00
|
|
|
TEST_F(TimerTest, Wait) {
|
2015-06-25 15:07:55 -04:00
|
|
|
Reset();
|
2014-06-07 17:37:51 -04:00
|
|
|
|
2015-06-25 15:07:55 -04:00
|
|
|
double initialTime = m_timer->GetFPGATimestamp();
|
|
|
|
|
|
|
|
|
|
Wait(kWaitTime);
|
|
|
|
|
|
|
|
|
|
double finalTime = m_timer->GetFPGATimestamp();
|
|
|
|
|
|
|
|
|
|
EXPECT_NEAR(kWaitTime, finalTime - initialTime, 0.001);
|
|
|
|
|
}
|