// 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 #include #include "CommandTestBase.h" #include "frc2/command/Commands.h" #include "frc2/command/ConditionalCommand.h" #include "frc2/command/InstantCommand.h" using namespace frc2; class ConditionalCommandTest : public CommandTestBase {}; TEST_F(ConditionalCommandTest, ConditionalCommandSchedule) { CommandScheduler scheduler = GetScheduler(); std::unique_ptr mock = std::make_unique(); 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(), [] { return true; }); scheduler.Schedule(&conditional); scheduler.Run(); mockptr->SetFinished(true); scheduler.Run(); EXPECT_FALSE(scheduler.IsScheduled(&conditional)); } TEST_F(ConditionalCommandTest, ConditionalCommandRequirement) { 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)); } 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()); }