/**
* TestCube is an enterprise Test management tool.
* Copyright (C) 2011 JatakaSource Ltd.
*
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* TestCube is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with TestCube. If not, see <http://www.gnu.org/licenses/>.
*/
package org.jatakasource.testcube.dao.testrun;
import java.util.List;
import org.apache.commons.lang.StringUtils;
import org.hibernate.Criteria;
import org.hibernate.criterion.MatchMode;
import org.hibernate.criterion.Restrictions;
import org.jatakasource.common.dao.BaseHibernateDao;
import org.jatakasource.common.model.paging.Paging;
import org.jatakasource.common.model.paging.Sorting;
import org.jatakasource.testcube.model.product.Product;
import org.jatakasource.testcube.model.testplan.TestPlan;
import org.jatakasource.testcube.model.testrun.ITestRun;
import org.jatakasource.testcube.model.testrun.TestRun;
import org.springframework.stereotype.Repository;
@Repository
public class HibernateTestRun extends BaseHibernateDao<ITestRun, Long> implements TestRunDao {
public HibernateTestRun() {
super(TestRun.class);
}
@Override
public List<ITestRun> findAll() {
return this.findAll(null, null, null);
}
public List<ITestRun> findAll(Paging paging, Sorting sorting, String keyword) {
return findAll(paging, sorting, keyword, null, null);
}
public List<ITestRun> findAll(Paging paging, Sorting sorting, String keyword, Long testPlanId) {
return findAll(paging, sorting, keyword, null, testPlanId);
}
@SuppressWarnings("unchecked")
public List<ITestRun> findAll(Paging paging, Sorting sorting, String keyword, Long productId, Long testPlanId) {
Criteria criteria = getCurrentSession().createCriteria(TestRun.class);
if (StringUtils.isNotEmpty(keyword)) {
criteria.add(Restrictions.or(Restrictions.ilike(TestRun.FIELD_NAME, keyword.toLowerCase(), MatchMode.ANYWHERE),
Restrictions.ilike(TestRun.FIELD_DESC, keyword.toLowerCase(), MatchMode.ANYWHERE)));
}
if (productId != null) {
criteria.createAlias(TestRun.FIELD_TESTPLAN, TestRun.FIELD_TESTPLAN_ALIAS);
criteria.add(Restrictions.eq(TestRun.FIELD_TESTPLAN_ALIAS + "." + TestPlan.FIELD_PRODUCT + "." + Product.FIELD_ID, productId));
}
if (testPlanId != null) {
criteria.add(Restrictions.eq(TestRun.FIELD_TESTPLAN + "." + TestRun.FIELD_ID, testPlanId));
}
addPaging(criteria, paging);
addSorting(criteria, sorting);
return criteria.list();
}
}