Huang Xingbo created FLINK-25622:
------------------------------------

             Summary: Throws NPE in Python UDTF
                 Key: FLINK-25622
                 URL: https://issues.apache.org/jira/browse/FLINK-25622
             Project: Flink
          Issue Type: Bug
          Components: API / Python
    Affects Versions: 1.14.3
            Reporter: Huang Xingbo


The failed case is

{code:python}
// Some comments here
       source_table = """
            CREATE TABLE ad_track_android_source (
              `Rows` ARRAY<ROW<`id` INT, `ad_channel` INT, `imei` 
VARCHAR(2147483647), `imei_hash` VARCHAR(2147483647), `android_id` 
VARCHAR(2147483647), `android_id_hash` VARCHAR(2147483647), `oaid` 
VARCHAR(2147483647), `callback` VARCHAR(2147483647), `create_time` 
VARCHAR(2147483647), `init_time` VARCHAR(2147483647), `ext` 
VARCHAR(2147483647)>>,
              `id` AS CAST(`Rows`[CASE WHEN `Rows`[2].`id` > 0 THEN 2 ELSE 1 
END].`id` AS INTEGER)
            ) WITH (
                'connector' = 'datagen'
            )
        """
        self.t_env.execute_sql(source_table)

        @udf(result_type=DataTypes.INT())
        def ug(id):
            return id

        self.t_env.create_temporary_function("ug", ug)
        res = self.t_env.sql_query(
            "select id ,ug(cast(id as int)) as s from `ad_track_android_source` 
where id>0")
        print(res.to_pandas())
{code}

The traceback is 

{code:java}
E                   : java.lang.NullPointerException
E                       at 
org.apache.calcite.rex.RexFieldAccess.checkValid(RexFieldAccess.java:74)
E                       at 
org.apache.calcite.rex.RexFieldAccess.<init>(RexFieldAccess.java:62)
E                       at 
org.apache.calcite.rex.RexShuttle.visitFieldAccess(RexShuttle.java:205)
E                       at 
org.apache.calcite.rex.RexProgramBuilder$RegisterShuttle.visitFieldAccess(RexProgramBuilder.java:904)
E                       at 
org.apache.calcite.rex.RexProgramBuilder$RegisterShuttle.visitFieldAccess(RexProgramBuilder.java:887)
E                       at 
org.apache.calcite.rex.RexFieldAccess.accept(RexFieldAccess.java:92)
E                       at 
org.apache.calcite.rex.RexProgramBuilder.registerInput(RexProgramBuilder.java:295)
E                       at 
org.apache.calcite.rex.RexProgramBuilder.addProject(RexProgramBuilder.java:206)
E                       at 
org.apache.calcite.rex.RexProgram.create(RexProgram.java:224)
E                       at 
org.apache.flink.table.planner.plan.rules.logical.PythonCalcSplitRuleBase.onMatch(PythonCalcSplitRule.scala:84)
E                       at 
org.apache.calcite.plan.AbstractRelOptPlanner.fireRule(AbstractRelOptPlanner.java:333)
E                       at 
org.apache.calcite.plan.hep.HepPlanner.applyRule(HepPlanner.java:542)
E                       at 
org.apache.calcite.plan.hep.HepPlanner.applyRules(HepPlanner.java:407)
E                       at 
org.apache.calcite.plan.hep.HepPlanner.executeInstruction(HepPlanner.java:243)
E                       at 
org.apache.calcite.plan.hep.HepInstruction$RuleInstance.execute(HepInstruction.java:127)
E                       at 
org.apache.calcite.plan.hep.HepPlanner.executeProgram(HepPlanner.java:202)
E                       at 
org.apache.calcite.plan.hep.HepPlanner.findBestExp(HepPlanner.java:189)
E                       at 
org.apache.flink.table.planner.plan.optimize.program.FlinkHepProgram.optimize(FlinkHepProgram.scala:69)
E                       at 
org.apache.flink.table.planner.plan.optimize.program.FlinkHepRuleSetProgram.optimize(FlinkHepRuleSetProgram.scala:87)
E                       at 
org.apache.flink.table.planner.plan.optimize.program.FlinkChainedProgram.$anonfun$optimize$1(FlinkChainedProgram.scala:62)
E                       at 
scala.collection.TraversableOnce.$anonfun$foldLeft$1(TraversableOnce.scala:156)
E                       at 
scala.collection.TraversableOnce.$anonfun$foldLeft$1$adapted(TraversableOnce.scala:156)
E                       at scala.collection.Iterator.foreach(Iterator.scala:937)
E                       at 
scala.collection.Iterator.foreach$(Iterator.scala:937)
E                       at 
scala.collection.AbstractIterator.foreach(Iterator.scala:1425)
E                       at 
scala.collection.IterableLike.foreach(IterableLike.scala:70)
E                       at 
scala.collection.IterableLike.foreach$(IterableLike.scala:69)
E                       at 
scala.collection.AbstractIterable.foreach(Iterable.scala:54)
E                       at 
scala.collection.TraversableOnce.foldLeft(TraversableOnce.scala:156)
E                       at 
scala.collection.TraversableOnce.foldLeft$(TraversableOnce.scala:154)
E                       at 
scala.collection.AbstractTraversable.foldLeft(Traversable.scala:104)
E                       at 
org.apache.flink.table.planner.plan.optimize.program.FlinkChainedProgram.optimize(FlinkChainedProgram.scala:58)
E                       at 
org.apache.flink.table.planner.plan.optimize.StreamCommonSubGraphBasedOptimizer.optimizeTree(StreamCommonSubGraphBasedOptimizer.scala:165)
E                       at 
org.apache.flink.table.planner.plan.optimize.StreamCommonSubGraphBasedOptimizer.doOptimize(StreamCommonSubGraphBasedOptimizer.scala:83)
E                       at 
org.apache.flink.table.planner.plan.optimize.CommonSubGraphBasedOptimizer.optimize(CommonSubGraphBasedOptimizer.scala:77)
E                       at 
org.apache.flink.table.planner.delegation.PlannerBase.optimize(PlannerBase.scala:309)
E                       at 
org.apache.flink.table.planner.delegation.PlannerBase.translate(PlannerBase.scala:187)
E                       at 
org.apache.flink.table.api.internal.TableEnvironmentImpl.translate(TableEnvironmentImpl.java:1630)
E                       at 
org.apache.flink.table.api.internal.TableEnvironmentImpl.executeQueryOperation(TableEnvironmentImpl.java:805)
E                       at 
org.apache.flink.table.api.internal.TableEnvironmentImpl.executeInternal(TableEnvironmentImpl.java:1313)
E                       at 
org.apache.flink.table.api.internal.TableImpl.execute(TableImpl.java:602)
E                       at 
org.apache.flink.table.runtime.arrow.ArrowUtils.collectAsPandasDataFrame(ArrowUtils.java:488)
E                       at sun.reflect.NativeMethodAccessorImpl.invoke0(Native 
Method)
E                       at 
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
E                       at 
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
E                       at java.lang.reflect.Method.invoke(Method.java:498)
E                       at 
org.apache.flink.api.python.shaded.py4j.reflection.MethodInvoker.invoke(MethodInvoker.java:244)
E                       at 
org.apache.flink.api.python.shaded.py4j.reflection.ReflectionEngine.invoke(ReflectionEngine.java:357)
E                       at 
org.apache.flink.api.python.shaded.py4j.Gateway.invoke(Gateway.java:282)
E                       at 
org.apache.flink.api.python.shaded.py4j.commands.AbstractCommand.invokeMethod(AbstractCommand.java:132)
E                       at 
org.apache.flink.api.python.shaded.py4j.commands.CallCommand.execute(CallCommand.java:79)
E                       at 
org.apache.flink.api.python.shaded.py4j.GatewayConnection.run(GatewayConnection.java:238)
E                       at java.lang.Thread.run(Thread.java:748)
{code}





--
This message was sent by Atlassian Jira
(v8.20.1#820001)

Reply via email to