[
https://issues.apache.org/jira/browse/CRUNCH-572?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=15663329#comment-15663329
]
Stefan De Smit commented on CRUNCH-572:
---------------------------------------
We have a similar problem, where we used Pair.getPairSchema() in our own code
(so, outside of PTableType)
Isn't the problem that Pair.makePairSchema always uses the same name "Pair" for
different schema's (as there's a cache for same key/value schema) instead of
generating a new name similar to Avros.createTupleSchema
> Avro schema error in Avros.tableOf() can't redefine
> org.apache.avro.mapred.Pair
> -------------------------------------------------------------------------------
>
> Key: CRUNCH-572
> URL: https://issues.apache.org/jira/browse/CRUNCH-572
> Project: Crunch
> Issue Type: Bug
> Affects Versions: 0.13.0
> Reporter: Adric Eckstein
> Attachments: CRUNCH-572.patch
>
>
> The Avros.tableOf() method produces a record schema named
> "org.apache.avro.mapred.Pair", which cannot be unique across types, whereas
> the Avros.pairs() method similarly creates a record schema, but calls
> Avros.createTupleSchema() which creates a unique name at every call.
> Example that fails on constructing schema:
> AvroType<Pair<String, String>> t1 = Avros.tableOf(Avros.strings(),
> Avros.strings());
> AvroType<Pair<String, Double>> t2 = Avros.tableOf(Avros.strings(),
> Avros.doubles());
> AvroType<Pair<Pair<String, String>, Pair<String, Double>>> t3 =
> Avros.pairs(t1, t2);
> System.out.println("schema: " + t3.getSchema().toString());
> Can the tableOf() method be updated to call the createTupleSchema() method
> instead of the avro pair constructor?
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)