/* * Copyright (C) 2011-2016 Markus Junginger, greenrobot (http://greenrobot.org) * * This file is part of greenDAO Generator. * * greenDAO Generator is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * greenDAO Generator 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with greenDAO Generator. If not, see <http://www.gnu.org/licenses/>. */ package org.greenrobot.greendao.daotest.query; import java.util.ArrayList; import org.greenrobot.greendao.daotest.entity.TestEntityTestBase; import org.greenrobot.greendao.query.CountQuery; import org.greenrobot.greendao.query.Query; import org.greenrobot.greendao.query.QueryBuilder; import org.greenrobot.greendao.daotest.TestEntity; import org.greenrobot.greendao.daotest.TestEntityDao.Properties; // TODO more tests public class CountQueryTest extends TestEntityTestBase { @Override protected void setUp() throws Exception { super.setUp(); QueryBuilder.LOG_SQL = true; QueryBuilder.LOG_VALUES = true; } public void testCountQuerySimple() { int value = getSimpleInteger(1); CountQuery<TestEntity> query = dao.queryBuilder().where(Properties.SimpleInteger.eq(value)).buildCount(); assertEquals(0, query.count()); ArrayList<TestEntity> inserted = insert(3); assertEquals(1, query.count()); inserted.get(2).setSimpleInteger(value); dao.update(inserted.get(2)); assertEquals(2, query.count()); dao.deleteAll(); assertEquals(0, query.count()); } public void testCountQueryTwoParameters() { int value = getSimpleInteger(1); String valueString = getSimpleString(1); QueryBuilder<TestEntity> queryBuilder = dao.queryBuilder(); queryBuilder.where(Properties.SimpleInteger.eq(value), Properties.SimpleString.eq(valueString)); CountQuery<TestEntity> query = queryBuilder.buildCount(); assertEquals(0, query.count()); ArrayList<TestEntity> inserted = insert(3); assertEquals(1, query.count()); inserted.get(2).setSimpleInteger(value); dao.update(inserted.get(2)); assertEquals(1, query.count()); inserted.get(2).setSimpleString(valueString); dao.update(inserted.get(2)); assertEquals(2, query.count()); dao.deleteAll(); assertEquals(0, query.count()); } public void testCountQueryTwoParametersOr() { int value = getSimpleInteger(1); String valueString = getSimpleString(2); QueryBuilder<TestEntity> queryBuilder = dao.queryBuilder(); queryBuilder.whereOr(Properties.SimpleInteger.eq(value), Properties.SimpleString.eq(valueString)); CountQuery<TestEntity> query = queryBuilder.buildCount(); assertEquals(0, query.count()); ArrayList<TestEntity> inserted = insert(3); assertEquals(2, query.count()); inserted.get(1).setSimpleInteger(getSimpleInteger(2)); dao.update(inserted.get(1)); assertEquals(1, query.count()); inserted.get(2).setSimpleString(getSimpleString(3)); dao.update(inserted.get(2)); assertEquals(0, query.count()); } public void testCountQueryChangeParameter() { insert(3); String value = "not existing value"; CountQuery<TestEntity> query = dao.queryBuilder().where(Properties.SimpleString.eq(value)).buildCount(); assertEquals(0, query.count()); query.setParameter(0, getSimpleString(1)); assertEquals(1, query.count()); query.setParameter(0, getSimpleString(2)); assertEquals(1, query.count()); query.setParameter(0, "you won't find me either"); assertEquals(0, query.count()); } public void testBuildQueryAndCountQuery() { insert(3); int value = getSimpleInteger(1); QueryBuilder<TestEntity> builder = dao.queryBuilder().where(Properties.SimpleInteger.eq(value)); Query<TestEntity> query = builder.build(); CountQuery<TestEntity> countQuery = builder.buildCount(); assertEquals(1, query.list().size()); assertEquals(1, countQuery.count()); } }