2023-11-21 13:11:57 -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>
|
2024-11-07 22:42:50 -08:00
|
|
|
#include <wpi/SmallVector.h>
|
2023-11-21 13:11:57 -05:00
|
|
|
|
|
|
|
|
#include "frc/geometry/Twist3d.h"
|
|
|
|
|
|
|
|
|
|
using namespace frc;
|
|
|
|
|
|
|
|
|
|
namespace {
|
|
|
|
|
|
|
|
|
|
const Twist3d kExpectedData =
|
|
|
|
|
Twist3d{1.1_m, 2.29_m, 35.04_m, 0.174_rad, 19.1_rad, 4.4_rad};
|
|
|
|
|
} // namespace
|
|
|
|
|
|
|
|
|
|
TEST(Twist3dProtoTest, Roundtrip) {
|
2024-11-07 22:42:50 -08:00
|
|
|
wpi::ProtobufMessage<decltype(kExpectedData)> message;
|
|
|
|
|
wpi::SmallVector<uint8_t, 64> buf;
|
|
|
|
|
|
|
|
|
|
ASSERT_TRUE(message.Pack(buf, kExpectedData));
|
|
|
|
|
auto unpacked_data = message.Unpack(buf);
|
|
|
|
|
ASSERT_TRUE(unpacked_data.has_value());
|
|
|
|
|
|
|
|
|
|
EXPECT_EQ(kExpectedData.dx.value(), unpacked_data->dx.value());
|
|
|
|
|
EXPECT_EQ(kExpectedData.dy.value(), unpacked_data->dy.value());
|
|
|
|
|
EXPECT_EQ(kExpectedData.dz.value(), unpacked_data->dz.value());
|
|
|
|
|
EXPECT_EQ(kExpectedData.rx.value(), unpacked_data->rx.value());
|
|
|
|
|
EXPECT_EQ(kExpectedData.ry.value(), unpacked_data->ry.value());
|
|
|
|
|
EXPECT_EQ(kExpectedData.rz.value(), unpacked_data->rz.value());
|
2023-11-21 13:11:57 -05:00
|
|
|
}
|