| getNodeExplainString(String, TExplainLevel) |   | 72% |   | 62% | 11 | 17 | 13 | 48 | 0 | 1 |
| HashJoinNode(PlanNodeId, PlanNode, PlanNode, JoinOperator, List, List, List, boolean) |   | 84% |   | 67% | 9 | 15 | 4 | 38 | 0 | 1 |
| toThrift(TPlanNode) |   | 87% |   | 67% | 8 | 15 | 4 | 37 | 0 | 1 |
| setMarkJoinConjuncts(List) |  | 0% | | n/a | 1 | 1 | 2 | 2 | 1 | 1 |
| setColocate(boolean, String) |  | 100% | | n/a | 0 | 1 | 0 | 3 | 0 | 1 |
| addSlotIdToHashOutputSlotIds(SlotId) |  | 100% | | n/a | 0 | 1 | 0 | 2 | 0 | 1 |
| isBucketShuffle() |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |
| setDistributionMode(HashJoinNode.DistributionMode) |  | 100% | | n/a | 0 | 1 | 0 | 2 | 0 | 1 |
| setOtherJoinConjuncts(List) |  | 100% | | n/a | 0 | 1 | 0 | 2 | 0 | 1 |
| getEqJoinConjuncts() |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |
| getDistributionMode() |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |
| getHashOutputExprSlotIdMap() |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |
| getHashOutputSlotIds() |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |
| getOtherJoinConjuncts() |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |
| getMarkJoinConjuncts() |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |