2014-08-08 17:05:49 -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. */
|
|
|
|
|
/*----------------------------------------------------------------------------*/
|
|
|
|
|
|
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 <Notifier.h>
|
|
|
|
|
#include <Timer.h>
|
2014-08-08 17:05:49 -04:00
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
#include "TestBench.h"
|
|
|
|
|
|
|
|
|
|
unsigned notifierCounter;
|
|
|
|
|
|
2015-06-25 15:07:55 -04:00
|
|
|
void notifierHandler(void *) { notifierCounter++; }
|
2014-08-08 17:05:49 -04:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Test if the Wait function works
|
|
|
|
|
*/
|
|
|
|
|
TEST(NotifierTest, DISABLED_TestTimerNotifications) {
|
2015-06-25 15:07:55 -04:00
|
|
|
std::cout << "NotifierTest..." << std::endl;
|
|
|
|
|
notifierCounter = 0;
|
2015-06-23 04:49:51 -07:00
|
|
|
std::cout << "notifier(notifierHandler, nullptr)..." << std::endl;
|
|
|
|
|
Notifier notifier(notifierHandler, nullptr);
|
2015-06-25 15:07:55 -04:00
|
|
|
std::cout << "Start Periodic..." << std::endl;
|
|
|
|
|
notifier.StartPeriodic(1.0);
|
|
|
|
|
|
|
|
|
|
std::cout << "Wait..." << std::endl;
|
|
|
|
|
Wait(10.5);
|
|
|
|
|
std::cout << "...Wait" << std::endl;
|
|
|
|
|
|
|
|
|
|
EXPECT_EQ(10u, notifierCounter) << "Received " << notifierCounter
|
|
|
|
|
<< " notifications in 10.5 seconds";
|
|
|
|
|
std::cout << "Received " << notifierCounter
|
|
|
|
|
<< " notifications in 10.5 seconds";
|
|
|
|
|
|
|
|
|
|
std::cout << "...NotifierTest" << std::endl;
|
2014-08-08 17:05:49 -04:00
|
|
|
}
|