From 04d81dbea8e29c7f3c9ed398512633d3e40364a0 Mon Sep 17 00:00:00 2001 From: Fabian Meumertzheim Date: Fri, 10 Nov 2023 09:00:50 -0800 Subject: [PATCH] Support lockfile serialization of Starlark tuples in MODULE.bazel files Fixes #20116 Closes #20129. PiperOrigin-RevId: 581276198 Change-Id: I66259e273802e94a09ff1f862001a0109cc623e6 --- .../bazel/bzlmod/AttributeValuesAdapter.java | 6 ++++-- .../bzlmod/AttributeValuesAdapterTest.java | 21 +++++++++++++++++++ 2 files changed, 25 insertions(+), 2 deletions(-) diff --git a/src/main/java/com/google/devtools/build/lib/bazel/bzlmod/AttributeValuesAdapter.java b/src/main/java/com/google/devtools/build/lib/bazel/bzlmod/AttributeValuesAdapter.java index 248d1060975d91..85fdd2a767eb2c 100644 --- a/src/main/java/com/google/devtools/build/lib/bazel/bzlmod/AttributeValuesAdapter.java +++ b/src/main/java/com/google/devtools/build/lib/bazel/bzlmod/AttributeValuesAdapter.java @@ -88,9 +88,11 @@ private JsonElement serializeObject(Object obj) { jsonObject.add(serializeObjToString(entry.getKey()), serializeObject(entry.getValue())); } return jsonObject; - } else if (obj instanceof StarlarkList) { + } else if (obj instanceof Iterable) { + // ListType supports any kind of Iterable, including Tuples and StarlarkLists. All of them + // are converted to an equivalent StarlarkList during deserialization. JsonArray jsonArray = new JsonArray(); - for (Object item : (StarlarkList) obj) { + for (Object item : (Iterable) obj) { jsonArray.add(serializeObject(item)); } return jsonArray; diff --git a/src/test/java/com/google/devtools/build/lib/bazel/bzlmod/AttributeValuesAdapterTest.java b/src/test/java/com/google/devtools/build/lib/bazel/bzlmod/AttributeValuesAdapterTest.java index 45fcbd7d322ea6..b5c0cda5ae66bb 100644 --- a/src/test/java/com/google/devtools/build/lib/bazel/bzlmod/AttributeValuesAdapterTest.java +++ b/src/test/java/com/google/devtools/build/lib/bazel/bzlmod/AttributeValuesAdapterTest.java @@ -30,6 +30,7 @@ import net.starlark.java.eval.Mutability; import net.starlark.java.eval.StarlarkInt; import net.starlark.java.eval.StarlarkList; +import net.starlark.java.eval.Tuple; import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.JUnit4; @@ -89,4 +90,24 @@ public void testAttributeValuesAdapter() throws IOException { assertThat(jsonString).contains(":\"Hello String\""); assertThat((Map) attributeValues.attributes()).containsExactlyEntriesIn(builtDict); } + + @Test + public void testTuple() throws IOException { + Dict.Builder dict = new Dict.Builder<>(); + dict.put("Tuple", Tuple.of("bzl", "mod")); + + Dict builtDict = dict.buildImmutable(); + AttributeValuesAdapter attrAdapter = new AttributeValuesAdapter(); + String jsonString; + try (StringWriter stringWriter = new StringWriter()) { + attrAdapter.write(new JsonWriter(stringWriter), AttributeValues.create(builtDict)); + jsonString = stringWriter.toString(); + } + AttributeValues attributeValues; + try (StringReader stringReader = new StringReader(jsonString)) { + attributeValues = attrAdapter.read(new JsonReader(stringReader)); + } + assertThat((Map) attributeValues.attributes()) + .containsExactly("Tuple", StarlarkList.of(Mutability.IMMUTABLE, "bzl", "mod")); + } }