-
Notifications
You must be signed in to change notification settings - Fork 611
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[cmd] Add Commands.Choose aka SendableChooserCommand
- Loading branch information
1 parent
02c78bc
commit 0d2b280
Showing
4 changed files
with
214 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
68 changes: 68 additions & 0 deletions
68
...bNewCommands/src/test/java/edu/wpi/first/wpilibj2/command/SendableChooserCommandTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,68 @@ | ||
// 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. | ||
|
||
package edu.wpi.first.wpilibj2.command; | ||
|
||
import static org.junit.jupiter.api.Assertions.assertArrayEquals; | ||
|
||
import edu.wpi.first.networktables.BooleanPublisher; | ||
import edu.wpi.first.networktables.NetworkTableInstance; | ||
import edu.wpi.first.wpilibj.smartdashboard.SmartDashboard; | ||
import java.util.stream.Stream; | ||
import org.junit.jupiter.api.AfterEach; | ||
import org.junit.jupiter.api.BeforeEach; | ||
import org.junit.jupiter.params.ParameterizedTest; | ||
import org.junit.jupiter.params.provider.Arguments; | ||
import org.junit.jupiter.params.provider.MethodSource; | ||
|
||
class SendableChooserCommandTest extends CommandTestBase { | ||
private NetworkTableInstance m_inst; | ||
private BooleanPublisher m_publish; | ||
private static final String kBasePath = "/SmartDashboard/chooser/"; | ||
|
||
@BeforeEach | ||
void setUp() { | ||
m_inst = NetworkTableInstance.create(); | ||
SmartDashboard.setNetworkTableInstance(m_inst); | ||
m_publish = m_inst.getBooleanTopic("/SmartDashboard/chooser").publish(); | ||
SmartDashboard.updateValues(); | ||
} | ||
|
||
@ParameterizedTest(name = "options[{index}]: {0}") | ||
@MethodSource | ||
void optionsAreCorrect( | ||
@SuppressWarnings("unused") String testName, Command[] commands, String[] names) { | ||
try (var optionsSubscriber = | ||
m_inst.getStringArrayTopic(kBasePath + "options").subscribe(new String[] {})) { | ||
@SuppressWarnings("unused") | ||
var command = Commands.choose(c -> SmartDashboard.putData("chooser", c), commands); | ||
SmartDashboard.updateValues(); | ||
assertArrayEquals(names, optionsSubscriber.get()); | ||
} | ||
} | ||
|
||
static Stream<Arguments> optionsAreCorrect() { | ||
return Stream.of( | ||
Arguments.of("empty", new Command[] {}, new String[] {}), | ||
Arguments.of( | ||
"duplicateName", | ||
new Command[] {commandNamed("a"), commandNamed("b"), commandNamed("a")}, | ||
new String[] {"a", "b"}), | ||
Arguments.of( | ||
"happyPath", | ||
new Command[] {commandNamed("a"), commandNamed("b"), commandNamed("c")}, | ||
new String[] {"a", "b", "c"})); | ||
} | ||
|
||
@AfterEach | ||
void tearDown() { | ||
m_publish.close(); | ||
m_inst.close(); | ||
SmartDashboard.setNetworkTableInstance(NetworkTableInstance.getDefault()); | ||
} | ||
|
||
private static Command commandNamed(String name) { | ||
return Commands.print(name).withName(name); | ||
} | ||
} |
71 changes: 71 additions & 0 deletions
71
wpilibNewCommands/src/test/native/cpp/frc2/command/SendableChooserCommandTest.cpp
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,71 @@ | ||
// 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 "CommandTestBase.h" | ||
#include "frc/smartdashboard/SmartDashboard.h" | ||
#include "frc2/command/CommandPtr.h" | ||
#include "frc2/command/Commands.h" | ||
#include "wpi/sendable/Sendable.h" | ||
#include <networktables/NetworkTableInstance.h> | ||
#include <networktables/BooleanTopic.h> | ||
#include <networktables/StringArrayTopic.h> | ||
#include <string_view> | ||
#include <utility> | ||
#include <vector> | ||
|
||
#include "make_vector.h" | ||
|
||
using namespace frc2; | ||
|
||
typename SendableChooserTestArgs = | ||
std::pair<std::vector<frc2::CommandPtr>, std::vector<std::string_view>>; | ||
|
||
class SendableChooserCommandTest | ||
: public CommandTestBaseWithParam<SendableChooserTestArgs> { | ||
protected: | ||
nt::BooleanPublisher m_publish; | ||
void SetUp() override { | ||
m_publish = nt::NetworkTableInstance::GetDefault() | ||
.GetBooleanTopic("/SmartDashboard/chooser") | ||
.Publish(); | ||
frc::SmartDashboard::UpdateValues(); | ||
} | ||
}; | ||
|
||
TEST_P(SendableChooserCommandTest, OptionsAreCorrect) { | ||
auto&& [commands, names] = GetParam(); | ||
nt::StringArraySubscriber optionsSubscriber = | ||
nt::NetworkTableInstance::GetDefault() | ||
.GetStringArrayTopic("/SmartDashboard/chooser/options") | ||
.Subscribe(); | ||
auto cmd = frc2::cmd::Choose( | ||
[&](wpi::Sendable* c) { frc::SmartDashboard::PutData("chooser", c); }, | ||
std::move(commands)); | ||
frc::SmartDashboard::UpdateValues(); | ||
// EXPECT_THAT(optionsSubscriber.Get(), ::testing::ElementsAre) | ||
} | ||
|
||
namespace utils { | ||
const static frc2::CommandPtr CommandNamed(std::string_view name) { | ||
return frc2::cmd::Print(name).WithName(name); | ||
} | ||
|
||
const static auto OptionsAreCorrectParams() { | ||
SendableChooserTestArgs empty{make_vector<frc2::CommandPtr>(), make_vector<std::string_view>()}; | ||
|
||
SendableChooserTestArgs duplicateName{ | ||
make_vector<frc2::CommandPtr>(CommandNamed("a"), CommandNamed("b"), CommandNamed("a")), | ||
make_vector<std::string_view>("a", "b")}; | ||
|
||
SendableChooserTestArgs happyPath{ | ||
make_vector<frc2::CommandPtr>(CommandNamed("a"), CommandNamed("b"), CommandNamed("c")), | ||
make_vector<std::string_view>("a", "b", "c")}; | ||
|
||
return testing::Values(empty, duplicateName, happyPath); | ||
} | ||
|
||
} // namespace utils | ||
|
||
INSTANTIATE_TEST_SUITE_P(SendableChooserCommandTests, SendableChooserCommandTest, | ||
utils::OptionsAreCorrectParams()); |