| OlapScanNode.java |   | 48% |   | 40% | 193 | 266 | 388 | 772 | 31 | 73 | 0 | 1 |
| ScanNode.java |   | 27% |   | 20% | 134 | 172 | 259 | 358 | 24 | 49 | 2 | 3 |
| PlanNode.java |   | 57% |   | 52% | 87 | 185 | 181 | 441 | 24 | 81 | 0 | 1 |
| GroupCommitPlanner.java |  | 0% |  | 0% | 44 | 44 | 149 | 149 | 13 | 13 | 1 | 1 |
| OlapTableSink.java |   | 67% |   | 65% | 81 | 163 | 141 | 495 | 11 | 38 | 0 | 1 |
| PluginDrivenTableSink.java |  | 0% |  | 0% | 33 | 33 | 126 | 126 | 10 | 10 | 1 | 1 |
| HiveTableSink.java |  | 0% |  | 0% | 28 | 28 | 136 | 136 | 11 | 11 | 2 | 2 |
| RangePartitionPrunerV2.java |  | 0% |  | 0% | 51 | 51 | 122 | 122 | 16 | 16 | 2 | 2 |
| ListPartitionPrunerV2.java |   | 7% |  | 5% | 43 | 46 | 109 | 116 | 24 | 26 | 1 | 2 |
| TVFTableSink.java |  | 0% |  | 0% | 26 | 26 | 81 | 81 | 9 | 9 | 1 | 1 |
| DataPartition.java |   | 31% |   | 34% | 34 | 48 | 77 | 112 | 7 | 15 | 2 | 3 |
| IcebergMergeSink.java |  | 0% |  | 0% | 23 | 23 | 83 | 83 | 7 | 7 | 2 | 2 |
| PartitionPrunerV2Base.java |  | 4% |  | 0% | 32 | 33 | 85 | 92 | 18 | 19 | 2 | 3 |
| RuntimeFilter.java |   | 72% |   | 78% | 27 | 88 | 50 | 211 | 13 | 44 | 0 | 3 |
| BackendPartitionedSchemaScanNode.java |   | 20% |  | 6% | 14 | 16 | 57 | 75 | 6 | 8 | 0 | 1 |
| IcebergDeleteSink.java |  | 0% |  | 0% | 17 | 17 | 57 | 57 | 7 | 7 | 2 | 2 |
| AggregationNode.java |   | 55% |   | 59% | 17 | 32 | 54 | 122 | 7 | 16 | 0 | 1 |
| PartitionColumnFilter.java |   | 14% |  | 6% | 17 | 23 | 41 | 54 | 2 | 8 | 0 | 1 |
| SchemaScanNode.java |   | 47% |   | 46% | 18 | 28 | 36 | 82 | 7 | 13 | 0 | 1 |
| PartitionSortNode.java |   | 38% |   | 23% | 17 | 20 | 40 | 71 | 1 | 3 | 0 | 1 |
| BucketedAggregationNode.java |  | 0% |  | 0% | 10 | 10 | 36 | 36 | 4 | 4 | 1 | 1 |
| TableFunctionNode.java |   | 38% |   | 30% | 9 | 15 | 28 | 53 | 1 | 5 | 0 | 1 |
| IcebergTableSink.java |   | 55% |   | 30% | 21 | 28 | 34 | 87 | 1 | 7 | 0 | 2 |
| ResultFileSink.java |   | 37% |   | 43% | 15 | 20 | 29 | 56 | 8 | 12 | 0 | 1 |
| PlanFragment.java |   | 77% |   | 63% | 31 | 94 | 40 | 182 | 8 | 52 | 0 | 1 |
| HashJoinNode.java |   | 78% |   | 63% | 30 | 60 | 23 | 142 | 1 | 15 | 0 | 1 |
| MaxComputeTableSink.java |  | 0% |  | 0% | 14 | 14 | 37 | 37 | 6 | 6 | 1 | 1 |
| SetOperationNode.java |   | 62% |   | 52% | 17 | 32 | 25 | 82 | 6 | 14 | 0 | 1 |
| SortNode.java |   | 73% |   | 55% | 28 | 45 | 29 | 109 | 4 | 15 | 0 | 1 |
| NestedLoopJoinNode.java |   | 66% |   | 44% | 23 | 36 | 16 | 62 | 1 | 8 | 0 | 1 |
| RecursiveCteNode.java |  | 0% | | 0% | 9 | 9 | 27 | 27 | 8 | 8 | 1 | 1 |
| MaterializationNode.java |   | 64% |  | 70% | 3 | 16 | 17 | 67 | 1 | 11 | 0 | 1 |
| RepeatNode.java |   | 40% |  | 0% | 5 | 8 | 16 | 29 | 3 | 6 | 0 | 1 |
| DataGenScanNode.java |   | 48% |  | 16% | 9 | 15 | 19 | 44 | 4 | 9 | 0 | 1 |
| BaseExternalTableDataSink.java |   | 33% |   | 28% | 20 | 24 | 26 | 42 | 4 | 8 | 0 | 1 |
| PartitionPruneV2ForShortCircuitPlan.java |  | 13% |  | 0% | 9 | 11 | 21 | 26 | 6 | 8 | 0 | 1 |
| ColumnRange.java |  | 0% |  | 0% | 17 | 17 | 24 | 24 | 10 | 10 | 1 | 1 |
| RangeMap.java |  | 12% |  | 0% | 10 | 11 | 17 | 19 | 4 | 5 | 1 | 2 |
| MysqlTableSink.java |  | 0% | | n/a | 5 | 5 | 18 | 18 | 5 | 5 | 1 | 1 |
| RecursiveCteScanNode.java |  | 0% | | 0% | 7 | 7 | 18 | 18 | 6 | 6 | 1 | 1 |
| Planner.java |   | 55% |   | 66% | 9 | 18 | 23 | 46 | 4 | 9 | 0 | 1 |
| GroupCommitBlockSink.java |  | 18% |   | 50% | 8 | 9 | 18 | 23 | 4 | 5 | 0 | 1 |
| RemoteOlapTableSink.java |  | 0% |  | 0% | 7 | 7 | 16 | 16 | 5 | 5 | 1 | 1 |
| ColumnBound.java |  | 0% |  | 0% | 10 | 10 | 16 | 16 | 7 | 7 | 1 | 1 |
| JoinNodeBase.java |   | 52% |  | 11% | 6 | 12 | 8 | 19 | 1 | 7 | 0 | 1 |
| ResultSink.java |   | 61% |  | 33% | 7 | 10 | 11 | 29 | 4 | 7 | 0 | 1 |
| DictionarySink.java |   | 78% |  | 100% | 3 | 12 | 7 | 43 | 3 | 9 | 0 | 1 |
| AssertNumRowsNode.java |   | 60% |  | 0% | 3 | 7 | 8 | 24 | 1 | 5 | 0 | 1 |
| BlackholeSink.java |  | 0% | | n/a | 5 | 5 | 12 | 12 | 5 | 5 | 1 | 1 |
| GroupCommitScanNode.java |  | 0% | | n/a | 6 | 6 | 12 | 12 | 6 | 6 | 1 | 1 |
| DataStreamSink.java |   | 92% |   | 86% | 8 | 46 | 8 | 105 | 2 | 24 | 0 | 1 |
| AnalyticEvalNode.java |   | 90% |   | 53% | 12 | 21 | 4 | 67 | 0 | 6 | 0 | 1 |
| SelectNode.java | | 46% |  | 0% | 3 | 6 | 6 | 12 | 1 | 4 | 0 | 1 |
| HashDistributionPruner.java |  | 90% |   | 75% | 7 | 20 | 5 | 53 | 0 | 4 | 0 | 1 |
| TabletLoadIndexRecorderMgr.java |  | 82% |  | 33% | 5 | 12 | 3 | 30 | 2 | 9 | 0 | 2 |
| DistributionMode.java |  | 79% | | 60% | 2 | 8 | 3 | 16 | 0 | 4 | 0 | 1 |
| FileLoadScanNode.java |  | 92% |   | 66% | 6 | 11 | 4 | 34 | 2 | 5 | 1 | 2 |
| PlanFragmentId.java | | 66% | | n/a | 1 | 5 | 1 | 5 | 1 | 5 | 0 | 2 |
| DataSink.java | | 70% | | n/a | 2 | 5 | 2 | 8 | 2 | 5 | 0 | 1 |
| MultiCastDataSink.java |  | 94% | | 100% | 1 | 9 | 1 | 21 | 1 | 8 | 0 | 1 |
| CTEScanNode.java | | 85% | | n/a | 3 | 6 | 3 | 8 | 3 | 6 | 0 | 1 |
| ScanContext.java |  | 96% |  | 66% | 2 | 10 | 0 | 13 | 0 | 7 | 0 | 2 |
| EmptySetNode.java | | 95% | | 50% | 1 | 4 | 0 | 7 | 0 | 3 | 0 | 1 |
| ExchangeNode.java |  | 100% |  | 90% | 2 | 23 | 0 | 41 | 0 | 13 | 0 | 1 |
| MultiCastPlanFragment.java |  | 100% | | n/a | 0 | 4 | 0 | 11 | 0 | 4 | 0 | 1 |
| RuntimeFilterId.java |  | 100% | | n/a | 0 | 6 | 0 | 6 | 0 | 6 | 0 | 2 |
| PlanNodeId.java |  | 100% | | n/a | 0 | 5 | 0 | 5 | 0 | 5 | 0 | 2 |
| UnionNode.java | | 100% | | n/a | 0 | 3 | 0 | 5 | 0 | 3 | 0 | 1 |
| IntersectNode.java | | 100% | | n/a | 0 | 2 | 0 | 4 | 0 | 2 | 0 | 1 |
| ExceptNode.java | | 100% | | n/a | 0 | 2 | 0 | 4 | 0 | 2 | 0 | 1 |