mirror of https://github.com/apache/nifi.git
NIFI-9594: When converting Record to Avro GenericRecord, ensure that any default values that are defined in the GenericRecord's schema get applied, regardless of whether or not the field exists in the associated RecordSchema.
Signed-off-by: Pierre Villard <pierre.villard.fr@gmail.com> This closes #5677.
This commit is contained in:
parent
139a269c41
commit
1d353435a5
|
@ -626,8 +626,7 @@ public class AvroTypeUtil {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
final Optional<RecordField> recordField = recordSchema.getField(field.name());
|
if (rec.get(field.name()) == null) {
|
||||||
if (!recordField.isPresent() && rec.get(field.name()) == null) {
|
|
||||||
rec.put(field.name(), field.defaultVal());
|
rec.put(field.name(), field.defaultVal());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -122,6 +122,27 @@ public class TestAvroTypeUtil {
|
||||||
assertEquals("blue", avroRecord.get("color"));
|
assertEquals("blue", avroRecord.get("color"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testAvroDefaultValueWithFieldInSchemaButNotRecord() throws IOException {
|
||||||
|
final List<RecordField> fields = new ArrayList<>();
|
||||||
|
fields.add(new RecordField("name", RecordFieldType.STRING.getDataType()));
|
||||||
|
fields.add(new RecordField("color", RecordFieldType.STRING.getDataType()));
|
||||||
|
final RecordSchema personSchema = new SimpleRecordSchema(fields);
|
||||||
|
|
||||||
|
final org.apache.nifi.serialization.record.Record record = new MapRecord(personSchema, Collections.singletonMap("name", "John Doe"));
|
||||||
|
final Schema avroSchema = SchemaBuilder.record("person").namespace("nifi")
|
||||||
|
.fields()
|
||||||
|
.requiredString("name")
|
||||||
|
.name("color").type().stringType().stringDefault("blue")
|
||||||
|
.endRecord();
|
||||||
|
|
||||||
|
final GenericRecord avroRecord = AvroTypeUtil.createAvroRecord(record, avroSchema);
|
||||||
|
assertEquals("John Doe", avroRecord.get("name"));
|
||||||
|
assertEquals("blue", avroRecord.get("color"));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testCreateAvroSchemaPrimitiveTypes() {
|
public void testCreateAvroSchemaPrimitiveTypes() {
|
||||||
final List<RecordField> fields = new ArrayList<>();
|
final List<RecordField> fields = new ArrayList<>();
|
||||||
|
@ -625,6 +646,7 @@ public class TestAvroTypeUtil {
|
||||||
assertTrue(field4.aliases().contains(" __ Another ONE!!"));
|
assertTrue(field4.aliases().contains(" __ Another ONE!!"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void testListToArrayConversion() {
|
public void testListToArrayConversion() {
|
||||||
final Charset charset = Charset.forName("UTF-8");
|
final Charset charset = Charset.forName("UTF-8");
|
||||||
Object o = AvroTypeUtil.convertToAvroObject(Collections.singletonList("Hello"), Schema.createArray(Schema.create(Type.STRING)), charset);
|
Object o = AvroTypeUtil.convertToAvroObject(Collections.singletonList("Hello"), Schema.createArray(Schema.create(Type.STRING)), charset);
|
||||||
|
|
Loading…
Reference in New Issue