2023-11-21 13:14:06 -05: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.
|
|
|
|
|
|
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
|
|
2026-03-06 14:19:15 -08:00
|
|
|
#include "wpi/math/kinematics/ChassisVelocities.hpp"
|
2025-11-07 19:57:55 -05:00
|
|
|
#include "wpi/util/SmallVector.hpp"
|
2023-11-21 13:14:06 -05:00
|
|
|
|
2025-11-07 20:00:05 -05:00
|
|
|
using namespace wpi::math;
|
2023-11-21 13:14:06 -05:00
|
|
|
|
|
|
|
|
namespace {
|
|
|
|
|
|
2026-03-06 14:19:15 -08:00
|
|
|
const ChassisVelocities kExpectedData =
|
|
|
|
|
ChassisVelocities{2.29_mps, 2.2_mps, 0.3504_rad_per_s};
|
2023-11-21 13:14:06 -05:00
|
|
|
} // namespace
|
|
|
|
|
|
2026-03-06 14:19:15 -08:00
|
|
|
TEST(ChassisVelocitiesProtoTest, Roundtrip) {
|
2025-11-07 20:00:05 -05:00
|
|
|
wpi::util::ProtobufMessage<decltype(kExpectedData)> message;
|
|
|
|
|
wpi::util::SmallVector<uint8_t, 64> buf;
|
2024-11-07 22:42:50 -08:00
|
|
|
|
|
|
|
|
ASSERT_TRUE(message.Pack(buf, kExpectedData));
|
|
|
|
|
auto unpacked_data = message.Unpack(buf);
|
|
|
|
|
ASSERT_TRUE(unpacked_data.has_value());
|
|
|
|
|
|
|
|
|
|
EXPECT_EQ(kExpectedData.vx.value(), unpacked_data->vx.value());
|
|
|
|
|
EXPECT_EQ(kExpectedData.vy.value(), unpacked_data->vy.value());
|
|
|
|
|
EXPECT_EQ(kExpectedData.omega.value(), unpacked_data->omega.value());
|
2023-11-21 13:14:06 -05:00
|
|
|
}
|