[
https://issues.apache.org/jira/browse/NIFI-14897?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=18018269#comment-18018269
]
ASF subversion and git services commented on NIFI-14897:
--------------------------------------------------------
Commit bf03af26d65d4be9c6d7f1302acd71afdb51175d in nifi's branch
refs/heads/main from Pierre Villard
[ https://gitbox.apache.org/repos/asf?p=nifi.git;h=bf03af26d6 ]
NIFI-14897 Fixed Avro FIXED serialization to use GenericFixed (#10266)
Signed-off-by: David Handermann <[email protected]>
> org.apache.nifi.serialization.RecordSetWriter does not support the Avro Fixed
> type
> ----------------------------------------------------------------------------------
>
> Key: NIFI-14897
> URL: https://issues.apache.org/jira/browse/NIFI-14897
> Project: Apache NiFi
> Issue Type: Bug
> Components: Extensions
> Affects Versions: 2.5.0
> Reporter: Christiaan Biesterbosch
> Assignee: Pierre Villard
> Priority: Major
> Time Spent: 20m
> Remaining Estimate: 0h
>
> See this commit for a failing test:
> https://github.com/apache/nifi/commit/b11eb5912e651e0cbe5bc32c9b228c58071b477a
>
> The problem seems to be that the Avro library expects something implementing
> `GenericFixed` for the Fixed type, but `RecordSetWriter` creates a
> `java.nio.HeapByteBuffer`.
> {{A workaround is using the Avro Bytes type, but that doesn't work with
> `"logicalType": "uuid"`.}}
> {{-------------------------------------------------------------------------------}}
> {{Test set: org.apache.nifi.avro.TestWriteAvroResultWithSchema}}
> {{-------------------------------------------------------------------------------}}
> {{Tests run: 7, Failures: 0, Errors: 1, Skipped: 0, Time elapsed: 0.096 s <<<
> FAILURE! – in org.apache.nifi.avro.TestWriteAvroResultWithSchema}}
> {{org.apache.nifi.avro.TestWriteAvroResultWithSchema.testDataTypes – Time
> elapsed: 0.003 s <<< ERROR!}}
> {{org.apache.avro.file.DataFileWriter$AppendWriteException:
> java.lang.ClassCastException: value java.nio.HeapByteBuffer[pos=0 lim=16
> cap=16] (a java.nio.HeapByteBuffer) cannot be cast to expected type fixed16
> at data_types.fixed}}
> {{at org.apache.avro.file.DataFileWriter.append(DataFileWriter.java:326)}}
> {{at
> org.apache.nifi.avro.WriteAvroResultWithSchema.writeRecord(WriteAvroResultWithSchema.java:61)}}
> {{at
> org.apache.nifi.serialization.AbstractRecordSetWriter.write(AbstractRecordSetWriter.java:59)}}
> {{at
> org.apache.nifi.serialization.AbstractRecordSetWriter.write(AbstractRecordSetWriter.java:52)}}
> {{at
> org.apache.nifi.avro.TestWriteAvroResult.testDataTypes(TestWriteAvroResult.java:316)}}
> {{at java.base/java.lang.reflect.Method.invoke(Method.java:565)}}
> {{at java.base/java.util.ArrayList.forEach(ArrayList.java:1604)}}
> {{at java.base/java.util.ArrayList.forEach(ArrayList.java:1604)}}
> {{Caused by: java.lang.ClassCastException: value
> java.nio.HeapByteBuffer[pos=0 lim=16 cap=16] (a java.nio.HeapByteBuffer)
> cannot be cast to expected type fixed16 at data_types.fixed}}
> {{at
> org.apache.avro.path.TracingClassCastException.summarize(TracingClassCastException.java:79)}}
> {{at
> org.apache.avro.path.TracingClassCastException.summarize(TracingClassCastException.java:30)}}
> {{at
> org.apache.avro.generic.GenericDatumWriter.write(GenericDatumWriter.java:84)}}
> {{at org.apache.avro.file.DataFileWriter.append(DataFileWriter.java:323)}}
> {{... 7 more}}
> {{Caused by: java.lang.ClassCastException: class java.nio.HeapByteBuffer
> cannot be cast to class org.apache.avro.generic.GenericFixed
> (java.nio.HeapByteBuffer is in module java.base of loader 'bootstrap';
> org.apache.avro.generic.GenericFixed is in unnamed module of loader 'app')}}
> {{at
> org.apache.avro.generic.GenericDatumWriter.writeFixed(GenericDatumWriter.java:408)}}
> {{at
> org.apache.avro.generic.GenericDatumWriter.writeWithoutConversion(GenericDatumWriter.java:162)}}
> {{at
> org.apache.avro.generic.GenericDatumWriter.write(GenericDatumWriter.java:95)}}
> {{at
> org.apache.avro.generic.GenericDatumWriter.writeField(GenericDatumWriter.java:245)}}
> {{at
> org.apache.avro.generic.GenericDatumWriter.writeRecord(GenericDatumWriter.java:234)}}
> {{at
> org.apache.avro.generic.GenericDatumWriter.writeWithoutConversion(GenericDatumWriter.java:145)}}
> {{at
> org.apache.avro.generic.GenericDatumWriter.write(GenericDatumWriter.java:95)}}
> {{at
> org.apache.avro.generic.GenericDatumWriter.write(GenericDatumWriter.java:82)}}
> {{... 8 more}}
--
This message was sent by Atlassian Jira
(v8.20.10#820010)