| HashJoinNode(PlanNodeId, PlanNode, PlanNode, TableRefInfo, List, List) |   | 0% |   | 0% | 14 | 14 | 27 | 27 | 1 | 1 | 
| getNodeExplainString(String, TExplainLevel) |    | 80% |    | 68% | 9 | 17 | 10 | 48 | 0 | 1 | 
| eqJoinConjunctsDebugString() |   | 0% |   | 0% | 2 | 2 | 5 | 5 | 1 | 1 | 
| debugString() |   | 0% |  | n/a | 1 | 1 | 2 | 2 | 1 | 1 | 
| HashJoinNode(PlanNodeId, PlanNode, PlanNode, JoinOperator, List, List, List, List, TupleDescriptor, TupleDescriptor, boolean) |   | 99% |    | 85% | 4 | 15 | 0 | 41 | 0 | 1 | 
| toThrift(TPlanNode) |   | 99% |    | 85% | 4 | 15 | 0 | 37 | 0 | 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 | 
| setMarkJoinConjuncts(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 |