From ca5b35907d4c9f8cac80042ff24292657000b54d Mon Sep 17 00:00:00 2001 From: psainics Date: Mon, 8 Jan 2024 13:20:25 +0530 Subject: [PATCH] Remove duplicate path when writing nested JSON array --- .../bigquery/sink/BigQueryRecordToJson.java | 4 -- .../bigquery/BigQueryRecordToJsonTest.java | 52 +++++++++++++++++++ 2 files changed, 52 insertions(+), 4 deletions(-) diff --git a/src/main/java/io/cdap/plugin/gcp/bigquery/sink/BigQueryRecordToJson.java b/src/main/java/io/cdap/plugin/gcp/bigquery/sink/BigQueryRecordToJson.java index ec2c70edb7..c397e52c74 100644 --- a/src/main/java/io/cdap/plugin/gcp/bigquery/sink/BigQueryRecordToJson.java +++ b/src/main/java/io/cdap/plugin/gcp/bigquery/sink/BigQueryRecordToJson.java @@ -250,14 +250,10 @@ private static void writeArray(JsonWriter writer, } if (element instanceof StructuredRecord) { StructuredRecord record = (StructuredRecord) element; - path.add(name); processRecord(writer, record, Objects.requireNonNull(record.getSchema().getFields()), path, jsonStringFieldsPaths); - path.remove(path.size() - 1); } else { - path.add(name); write(writer, name, true, element, componentSchema, path, jsonStringFieldsPaths); - path.remove(path.size() - 1); } } } diff --git a/src/test/java/io/cdap/plugin/gcp/bigquery/BigQueryRecordToJsonTest.java b/src/test/java/io/cdap/plugin/gcp/bigquery/BigQueryRecordToJsonTest.java index 962a44fd28..e7c1f82aee 100644 --- a/src/test/java/io/cdap/plugin/gcp/bigquery/BigQueryRecordToJsonTest.java +++ b/src/test/java/io/cdap/plugin/gcp/bigquery/BigQueryRecordToJsonTest.java @@ -422,6 +422,58 @@ public void testJsonStringWithEmptyArray() throws IOException { } } + @Test + public void testJsonStringWithStringArray() throws IOException { + Schema recordSchema = Schema.recordOf("record", + Schema.Field.of("arrayOfString", Schema.arrayOf(Schema.of(Schema.Type.STRING)))); + List jsonStringList = ImmutableList.of("{\"arrayKey1\": \"arrayValue1\"}", + "{\"arrayKey2\": \"arrayValue2\"}"); + StructuredRecord record = StructuredRecord.builder(recordSchema).set("arrayOfString", jsonStringList).build(); + Set jsonStringFieldsPaths = ImmutableSet.of("arrayOfString"); + try (JsonTreeWriter writer = new JsonTreeWriter()) { + writer.beginObject(); + for (Schema.Field recordField : Objects.requireNonNull(record.getSchema().getFields())) { + if (recordSchema.getField(recordField.getName()) != null) { + BigQueryRecordToJson.write(writer, recordField.getName(), record.get(recordField.getName()), + recordField.getSchema(), jsonStringFieldsPaths); + } + } + writer.endObject(); + JsonObject actual = writer.get().getAsJsonObject(); + String actualJsonString = actual.get("arrayOfString").getAsJsonArray().toString(); + String expectedJsonString = "[{\"arrayKey1\":\"arrayValue1\"},{\"arrayKey2\":\"arrayValue2\"}]"; + Assert.assertEquals(expectedJsonString, actualJsonString); + } + } + + @Test + public void testJsonStringWithArrayAndNestedRecord() throws IOException { + Schema nestedRecordSchema = Schema.recordOf("nestedRecord", + Schema.Field.of("nestedJsonString", Schema.of(Schema.Type.STRING))); + StructuredRecord nestedRecord = StructuredRecord.builder(nestedRecordSchema) + .set("nestedJsonString", "{\"nestedKey1\":\"nestedValue1\"}").build(); + Schema recordSchema = Schema.recordOf("record", + Schema.Field.of("arrayOfNestedRecord", Schema.arrayOf(nestedRecordSchema))); + List nestedRecordList = ImmutableList.of(nestedRecord); + StructuredRecord record = StructuredRecord.builder(recordSchema).set("arrayOfNestedRecord", nestedRecordList) + .build(); + + Set jsonStringFieldsPaths = ImmutableSet.of("arrayOfNestedRecord.nestedJsonString"); + try (JsonTreeWriter writer = new JsonTreeWriter()) { + writer.beginObject(); + for (Schema.Field recordField : Objects.requireNonNull(record.getSchema().getFields())) { + if (recordSchema.getField(recordField.getName()) != null) { + BigQueryRecordToJson.write(writer, recordField.getName(), record.get(recordField.getName()), + recordField.getSchema(), jsonStringFieldsPaths); + } + } + writer.endObject(); + JsonObject actual = writer.get().getAsJsonObject(); + String actualJsonString = actual.get("arrayOfNestedRecord").toString(); + String expectedJsonString = "[{\"nestedJsonString\":{\"nestedKey1\":\"nestedValue1\"}}]"; + Assert.assertEquals(expectedJsonString, actualJsonString); + } + } /** * Empty JSON string is not a valid JSON string and should throw an exception.