/** * Copyright (C) 2014-2016 LinkedIn Corp. (pinot-core@linkedin.com) * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.linkedin.pinot.query.planner; import com.linkedin.pinot.common.segment.SegmentMetadata; import com.linkedin.pinot.core.common.DataSource; import com.linkedin.pinot.core.indexsegment.IndexSegment; import com.linkedin.pinot.core.indexsegment.IndexType; import com.linkedin.pinot.core.query.planner.FixedNumJobsQueryPlannerImpl; import com.linkedin.pinot.core.query.planner.FixedNumOfSegmentsPerJobQueryPlannerImpl; import com.linkedin.pinot.core.query.planner.JobVertex; import com.linkedin.pinot.core.query.planner.ParallelQueryPlannerImpl; import com.linkedin.pinot.core.query.planner.QueryPlan; import com.linkedin.pinot.core.query.planner.QueryPlanner; import com.linkedin.pinot.core.query.planner.SequentialQueryPlannerImpl; import com.linkedin.pinot.core.startree.StarTree; import java.util.ArrayList; import java.util.List; import org.testng.annotations.BeforeMethod; import org.testng.annotations.Test; import static org.testng.Assert.assertEquals; public class QueryPlannerTest { public List<IndexSegment> _indexSegmentList = null; public int _numOfSegmentDataManagers = 100; @BeforeMethod public void init() { _indexSegmentList = new ArrayList<IndexSegment>(); for (int i = 0; i < _numOfSegmentDataManagers; ++i) { _indexSegmentList.add(new IndexSegment() { @Override public String getSegmentName() { // TODO Auto-generated method stub return null; } @Override public SegmentMetadata getSegmentMetadata() { // TODO Auto-generated method stub return null; } @Override public IndexType getIndexType() { // TODO Auto-generated method stub return null; } @Override public DataSource getDataSource(String columnName) { // TODO Auto-generated method stub return null; } @Override public String getAssociatedDirectory() { // TODO Auto-generated method stub return null; } @Override public String[] getColumnNames() { // TODO Auto-generated method stub return null; } @Override public void destroy() { // TODO Auto-generated method stub } @Override public StarTree getStarTree() { return null; } @Override public long getDiskSizeBytes() { return 0; } }); } } @Test public void testParallelQueryPlanner() { final QueryPlanner queryPlanner = new ParallelQueryPlannerImpl(); final QueryPlan plan = queryPlanner.computeQueryPlan(null, _indexSegmentList); final List<JobVertex> roots = plan.getVirtualRoot().getSuccessors(); assertEquals(_numOfSegmentDataManagers, roots.size()); } @Test public void testSequentialQueryPlanner() { final QueryPlanner queryPlanner = new SequentialQueryPlannerImpl(); final QueryPlan plan = queryPlanner.computeQueryPlan(null, _indexSegmentList); final List<JobVertex> roots = plan.getVirtualRoot().getSuccessors(); assertEquals(1, roots.size()); assertEquals(_numOfSegmentDataManagers, roots.get(0).getIndexSegmentList().size()); } @Test public void testFixedJobsQueryPlanner() { for (int numJobs = 1; numJobs <= _numOfSegmentDataManagers; ++numJobs) { int totalSegments = 0; final QueryPlanner queryPlanner = new FixedNumJobsQueryPlannerImpl(numJobs); final QueryPlan plan = queryPlanner.computeQueryPlan(null, _indexSegmentList); final List<JobVertex> roots = plan.getVirtualRoot().getSuccessors(); assertEquals(roots.size(), numJobs); for (int i = numJobs - 1; i >= 0; --i) { totalSegments += roots.get(0).getIndexSegmentList().size(); roots.remove(0); assertEquals(roots.size(), i); } assertEquals(_numOfSegmentDataManagers, totalSegments); } } @Test public void testFixedSegmentsPerJobQueryPlanner() { for (int numSegment = 1; numSegment <= _numOfSegmentDataManagers; ++numSegment) { int totalSegments = 0; final int numJobs = (int) Math.ceil((double) _numOfSegmentDataManagers / (double) numSegment); final QueryPlanner queryPlanner = new FixedNumOfSegmentsPerJobQueryPlannerImpl(numSegment); final QueryPlan plan = queryPlanner.computeQueryPlan(null, _indexSegmentList); final List<JobVertex> roots = plan.getVirtualRoot().getSuccessors(); assertEquals(roots.size(), numJobs); for (int i = numJobs - 1; i >= 0; --i) { totalSegments += roots.get(0).getIndexSegmentList().size(); roots.remove(0); assertEquals(roots.size(), i); } assertEquals(_numOfSegmentDataManagers, totalSegments); } } }