mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-06-23 01:21:42 +00:00
Having PCM as a singleton is a problem, as multiple things need to use it, and that gets really ugly. This changes PCM's to be a reference counted object, that can be passed around and constructed from multiple places. In Java, this is using a map to hold a data store with a ref count, and allocating new objects any time a duplicate is requested. In C++, this uses a trick constructor to store a PCM instance in the data store itself. This instance can then be passed to base objects using std::shared_ptr's aliasing constructor, which means constructing a solenoid from a PCM is not allocating after the 1st one. This did require removing sendable from PCM. A compressor class was added back in to act as sendable for the PCM. After this change is finished, the only change RobotBuilder and Team Code would require is passing a module type to solenoid constructors. Co-authored-by: sciencewhiz <sciencewhiz@users.noreply.github.com>
53 lines
1.5 KiB
C++
53 lines
1.5 KiB
C++
// 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.
|
|
|
|
#include <hal/HAL.h>
|
|
|
|
#include "frc/DoubleSolenoid.h"
|
|
#include "frc/PneumaticsControlModule.h"
|
|
#include "frc/Solenoid.h"
|
|
#include "gtest/gtest.h"
|
|
|
|
namespace frc {
|
|
TEST(SolenoidTest, ValidInitialization) {
|
|
Solenoid solenoid{3, frc::PneumaticsModuleType::CTREPCM, 2};
|
|
EXPECT_EQ(2, solenoid.GetChannel());
|
|
|
|
solenoid.Set(true);
|
|
EXPECT_TRUE(solenoid.Get());
|
|
|
|
solenoid.Set(false);
|
|
EXPECT_FALSE(solenoid.Get());
|
|
}
|
|
|
|
TEST(SolenoidTest, DoubleInitialization) {
|
|
Solenoid solenoid{3, frc::PneumaticsModuleType::CTREPCM, 2};
|
|
EXPECT_THROW(Solenoid(3, frc::PneumaticsModuleType::CTREPCM, 2),
|
|
std::runtime_error);
|
|
}
|
|
|
|
TEST(SolenoidTest, DoubleInitializationFromDoubleSolenoid) {
|
|
DoubleSolenoid solenoid{3, frc::PneumaticsModuleType::CTREPCM, 2, 3};
|
|
EXPECT_THROW(Solenoid(3, frc::PneumaticsModuleType::CTREPCM, 2),
|
|
std::runtime_error);
|
|
}
|
|
|
|
TEST(SolenoidTest, InvalidChannel) {
|
|
EXPECT_THROW(Solenoid(3, frc::PneumaticsModuleType::CTREPCM, 100),
|
|
std::runtime_error);
|
|
}
|
|
|
|
TEST(SolenoidTest, Toggle) {
|
|
Solenoid solenoid{3, frc::PneumaticsModuleType::CTREPCM, 2};
|
|
solenoid.Set(true);
|
|
EXPECT_TRUE(solenoid.Get());
|
|
|
|
solenoid.Toggle();
|
|
EXPECT_FALSE(solenoid.Get());
|
|
|
|
solenoid.Toggle();
|
|
EXPECT_TRUE(solenoid.Get());
|
|
}
|
|
} // namespace frc
|