Skip to content

Commit

Permalink
DGS-4971 Handle map types with enhanced.protobuf.schema.support (#2395)
Browse files Browse the repository at this point in the history
  • Loading branch information
rayokota authored Sep 29, 2022
1 parent cd6d45d commit 78663d3
Show file tree
Hide file tree
Showing 3 changed files with 40 additions and 6 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -1062,7 +1062,8 @@ private static boolean isMapDescriptor(

private SchemaBuilder toMapSchema(ToConnectContext ctx, Descriptor descriptor) {
List<FieldDescriptor> fieldDescriptors = descriptor.getFields();
String name = ProtobufSchema.toMapField(descriptor.getName());
String name = ProtobufSchema.toMapField(
enhancedSchemaSupport ? descriptor.getFullName() : descriptor.getName());
return SchemaBuilder.map(toConnectSchema(ctx, fieldDescriptors.get(0)),
toConnectSchema(ctx, fieldDescriptors.get(1))
).name(name);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1273,6 +1273,36 @@ public void testToConnectFullyQualifiedSchema() {
assertEquals("foo.Event.Action", actual.field("action").schema().name());
}

@Test
public void testToConnectFullyQualifiedMapSchema() {
String schema = "syntax = \"proto3\";\n"
+ "\n"
+ "option java_package = \"io.confluent.connect.protobuf.test\";\n"
+ "\n"
+ "message Customer {\n"
+ " map<string,string> tags = 1;\n"
+ " Meta meta = 2;\n"
+ "}\n"
+ "\n"
+ "message Meta {\n"
+ " map<string,Value> tags = 2;\n"
+ "}\n"
+ "\n"
+ "message Value{\n"
+ " float a=1;\n"
+ " float b=2;\n"
+ "}\n";

ProtobufSchema protobufSchema = new ProtobufSchema(schema);
Map<String, Object> configs = new HashMap<>();
configs.put(ProtobufDataConfig.ENHANCED_PROTOBUF_SCHEMA_SUPPORT_CONFIG, true);
ProtobufData protobufData = new ProtobufData(new ProtobufDataConfig(configs));
Schema actual = protobufData.toConnectSchema(protobufSchema);
assertEquals("Customer.tags",
actual.field("tags").schema().name());
assertEquals("Meta.tags", actual.field("meta").schema().field("tags").schema().name());
}

@Test
public void testToConnectMultipleMapReferences() throws Exception {
AttributeFieldEntry entry1 = AttributeFieldEntry.newBuilder()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -954,10 +954,13 @@ public static String toMapEntry(String s) {
}

public static String toMapField(String s) {
if (s.endsWith(MAP_ENTRY_SUFFIX)) {
s = s.substring(0, s.length() - MAP_ENTRY_SUFFIX.length());
s = UPPER_CAMEL.to(LOWER_UNDERSCORE, s);
}
return s;
String[] parts = s.split("\\.");
String lastPart = parts[parts.length - 1];
if (lastPart.endsWith(MAP_ENTRY_SUFFIX)) {
lastPart = lastPart.substring(0, lastPart.length() - MAP_ENTRY_SUFFIX.length());
lastPart = UPPER_CAMEL.to(LOWER_UNDERSCORE, lastPart);
parts[parts.length - 1] = lastPart;
}
return String.join(".", parts);
}
}

0 comments on commit 78663d3

Please sign in to comment.