Zoltan Farkas created AVRO-2278:
-----------------------------------

             Summary: GenericData.Record field getter no correct
                 Key: AVRO-2278
                 URL: https://issues.apache.org/jira/browse/AVRO-2278
             Project: Apache Avro
          Issue Type: Bug
    Affects Versions: 1.8.2
            Reporter: Zoltan Farkas


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
(v7.6.3#76005)

Reply via email to