/**
* 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);
}
}
}