2021-08-05 22:04:51 -04:00
|
|
|
// Copyright (c) FIRST and other WPILib contributors.
|
|
|
|
|
// Open Source Software; you can modify and/or share it under the terms of
|
|
|
|
|
// the WPILib BSD license file in the root directory of this project.
|
|
|
|
|
|
2025-11-07 19:56:21 -05:00
|
|
|
#include "wpi/simulation/DutyCycleSim.hpp" // NOLINT(build/include_order)
|
2021-08-05 22:04:51 -04:00
|
|
|
|
2023-08-28 15:13:34 -07:00
|
|
|
#include <gtest/gtest.h>
|
2025-11-07 19:56:21 -05:00
|
|
|
#include "wpi/hal/HAL.h"
|
2021-08-05 22:04:51 -04:00
|
|
|
|
2025-11-07 19:56:21 -05:00
|
|
|
#include "callback_helpers/TestCallbackHelpers.hpp"
|
|
|
|
|
#include "wpi/hardware/discrete/DigitalInput.hpp"
|
|
|
|
|
#include "wpi/hardware/rotation/DutyCycle.hpp"
|
2021-08-05 22:04:51 -04:00
|
|
|
|
|
|
|
|
namespace frc::sim {
|
|
|
|
|
|
|
|
|
|
TEST(DutyCycleSimTest, Initialization) {
|
|
|
|
|
HAL_Initialize(500, 0);
|
2025-07-14 23:46:17 -07:00
|
|
|
DutyCycleSim sim = DutyCycleSim::CreateForChannel(2);
|
2021-08-05 22:04:51 -04:00
|
|
|
EXPECT_FALSE(sim.GetInitialized());
|
|
|
|
|
|
|
|
|
|
BooleanCallback callback;
|
|
|
|
|
auto cb = sim.RegisterInitializedCallback(callback.GetCallback(), false);
|
|
|
|
|
|
2025-01-15 11:57:31 -08:00
|
|
|
DutyCycle dc{2};
|
2021-08-05 22:04:51 -04:00
|
|
|
EXPECT_TRUE(sim.GetInitialized());
|
|
|
|
|
EXPECT_TRUE(callback.WasTriggered());
|
|
|
|
|
EXPECT_TRUE(callback.GetLastValue());
|
|
|
|
|
|
|
|
|
|
callback.Reset();
|
|
|
|
|
sim.SetInitialized(false);
|
|
|
|
|
EXPECT_TRUE(callback.WasTriggered());
|
|
|
|
|
EXPECT_FALSE(callback.GetLastValue());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(DutyCycleSimTest, SetFrequency) {
|
|
|
|
|
HAL_Initialize(500, 0);
|
|
|
|
|
|
2025-01-15 11:57:31 -08:00
|
|
|
DutyCycle dc{2};
|
2021-08-05 22:04:51 -04:00
|
|
|
DutyCycleSim sim(dc);
|
|
|
|
|
|
2025-07-14 23:46:17 -07:00
|
|
|
DoubleCallback callback;
|
2021-08-05 22:04:51 -04:00
|
|
|
auto cb = sim.RegisterFrequencyCallback(callback.GetCallback(), false);
|
|
|
|
|
|
2025-07-14 23:46:17 -07:00
|
|
|
sim.SetFrequency(191_Hz);
|
|
|
|
|
EXPECT_EQ(191_Hz, sim.GetFrequency());
|
|
|
|
|
EXPECT_EQ(191_Hz, dc.GetFrequency());
|
2021-08-05 22:04:51 -04:00
|
|
|
EXPECT_TRUE(callback.WasTriggered());
|
|
|
|
|
EXPECT_EQ(191, callback.GetLastValue());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(DutyCycleSimTest, SetOutput) {
|
|
|
|
|
HAL_Initialize(500, 0);
|
|
|
|
|
|
2025-01-15 11:57:31 -08:00
|
|
|
DutyCycle dc{2};
|
2021-08-05 22:04:51 -04:00
|
|
|
DutyCycleSim sim(dc);
|
|
|
|
|
|
|
|
|
|
DoubleCallback callback;
|
|
|
|
|
auto cb = sim.RegisterOutputCallback(callback.GetCallback(), false);
|
|
|
|
|
|
|
|
|
|
sim.SetOutput(229.174);
|
|
|
|
|
EXPECT_EQ(229.174, sim.GetOutput());
|
|
|
|
|
EXPECT_EQ(229.174, dc.GetOutput());
|
|
|
|
|
EXPECT_TRUE(callback.WasTriggered());
|
|
|
|
|
EXPECT_EQ(229.174, callback.GetLastValue());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
} // namespace frc::sim
|