| OlapScanNode.java |   | 52% |   | 43% | 181 | 270 | 353 | 780 | 32 | 77 | 0 | 1 | 
| OlapTableSink.java |   | 51% |   | 41% | 117 | 160 | 222 | 483 | 18 | 38 | 0 | 1 | 
| ScanNode.java |   | 38% |   | 25% | 134 | 169 | 206 | 348 | 15 | 42 | 0 | 3 | 
| GroupCommitPlanner.java |  | 0% |  | 0% | 44 | 44 | 149 | 149 | 13 | 13 | 1 | 1 | 
| RangePartitionPrunerV2.java |  | 0% |  | 0% | 51 | 51 | 122 | 122 | 16 | 16 | 2 | 2 | 
| HashJoinNode.java |   | 67% |   | 51% | 64 | 99 | 70 | 214 | 12 | 30 | 1 | 3 | 
| PartitionSortNode.java |  | 0% |  | 0% | 20 | 20 | 73 | 73 | 3 | 3 | 1 | 1 | 
| ListPartitionPrunerV2.java |   | 31% |   | 15% | 34 | 46 | 82 | 116 | 16 | 26 | 0 | 2 | 
| IcebergTableSink.java |  | 0% |  | 0% | 16 | 16 | 67 | 67 | 6 | 6 | 2 | 2 | 
| SchemaScanNode.java |   | 33% |   | 16% | 21 | 29 | 55 | 82 | 6 | 14 | 0 | 1 | 
| PlanNode.java |   | 86% |   | 75% | 52 | 179 | 62 | 423 | 21 | 90 | 0 | 1 | 
| MaterializationNode.java |   | 29% |  | 30% | 7 | 16 | 37 | 66 | 3 | 11 | 0 | 1 | 
| PlanFragment.java |   | 70% |   | 52% | 40 | 96 | 54 | 187 | 11 | 55 | 0 | 1 | 
| RuntimeFilter.java |   | 78% |   | 58% | 42 | 92 | 36 | 206 | 11 | 45 | 0 | 2 | 
| ResultFileSink.java |   | 37% |   | 33% | 19 | 22 | 44 | 69 | 10 | 13 | 0 | 1 | 
| DataGenScanNode.java |  | 0% |  | 0% | 14 | 14 | 43 | 43 | 9 | 9 | 1 | 1 | 
| DataStreamSink.java |   | 56% |   | 50% | 30 | 48 | 46 | 107 | 11 | 25 | 0 | 1 | 
| ExportSink.java |  | 0% |  | 0% | 9 | 9 | 35 | 35 | 6 | 6 | 1 | 1 | 
| DictionarySink.java |  | 0% |  | 0% | 12 | 12 | 43 | 43 | 9 | 9 | 1 | 1 | 
| SortNode.java |   | 69% |   | 52% | 34 | 58 | 39 | 136 | 6 | 21 | 0 | 1 | 
| SetOperationNode.java |   | 56% |   | 58% | 14 | 29 | 30 | 86 | 2 | 11 | 0 | 1 | 
| NestedLoopJoinNode.java |   | 62% |   | 55% | 26 | 39 | 28 | 80 | 4 | 11 | 0 | 1 | 
| PartitionColumnFilter.java |   | 38% |   | 16% | 16 | 23 | 33 | 54 | 1 | 8 | 0 | 1 | 
| FileLoadScanNode.java |  | 0% |  | 0% | 11 | 11 | 34 | 34 | 5 | 5 | 2 | 2 | 
| HiveTableSink.java |   | 71% |   | 38% | 14 | 25 | 33 | 124 | 2 | 11 | 0 | 2 | 
| PartitionPrunerV2Base.java |   | 58% |   | 37% | 18 | 33 | 42 | 92 | 5 | 19 | 0 | 3 | 
| AssertNumRowsNode.java |  | 0% |  | 0% | 8 | 8 | 30 | 30 | 5 | 5 | 1 | 1 | 
| AnalyticEvalNode.java |   | 72% |   | 47% | 15 | 23 | 24 | 93 | 1 | 6 | 0 | 1 | 
| BaseExternalTableDataSink.java |   | 25% |   | 16% | 20 | 23 | 29 | 40 | 5 | 8 | 0 | 1 | 
| PartitionPruneV2ForShortCircuitPlan.java |  | 13% |  | 0% | 9 | 11 | 21 | 26 | 6 | 8 | 0 | 1 | 
| RangeMap.java |  | 11% |  | 0% | 10 | 11 | 19 | 21 | 4 | 5 | 1 | 2 | 
| MysqlTableSink.java |  | 0% |  | n/a | 5 | 5 | 18 | 18 | 5 | 5 | 1 | 1 | 
| JoinCostEvaluation.java |   | 74% |   | 66% | 5 | 16 | 8 | 44 | 0 | 7 | 0 | 1 | 
| ColumnRange.java |  | 26% |  | 21% | 15 | 17 | 18 | 24 | 8 | 10 | 0 | 1 | 
| GroupCommitBlockSink.java |  | 18% |   | 50% | 8 | 9 | 18 | 23 | 4 | 5 | 0 | 1 | 
| AggregationNode.java |   | 87% |   | 87% | 7 | 34 | 12 | 126 | 3 | 18 | 0 | 1 | 
| JoinNodeBase.java |   | 67% |   | 42% | 10 | 18 | 10 | 38 | 1 | 8 | 0 | 1 | 
| HashDistributionPruner.java |   | 76% |   | 65% | 8 | 20 | 11 | 53 | 0 | 4 | 0 | 1 | 
| DataSink.java |  | 20% |  | 0% | 7 | 10 | 11 | 17 | 3 | 6 | 0 | 1 | 
| Planner.java |   | 70% |   | 77% | 7 | 18 | 18 | 46 | 3 | 9 | 0 | 1 | 
| ColumnBound.java |  | 25% |  | 0% | 7 | 10 | 11 | 16 | 4 | 7 | 0 | 1 | 
| TableFunctionNode.java |   | 81% |   | 72% | 5 | 13 | 6 | 47 | 0 | 4 | 0 | 1 | 
| ResultSink.java |   | 61% |  | 33% | 7 | 10 | 11 | 29 | 4 | 7 | 0 | 1 | 
| MultiCastDataSink.java |   | 55% |  | 0% | 4 | 9 | 8 | 21 | 3 | 8 | 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 | 
| TabletLoadIndexRecorderMgr.java |  | 82% |  | 33% | 5 | 12 | 3 | 30 | 2 | 9 | 0 | 2 | 
| ExchangeNode.java |  | 91% |   | 80% | 5 | 25 | 4 | 52 | 1 | 15 | 0 | 1 | 
| DataPartition.java |  | 89% |   | 56% | 11 | 24 | 1 | 35 | 1 | 9 | 0 | 1 | 
| BackendPartitionedSchemaScanNode.java |  | 94% |   | 75% | 4 | 16 | 2 | 70 | 0 | 8 | 0 | 1 | 
| RepeatNode.java |  | 93% |  | 50% | 3 | 9 | 3 | 32 | 1 | 7 | 0 | 1 | 
| SelectNode.java |  | 77% |  | 50% | 2 | 7 | 2 | 14 | 0 | 5 | 0 | 1 | 
| ExceptNode.java |  | 0% |  | n/a | 2 | 2 | 4 | 4 | 2 | 2 | 1 | 1 | 
| IntersectNode.java |  | 54% |  | n/a | 1 | 2 | 2 | 4 | 1 | 2 | 0 | 1 | 
| CTEScanNode.java |  | 80% |  | n/a | 3 | 6 | 3 | 8 | 3 | 6 | 0 | 1 | 
| MultiCastPlanFragment.java |  | 93% |  | n/a | 1 | 4 | 1 | 11 | 1 | 4 | 0 | 1 | 
| RuntimeFilterGenerator.java |  | 92% |  | n/a | 1 | 2 | 1 | 10 | 1 | 2 | 1 | 2 | 
| DistributedPlanColocateRule.java |  | 0% |  | n/a | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 
| PlannerContext.java |  | 0% |  | n/a | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 
| EmptySetNode.java |  | 95% |  | 50% | 1 | 4 | 0 | 7 | 0 | 3 | 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 | 
| PlanFragmentId.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 |