Skip to content

Commit

Permalink
KYLIN-3265 Add jobSearchMode as a filter condition for jobs api
Browse files Browse the repository at this point in the history
Signed-off-by: shaofengshi <shaofengshi@apache.org>
  • Loading branch information
shaofengshi authored and yiming187 committed Feb 28, 2018
1 parent 2b38b3b commit 76934db
Show file tree
Hide file tree
Showing 4 changed files with 50 additions and 34 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,6 @@

import java.io.IOException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
Expand Down Expand Up @@ -60,7 +59,7 @@ public class JobController extends BasicController {
@ResponseBody
public List<JobInstance> list(JobListRequest jobRequest) {

List<JobInstance> jobInstanceList = Collections.emptyList();
List<JobInstance> jobInstanceList;
List<JobStatusEnum> statusList = new ArrayList<JobStatusEnum>();

if (null != jobRequest.getStatus()) {
Expand All @@ -74,9 +73,18 @@ public List<JobInstance> list(JobListRequest jobRequest) {
timeFilter = JobTimeFilterEnum.getByCode(jobRequest.getTimeFilter());
}

JobService.JobSearchMode jobSearchMode = JobService.JobSearchMode.CUBING_ONLY;
if (null != jobRequest.getJobSearchMode()) {
try {
jobSearchMode = JobService.JobSearchMode.valueOf(jobRequest.getJobSearchMode());
} catch (IllegalArgumentException e) {
logger.error("Invalid value for JobSearchMode: '" + jobRequest.getJobSearchMode() + "', skip it.", e);
}
}

try {
jobInstanceList = jobService.searchJobs(jobRequest.getCubeName(), jobRequest.getProjectName(), statusList,
jobRequest.getLimit(), jobRequest.getOffset(), timeFilter);
jobRequest.getLimit(), jobRequest.getOffset(), timeFilter, jobSearchMode);
} catch (Exception e) {
logger.error(e.getLocalizedMessage(), e);
throw new InternalErrorException(e);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ public class JobListRequest {
private Integer offset;
private Integer limit;
private Integer timeFilter;
private String jobSearchMode;

public JobListRequest() {
}
Expand Down Expand Up @@ -83,4 +84,13 @@ public Integer getTimeFilter() {
public void setTimeFilter(Integer timeFilter) {
this.timeFilter = timeFilter;
}

public String getJobSearchMode() {
return jobSearchMode;
}

public void setJobSearchMode(String jobSearchMode) {
this.jobSearchMode = jobSearchMode;
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -18,18 +18,12 @@

package org.apache.kylin.rest.service;

import java.io.IOException;
import java.util.Calendar;
import java.util.Collections;
import java.util.Date;
import java.util.EnumSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.TimeZone;

import javax.annotation.Nullable;

import com.google.common.base.Function;
import com.google.common.base.Predicate;
import com.google.common.base.Predicates;
import com.google.common.collect.FluentIterable;
import com.google.common.collect.Lists;
import com.google.common.collect.Sets;
import org.apache.commons.lang3.StringUtils;
import org.apache.directory.api.util.Strings;
import org.apache.kylin.common.KylinConfig;
Expand Down Expand Up @@ -78,12 +72,16 @@
import org.springframework.security.core.context.SecurityContextHolder;
import org.springframework.stereotype.Component;

import com.google.common.base.Function;
import com.google.common.base.Predicate;
import com.google.common.base.Predicates;
import com.google.common.collect.FluentIterable;
import com.google.common.collect.Lists;
import com.google.common.collect.Sets;
import javax.annotation.Nullable;
import java.io.IOException;
import java.util.Calendar;
import java.util.Collections;
import java.util.Date;
import java.util.EnumSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.TimeZone;

/**
* @author ysong1
Expand Down Expand Up @@ -633,10 +631,10 @@ public void dropJob(JobInstance job) {
*/
public List<JobInstance> searchJobs(final String cubeNameSubstring, final String projectName,
final List<JobStatusEnum> statusList, final Integer limitValue, final Integer offsetValue,
final JobTimeFilterEnum timeFilter) {
final JobTimeFilterEnum timeFilter, JobSearchMode jobSearchMode) {
Integer limit = (null == limitValue) ? 30 : limitValue;
Integer offset = (null == offsetValue) ? 0 : offsetValue;
List<JobInstance> jobs = searchJobsByCubeName(cubeNameSubstring, projectName, statusList, timeFilter);
List<JobInstance> jobs = searchJobsByCubeName(cubeNameSubstring, projectName, statusList, timeFilter, jobSearchMode);

Collections.sort(jobs);

Expand All @@ -653,11 +651,11 @@ public List<JobInstance> searchJobs(final String cubeNameSubstring, final String

public List<JobInstance> searchJobsByCubeName(final String cubeNameSubstring, final String projectName,
final List<JobStatusEnum> statusList, final JobTimeFilterEnum timeFilter) {
return searchJobsByCubeName(cubeNameSubstring, projectName, statusList, timeFilter, JobSearchMode.ALL);
return searchJobsByCubeName(cubeNameSubstring, projectName, statusList, timeFilter, JobSearchMode.CUBING_ONLY);
}

public List<JobInstance> searchJobsByCubeName(final String cubeNameSubstring, final String projectName,
final List<JobStatusEnum> statusList, final JobTimeFilterEnum timeFilter, JobSearchMode jobSearchMode) {
final List<JobStatusEnum> statusList, final JobTimeFilterEnum timeFilter, final JobSearchMode jobSearchMode) {
return innerSearchJobs(cubeNameSubstring, null, projectName, statusList, timeFilter, jobSearchMode);
}

Expand All @@ -675,16 +673,16 @@ public List<JobInstance> innerSearchJobs(final String cubeName, final String job
final List<JobStatusEnum> statusList, final JobTimeFilterEnum timeFilter, JobSearchMode jobSearchMode) {
List<JobInstance> result = Lists.newArrayList();
switch (jobSearchMode) {
case CUBING_ONLY:
case ALL:
result.addAll(innerSearchCubingJobs(cubeName, jobName, projectName, statusList, timeFilter));
result.addAll(innerSearchCheckpointJobs(cubeName, jobName, projectName, statusList, timeFilter));
break;
case CHECKPOINT_ONLY:
result.addAll(innerSearchCheckpointJobs(cubeName, jobName, projectName, statusList, timeFilter));
break;
case ALL:
case CUBING_ONLY:
default:
result.addAll(innerSearchCubingJobs(cubeName, jobName, projectName, statusList, timeFilter));
result.addAll(innerSearchCheckpointJobs(cubeName, jobName, projectName, statusList, timeFilter));
}
return result;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,11 +18,6 @@

package org.apache.kylin.rest.service;

import java.io.IOException;
import java.sql.SQLException;
import java.util.Collections;
import java.util.List;

import org.apache.kylin.engine.mr.CubingJob;
import org.apache.kylin.job.constant.JobTimeFilterEnum;
import org.apache.kylin.job.exception.ExecuteException;
Expand All @@ -40,6 +35,11 @@
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;

import java.io.IOException;
import java.sql.SQLException;
import java.util.Collections;
import java.util.List;

/**
* @author xduo
*/
Expand All @@ -60,7 +60,7 @@ public void testBasics() throws JobException, IOException, SQLException {
Assert.assertNotNull(jobService.getDataModelManager());
Assert.assertNotNull(QueryConnection.getConnection(ProjectInstance.DEFAULT_PROJECT_NAME));
Assert.assertNull(jobService.getJobInstance("job_not_exist"));
Assert.assertNotNull(jobService.searchJobs(null, null, null, 0, 0, JobTimeFilterEnum.ALL));
Assert.assertNotNull(jobService.searchJobs(null, null, null, 0, 0, JobTimeFilterEnum.ALL, JobService.JobSearchMode.ALL));
}

@Test
Expand Down

0 comments on commit 76934db

Please sign in to comment.