Add concrete component script field support
This commit is contained in:
@@ -20,6 +20,7 @@ TEST(ScriptFieldStorage_Test, StoresRetrievesAndRemovesSupportedValues) {
|
||||
EXPECT_TRUE(storage.SetFieldValue("Velocity", Vector3(3.0f, 4.0f, 5.0f)));
|
||||
EXPECT_TRUE(storage.SetFieldValue("Tint", Vector4(0.1f, 0.2f, 0.3f, 1.0f)));
|
||||
EXPECT_TRUE(storage.SetFieldValue("Target", GameObjectReference{42}));
|
||||
EXPECT_TRUE(storage.SetFieldValue("TargetCamera", ComponentReference{42, 0}));
|
||||
|
||||
float speed = 0.0f;
|
||||
double accuracy = 0.0;
|
||||
@@ -31,8 +32,9 @@ TEST(ScriptFieldStorage_Test, StoresRetrievesAndRemovesSupportedValues) {
|
||||
Vector3 velocity;
|
||||
Vector4 tint;
|
||||
GameObjectReference target;
|
||||
ComponentReference targetCamera;
|
||||
|
||||
EXPECT_EQ(storage.GetFieldCount(), 10u);
|
||||
EXPECT_EQ(storage.GetFieldCount(), 11u);
|
||||
EXPECT_TRUE(storage.Contains("Velocity"));
|
||||
EXPECT_TRUE(storage.TryGetFieldValue("Speed", speed));
|
||||
EXPECT_TRUE(storage.TryGetFieldValue("Accuracy", accuracy));
|
||||
@@ -44,6 +46,7 @@ TEST(ScriptFieldStorage_Test, StoresRetrievesAndRemovesSupportedValues) {
|
||||
EXPECT_TRUE(storage.TryGetFieldValue("Velocity", velocity));
|
||||
EXPECT_TRUE(storage.TryGetFieldValue("Tint", tint));
|
||||
EXPECT_TRUE(storage.TryGetFieldValue("Target", target));
|
||||
EXPECT_TRUE(storage.TryGetFieldValue("TargetCamera", targetCamera));
|
||||
|
||||
EXPECT_FLOAT_EQ(speed, 3.5f);
|
||||
EXPECT_DOUBLE_EQ(accuracy, 0.875);
|
||||
@@ -55,10 +58,11 @@ TEST(ScriptFieldStorage_Test, StoresRetrievesAndRemovesSupportedValues) {
|
||||
EXPECT_EQ(velocity, Vector3(3.0f, 4.0f, 5.0f));
|
||||
EXPECT_EQ(tint, Vector4(0.1f, 0.2f, 0.3f, 1.0f));
|
||||
EXPECT_EQ(target, GameObjectReference{42});
|
||||
EXPECT_EQ(targetCamera, (ComponentReference{42, 0}));
|
||||
|
||||
EXPECT_TRUE(storage.Remove("IsAlive"));
|
||||
EXPECT_FALSE(storage.Contains("IsAlive"));
|
||||
EXPECT_EQ(storage.GetFieldCount(), 9u);
|
||||
EXPECT_EQ(storage.GetFieldCount(), 10u);
|
||||
}
|
||||
|
||||
TEST(ScriptFieldStorage_Test, SerializeRoundTripPreservesFieldValues) {
|
||||
@@ -66,6 +70,7 @@ TEST(ScriptFieldStorage_Test, SerializeRoundTripPreservesFieldValues) {
|
||||
ASSERT_TRUE(original.SetFieldValue("Message", std::string("Ready;Set=Go|100%\nLine2")));
|
||||
ASSERT_TRUE(original.SetFieldValue("Scale", Vector3(2.0f, 3.0f, 4.0f)));
|
||||
ASSERT_TRUE(original.SetFieldValue("Owner", GameObjectReference{778899}));
|
||||
ASSERT_TRUE(original.SetFieldValue("View", ComponentReference{778899, 123456}));
|
||||
ASSERT_TRUE(original.SetFieldValue("Counter", int32_t(-17)));
|
||||
|
||||
const std::string serialized = original.SerializeToString();
|
||||
@@ -76,16 +81,19 @@ TEST(ScriptFieldStorage_Test, SerializeRoundTripPreservesFieldValues) {
|
||||
std::string message;
|
||||
Vector3 scale;
|
||||
GameObjectReference owner;
|
||||
ComponentReference view;
|
||||
int32_t counter = 0;
|
||||
|
||||
EXPECT_TRUE(restored.TryGetFieldValue("Message", message));
|
||||
EXPECT_TRUE(restored.TryGetFieldValue("Scale", scale));
|
||||
EXPECT_TRUE(restored.TryGetFieldValue("Owner", owner));
|
||||
EXPECT_TRUE(restored.TryGetFieldValue("View", view));
|
||||
EXPECT_TRUE(restored.TryGetFieldValue("Counter", counter));
|
||||
|
||||
EXPECT_EQ(message, "Ready;Set=Go|100%\nLine2");
|
||||
EXPECT_EQ(scale, Vector3(2.0f, 3.0f, 4.0f));
|
||||
EXPECT_EQ(owner, GameObjectReference{778899});
|
||||
EXPECT_EQ(view, (ComponentReference{778899, 123456}));
|
||||
EXPECT_EQ(counter, -17);
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user