2020-12-26 14:12:05 -08: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.
|
2019-08-25 23:55:59 -04:00
|
|
|
|
|
|
|
|
#include "CommandTestBase.h"
|
2023-06-23 18:21:05 +03:00
|
|
|
#include "frc2/command/Commands.h"
|
2019-08-25 23:55:59 -04:00
|
|
|
#include "frc2/command/ConditionalCommand.h"
|
|
|
|
|
#include "frc2/command/InstantCommand.h"
|
|
|
|
|
|
|
|
|
|
using namespace frc2;
|
|
|
|
|
class ConditionalCommandTest : public CommandTestBase {};
|
|
|
|
|
|
2021-09-17 22:51:51 -07:00
|
|
|
TEST_F(ConditionalCommandTest, ConditionalCommandSchedule) {
|
2019-08-25 23:55:59 -04:00
|
|
|
CommandScheduler scheduler = GetScheduler();
|
|
|
|
|
|
|
|
|
|
std::unique_ptr<MockCommand> mock = std::make_unique<MockCommand>();
|
|
|
|
|
MockCommand* mockptr = mock.get();
|
|
|
|
|
|
|
|
|
|
EXPECT_CALL(*mock, Initialize());
|
|
|
|
|
EXPECT_CALL(*mock, Execute()).Times(2);
|
|
|
|
|
EXPECT_CALL(*mock, End(false));
|
|
|
|
|
|
|
|
|
|
ConditionalCommand conditional(
|
|
|
|
|
std::move(mock), std::make_unique<InstantCommand>(), [] { return true; });
|
|
|
|
|
|
|
|
|
|
scheduler.Schedule(&conditional);
|
|
|
|
|
scheduler.Run();
|
|
|
|
|
mockptr->SetFinished(true);
|
|
|
|
|
scheduler.Run();
|
|
|
|
|
|
|
|
|
|
EXPECT_FALSE(scheduler.IsScheduled(&conditional));
|
|
|
|
|
}
|
|
|
|
|
|
2021-09-17 22:51:51 -07:00
|
|
|
TEST_F(ConditionalCommandTest, ConditionalCommandRequirement) {
|
2019-08-25 23:55:59 -04:00
|
|
|
CommandScheduler scheduler = GetScheduler();
|
|
|
|
|
|
|
|
|
|
TestSubsystem requirement1;
|
|
|
|
|
TestSubsystem requirement2;
|
|
|
|
|
TestSubsystem requirement3;
|
|
|
|
|
TestSubsystem requirement4;
|
|
|
|
|
|
|
|
|
|
InstantCommand command1([] {}, {&requirement1, &requirement2});
|
|
|
|
|
InstantCommand command2([] {}, {&requirement3});
|
|
|
|
|
InstantCommand command3([] {}, {&requirement3, &requirement4});
|
|
|
|
|
|
|
|
|
|
ConditionalCommand conditional(std::move(command1), std::move(command2),
|
|
|
|
|
[] { return true; });
|
|
|
|
|
scheduler.Schedule(&conditional);
|
|
|
|
|
scheduler.Schedule(&command3);
|
|
|
|
|
|
|
|
|
|
EXPECT_TRUE(scheduler.IsScheduled(&command3));
|
|
|
|
|
EXPECT_FALSE(scheduler.IsScheduled(&conditional));
|
|
|
|
|
}
|
2023-06-23 18:21:05 +03:00
|
|
|
|
|
|
|
|
TEST_F(ConditionalCommandTest, AllTrue) {
|
|
|
|
|
CommandPtr command =
|
|
|
|
|
cmd::Either(cmd::WaitUntil([] { return false; }).IgnoringDisable(true),
|
|
|
|
|
cmd::WaitUntil([] { return false; }).IgnoringDisable(true),
|
|
|
|
|
[] { return true; });
|
|
|
|
|
EXPECT_EQ(true, command.get()->RunsWhenDisabled());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(ConditionalCommandTest, AllFalse) {
|
|
|
|
|
CommandPtr command =
|
|
|
|
|
cmd::Either(cmd::WaitUntil([] { return false; }).IgnoringDisable(false),
|
|
|
|
|
cmd::WaitUntil([] { return false; }).IgnoringDisable(false),
|
|
|
|
|
[] { return true; });
|
|
|
|
|
EXPECT_EQ(false, command.get()->RunsWhenDisabled());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(ConditionalCommandTest, OneTrueOneFalse) {
|
|
|
|
|
CommandPtr command =
|
|
|
|
|
cmd::Either(cmd::WaitUntil([] { return false; }).IgnoringDisable(true),
|
|
|
|
|
cmd::WaitUntil([] { return false; }).IgnoringDisable(false),
|
|
|
|
|
[] { return true; });
|
|
|
|
|
EXPECT_EQ(false, command.get()->RunsWhenDisabled());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(ConditionalCommandTest, TwoFalseOneTrue) {
|
|
|
|
|
CommandPtr command =
|
|
|
|
|
cmd::Either(cmd::WaitUntil([] { return false; }).IgnoringDisable(false),
|
|
|
|
|
cmd::WaitUntil([] { return false; }).IgnoringDisable(true),
|
|
|
|
|
[] { return true; });
|
|
|
|
|
EXPECT_EQ(false, command.get()->RunsWhenDisabled());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(ConditionalCommandTest, AllCancelSelf) {
|
|
|
|
|
CommandPtr command = cmd::Either(
|
|
|
|
|
cmd::WaitUntil([] {
|
|
|
|
|
return false;
|
|
|
|
|
}).WithInterruptBehavior(Command::InterruptionBehavior::kCancelSelf),
|
|
|
|
|
cmd::WaitUntil([] {
|
|
|
|
|
return false;
|
|
|
|
|
}).WithInterruptBehavior(Command::InterruptionBehavior::kCancelSelf),
|
|
|
|
|
[] { return true; });
|
|
|
|
|
EXPECT_EQ(Command::InterruptionBehavior::kCancelSelf,
|
|
|
|
|
command.get()->GetInterruptionBehavior());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(ConditionalCommandTest, AllCancelIncoming) {
|
|
|
|
|
CommandPtr command = cmd::Either(
|
|
|
|
|
cmd::WaitUntil([] {
|
|
|
|
|
return false;
|
|
|
|
|
}).WithInterruptBehavior(Command::InterruptionBehavior::kCancelIncoming),
|
|
|
|
|
cmd::WaitUntil([] {
|
|
|
|
|
return false;
|
|
|
|
|
}).WithInterruptBehavior(Command::InterruptionBehavior::kCancelIncoming),
|
|
|
|
|
[] { return false; });
|
|
|
|
|
EXPECT_EQ(Command::InterruptionBehavior::kCancelIncoming,
|
|
|
|
|
command.get()->GetInterruptionBehavior());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(ConditionalCommandTest, OneCancelSelfOneIncoming) {
|
|
|
|
|
CommandPtr command = cmd::Either(
|
|
|
|
|
cmd::WaitUntil([] {
|
|
|
|
|
return false;
|
|
|
|
|
}).WithInterruptBehavior(Command::InterruptionBehavior::kCancelSelf),
|
|
|
|
|
cmd::WaitUntil([] {
|
|
|
|
|
return false;
|
|
|
|
|
}).WithInterruptBehavior(Command::InterruptionBehavior::kCancelIncoming),
|
|
|
|
|
[] { return false; });
|
|
|
|
|
EXPECT_EQ(Command::InterruptionBehavior::kCancelSelf,
|
|
|
|
|
command.get()->GetInterruptionBehavior());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(ConditionalCommandTest, OneCancelIncomingOneSelf) {
|
|
|
|
|
CommandPtr command = cmd::Either(
|
|
|
|
|
cmd::WaitUntil([] {
|
|
|
|
|
return false;
|
|
|
|
|
}).WithInterruptBehavior(Command::InterruptionBehavior::kCancelIncoming),
|
|
|
|
|
cmd::WaitUntil([] {
|
|
|
|
|
return false;
|
|
|
|
|
}).WithInterruptBehavior(Command::InterruptionBehavior::kCancelSelf),
|
|
|
|
|
[] { return false; });
|
|
|
|
|
EXPECT_EQ(Command::InterruptionBehavior::kCancelSelf,
|
|
|
|
|
command.get()->GetInterruptionBehavior());
|
|
|
|
|
}
|