[New] Added Unit tests to test the bulk operations

This commit is contained in:
Robert von Burg 2013-12-24 01:48:09 +01:00
parent 86dddde196
commit 38d1cf61dd
3 changed files with 181 additions and 0 deletions

View File

@ -0,0 +1,33 @@
/*
* Copyright 2013 Robert von Burg <eitch@eitchnet.ch>
*
* 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 li.strolch.persistence.impl.dao.test;
import li.strolch.persistence.api.StrolchTransaction;
import org.junit.Test;
/**
* @author Robert von Burg <eitch@eitchnet.ch>
*/
public class XmlContainerTest extends AbstractDaoImplTest {
@Test
public void shouldStartContainer() {
try (StrolchTransaction tx = getPersistenceHandler().openTx()) {
tx.getOrderDao().queryKeySet();
}
}
}

View File

@ -18,12 +18,22 @@ package li.strolch.persistence.impl.dao.test;
import static li.strolch.model.ModelGenerator.BAG_ID;
import static li.strolch.model.ModelGenerator.PARAM_STRING_ID;
import static li.strolch.model.ModelGenerator.createOrder;
import static li.strolch.model.ModelGenerator.createOrders;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertNull;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import li.strolch.model.Order;
import li.strolch.model.parameter.Parameter;
import li.strolch.persistence.api.OrderDao;
import li.strolch.persistence.api.StrolchTransaction;
import org.junit.Test;
@ -89,4 +99,68 @@ public class XmlOrderDaoTest extends AbstractDaoImplTest {
assertNull("Should no read Order with id " + ID, order); //$NON-NLS-1$
}
}
@SuppressWarnings("nls")
@Test
public void shouldPerformBulkOperations() {
List<Order> orders = new ArrayList<>();
orders.addAll(createOrders(orders.size(), 5, "@", "My Order ", "MyType1"));
orders.addAll(createOrders(orders.size(), 5, "@", "Other Order ", "MyType2"));
orders.addAll(createOrders(orders.size(), 5, "@", "Further Order ", "MyType3"));
Comparator<Order> comparator = new Comparator<Order>() {
@Override
public int compare(Order o1, Order o2) {
return o1.getId().compareTo(o2.getId());
}
};
Collections.sort(orders, comparator);
try (StrolchTransaction tx = persistenceHandler.openTx()) {
tx.getOrderDao().removeAll(tx.getOrderDao().queryAll());
}
try (StrolchTransaction tx = persistenceHandler.openTx()) {
tx.getOrderDao().saveAll(orders);
}
Set<String> expectedTypes = new HashSet<>();
expectedTypes.add("MyType1");
expectedTypes.add("MyType2");
expectedTypes.add("MyType3");
try (StrolchTransaction tx = persistenceHandler.openTx()) {
List<Order> allOrders = tx.getOrderDao().queryAll();
Collections.sort(allOrders, comparator);
assertEquals(orders, allOrders);
}
try (StrolchTransaction tx = persistenceHandler.openTx()) {
OrderDao orderDao = tx.getOrderDao();
Set<String> types = orderDao.queryTypes();
assertEquals(expectedTypes, types);
Set<String> keySet = orderDao.queryKeySet();
assertEquals(15, keySet.size());
for (String type : types) {
Set<String> idsByType = orderDao.queryKeySet(type);
assertEquals(5, idsByType.size());
List<Order> ordersByType = orderDao.queryAll(type);
assertEquals(5, ordersByType.size());
}
}
try (StrolchTransaction tx = persistenceHandler.openTx()) {
Order order = tx.getOrderDao().queryBy("MyType1", "@_1");
assertNotNull(order);
order = tx.getOrderDao().queryBy("MyType2", "@_6");
assertNotNull(order);
order = tx.getOrderDao().queryBy("MyType3", "@_11");
assertNotNull(order);
}
}
}

View File

@ -18,12 +18,22 @@ package li.strolch.persistence.impl.dao.test;
import static li.strolch.model.ModelGenerator.BAG_ID;
import static li.strolch.model.ModelGenerator.PARAM_STRING_ID;
import static li.strolch.model.ModelGenerator.createResource;
import static li.strolch.model.ModelGenerator.createResources;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertNull;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import li.strolch.model.Resource;
import li.strolch.model.parameter.Parameter;
import li.strolch.persistence.api.ResourceDao;
import li.strolch.persistence.api.StrolchTransaction;
import org.junit.Test;
@ -89,4 +99,68 @@ public class XmlResourceDaoTest extends AbstractDaoImplTest {
assertNull("Should no read Resource with id " + ID, resource); //$NON-NLS-1$
}
}
@SuppressWarnings("nls")
@Test
public void shouldPerformBulkOperations() {
List<Resource> resources = new ArrayList<>();
resources.addAll(createResources(resources.size(), 5, "@", "My Resource ", "MyType1"));
resources.addAll(createResources(resources.size(), 5, "@", "Other Resource ", "MyType2"));
resources.addAll(createResources(resources.size(), 5, "@", "Further Resource ", "MyType3"));
Comparator<Resource> comparator = new Comparator<Resource>() {
@Override
public int compare(Resource o1, Resource o2) {
return o1.getId().compareTo(o2.getId());
}
};
Collections.sort(resources, comparator);
try (StrolchTransaction tx = persistenceHandler.openTx()) {
tx.getResourceDao().removeAll(tx.getResourceDao().queryAll());
}
try (StrolchTransaction tx = persistenceHandler.openTx()) {
tx.getResourceDao().saveAll(resources);
}
Set<String> expectedTypes = new HashSet<>();
expectedTypes.add("MyType1");
expectedTypes.add("MyType2");
expectedTypes.add("MyType3");
try (StrolchTransaction tx = persistenceHandler.openTx()) {
List<Resource> allResources = tx.getResourceDao().queryAll();
Collections.sort(allResources, comparator);
assertEquals(resources, allResources);
}
try (StrolchTransaction tx = persistenceHandler.openTx()) {
ResourceDao resourceDao = tx.getResourceDao();
Set<String> types = resourceDao.queryTypes();
assertEquals(expectedTypes, types);
Set<String> keySet = resourceDao.queryKeySet();
assertEquals(15, keySet.size());
for (String type : types) {
Set<String> idsByType = resourceDao.queryKeySet(type);
assertEquals(5, idsByType.size());
List<Resource> resourcesByType = resourceDao.queryAll(type);
assertEquals(5, resourcesByType.size());
}
}
try (StrolchTransaction tx = persistenceHandler.openTx()) {
Resource resource = tx.getResourceDao().queryBy("MyType1", "@_1");
assertNotNull(resource);
resource = tx.getResourceDao().queryBy("MyType2", "@_6");
assertNotNull(resource);
resource = tx.getResourceDao().queryBy("MyType3", "@_11");
assertNotNull(resource);
}
}
}