/**
* Copyright 2011 Intuit Inc. All Rights Reserved
*/
package com.intuit.tank.dao;
/*
* #%L
* Data Access
* %%
* Copyright (C) 2011 - 2015 Intuit Inc.
* %%
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
* #L%
*/
import java.util.ArrayList;
import java.util.List;
import com.intuit.tank.project.JobInstance;
import com.intuit.tank.vm.api.enumerated.JobQueueStatus;
/**
* JobInstance
*
* @author dangleton
*
*/
public class JobInstanceDao extends BaseDao<JobInstance> {
/**
* @param entityClass
*/
public JobInstanceDao() {
super();
setReloadEntities(true);
}
public List<JobInstance> getForStatus(List<JobQueueStatus> statuses) {
String prefix = "x";
NamedParameter parameter = new NamedParameter(JobInstance.PROPERTY_STATUS, "status", statuses);
StringBuilder sb = new StringBuilder();
sb.append(buildQlSelect(prefix)).append(startWhere()).append(buildWhereClause(Operation.IN, prefix, parameter));
return listWithJQL(sb.toString(), parameter);
}
public List<JobInstance> findCompleted() {
String prefix = "x";
NamedParameter startTimeParam = new NamedParameter(JobInstance.PROPERTY_START_TIME, "startTime", null);
NamedParameter endTimeParam = new NamedParameter(JobInstance.PROPERTY_END_TIME, "endTime", null);
StringBuilder sb = new StringBuilder();
sb.append(buildQlSelect(prefix)).append(startWhere())
.append(buildWhereClause(Operation.NOT_NULL, prefix, startTimeParam)).append(getAnd())
.append(buildWhereClause(Operation.NOT_NULL, prefix, endTimeParam));
return listWithJQL(sb.toString());
}
public List<JobInstance> findNotCompleted() {
String prefix = "x";
List<JobQueueStatus> statuses = new ArrayList<JobQueueStatus>();
statuses.add(JobQueueStatus.Completed);
statuses.add(JobQueueStatus.Aborted);
NamedParameter parameter = new NamedParameter(JobInstance.PROPERTY_STATUS, "status", statuses);
StringBuilder sb = new StringBuilder();
sb.append(buildQlSelect(prefix)).append(startWhere())
.append(buildWhereClause(Operation.NOT_IN, prefix, parameter));
return listWithJQL(sb.toString(), parameter);
}
}