Wang Yanlin created CALCITE-3583:
------------------------------------

             Summary: Support serialized to json and deserialized from json for 
Exchange relation operator
                 Key: CALCITE-3583
                 URL: https://issues.apache.org/jira/browse/CALCITE-3583
             Project: Calcite
          Issue Type: Improvement
            Reporter: Wang Yanlin


Currently, serialize Exchange relnode to json  will cause exception

{code:java}
// RelWriterTest
@Test public void testExchange() {
    final FrameworkConfig config = RelBuilderTest.config().build();
    final RelBuilder builder = RelBuilder.create(config);
    final RelNode rel = builder
        .scan("EMP")
        .exchange(RelDistributions.hash(ImmutableList.of(0, 1)))
        .build();
    String relJson = RelOptUtil.dumpPlan("", rel,
        SqlExplainFormat.JSON, SqlExplainLevel.EXPPLAN_ATTRIBUTES);
    String s = deserializeAndDumpToTextFormat(getSchema(rel), relJson);
    final String expected = ""
        + "LogicalExchange(distribution=[hash[0, 1]])\n"
        + "  LogicalTableScan(table=[[scott, EMP]])\n";
    assertThat(s, isLinux(expected));
  }
{code}

got


{code:java}
java.lang.UnsupportedOperationException: type not serializable: hash[0, 1] 
(type org.apache.calcite.rel.RelDistributions.RelDistributionImpl)

        at org.apache.calcite.rel.externalize.RelJson.toJson(RelJson.java:290)
        at 
org.apache.calcite.rel.externalize.RelJsonWriter.put(RelJsonWriter.java:83)
        at 
org.apache.calcite.rel.externalize.RelJsonWriter.explain_(RelJsonWriter.java:66)
        at 
org.apache.calcite.rel.externalize.RelJsonWriter.done(RelJsonWriter.java:128)
        at 
org.apache.calcite.rel.AbstractRelNode.explain(AbstractRelNode.java:299)
        at org.apache.calcite.plan.RelOptUtil.dumpPlan(RelOptUtil.java:1981)
        at 
org.apache.calcite.plan.RelWriterTest.testExchange(RelWriterTest.java:772)
{code}





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

Reply via email to