[prev in list] [next in list] [prev in thread] [next in thread] 

List:       avro-dev
Subject:    [jira] [Assigned] (AVRO-2278) GenericData.Record field getter not correct
From:       "Zoltan Farkas (Jira)" <jira () apache ! org>
Date:       2020-04-28 13:08:00
Message-ID: JIRA.13200939.1543349157000.58513.1588079280194 () Atlassian ! JIRA
[Download RAW message or body]


     [ https://issues.apache.org/jira/browse/AVRO-2278?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel \
]

Zoltan Farkas reassigned AVRO-2278:
-----------------------------------

    Assignee: Zoltan Farkas

> GenericData.Record field getter not correct
> -------------------------------------------
> 
> Key: AVRO-2278
> URL: https://issues.apache.org/jira/browse/AVRO-2278
> Project: Apache Avro
> Issue Type: Bug
> Components: java
> Affects Versions: 1.8.2
> Reporter: Zoltan Farkas
> Assignee: Zoltan Farkas
> Priority: Major
> 
> Currently the get field implementation is not correct in GenericData.Record:
> at: https://github.com/apache/avro/blob/master/lang/java/avro/src/main/java/org/apache/avro/generic/GenericData.java#L209
>  {code}
> @Override public Object get(String key) {
> Field field = schema.getField(key);
> if (field == null) return null;
> return values[field.pos()];
> }
> {code}
> The method returns null when a field is not present, making it impossible to \
> distinguish between: field value = null
> and
> field does not exist.
> A more "correct" implementation would be:
> {code}
> @Override public Object get(String key) {
> Field field = schema.getField(key);
> if (field == null) {
> throw new IllegalArgumentException("Invalid field " + key);
> }
> return values[field.pos()];
> }
> {code}
> this will make the behavior consistent with put which will throw a exception when \
> setting a non existent field. when I make this change in my fork, some bugs in unit \
> tests showed up....



--
This message was sent by Atlassian Jira
(v8.3.4#803005)


[prev in list] [next in list] [prev in thread] [next in thread] 

Configure | About | News | Add a list | Sponsored by KoreLogic