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