// Copyright 2022 Google LLC // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #include "commands.hpp" #include "handler_mock.hpp" #include "helper.hpp" #include "pcie_bifurcation.hpp" #include #include using ::testing::Return; namespace google { namespace ipmi { using testing::_; using ::testing::ContainerEq; TEST(PcieBifurcationCommandTest, InvalidRequest) { std::vector request = {}; HandlerMock hMock; EXPECT_EQ(::ipmi::responseReqDataLenInvalid(), pcieBifurcation(request, &hMock)); } TEST(PcieBifurcationCommandTest, ValidRequest) { std::vector request = {5}; std::vector expectedOutput = {4, 8, 1, 2}; HandlerMock hMock; EXPECT_CALL(hMock, pcieBifurcation(5)).WillOnce(Return(expectedOutput)); auto reply = pcieBifurcation(request, &hMock); auto result = ValidateReply(reply); auto& data = result.second; EXPECT_EQ(sizeof(struct PcieBifurcationReply) + expectedOutput.size(), data.size()); EXPECT_EQ(SysOEMCommands::SysPCIeSlotBifurcation, result.first); EXPECT_THAT(std::vector(data.begin() + 1, data.end()), ContainerEq(expectedOutput)); } TEST(PcieBifurcationCommandTest, ReplyExceddedMaxValue) { std::vector request = {5}; std::vector expectedOutput(64, 1); HandlerMock hMock; EXPECT_CALL(hMock, pcieBifurcation(5)).WillOnce(Return(expectedOutput)); EXPECT_EQ(::ipmi::responseInvalidCommand(), pcieBifurcation(request, &hMock)); } } // namespace ipmi } // namespace google