/* * Copyright (c) 2011 Lockheed Martin Corporation * * 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 org.eurekastreams.server.persistence.mappers.db.metrics; import java.util.List; import junit.framework.Assert; import org.eurekastreams.server.domain.EntityType; import org.eurekastreams.server.domain.dto.StreamDTO; import org.eurekastreams.server.persistence.mappers.MapperTest; import org.junit.Before; import org.junit.Test; import com.ibm.icu.util.Calendar; /** * Test fixture GetStreamsByMostRecentDbMapper. */ public class GetStreamsByMostRecentDbMapperTest extends MapperTest { /** * System under test. */ private GetStreamsByMostRecentDbMapper sut; /** * Setup. */ @Before public void setup() { sut = new GetStreamsByMostRecentDbMapper(4); sut.setEntityManager(getEntityManager()); } /** * TestExecute. */ @Test public void testExecute() { Calendar cal = Calendar.getInstance(); // setup the data for: Group5, Group7 (ignored b/c pending), Group1, Group2, Group3, add in some people, but // they should // be ignored in the // results // -- the last two with the same date System.out.println("TIME: " + cal.getTime()); getEntityManager().createQuery("UPDATE DomainGroup SET dateAdded = :dateAdded WHERE id=:id").setParameter( "id", 5L).setParameter("dateAdded", cal.getTime()).executeUpdate(); cal.add(Calendar.HOUR, -1); getEntityManager().createQuery("UPDATE Person SET dateAdded = :dateAdded WHERE id=:id").setParameter("id", 4507L).setParameter("dateAdded", cal.getTime()).executeUpdate(); // ignored b/c PENDING cal.add(Calendar.HOUR, -1); getEntityManager().createQuery("UPDATE DomainGroup SET dateAdded = :dateAdded WHERE id=:id").setParameter( "id", 7L).setParameter("dateAdded", cal.getTime()).executeUpdate(); cal.add(Calendar.HOUR, -1); getEntityManager().createQuery("UPDATE DomainGroup SET dateAdded = :dateAdded WHERE id=:id").setParameter( "id", 1L).setParameter("dateAdded", cal.getTime()).executeUpdate(); cal.add(Calendar.HOUR, -1); getEntityManager().createQuery("UPDATE Person SET dateAdded = :dateAdded WHERE id=:id") .setParameter("id", 99L).setParameter("dateAdded", cal.getTime()).executeUpdate(); cal.add(Calendar.HOUR, -1); getEntityManager().createQuery("UPDATE DomainGroup SET dateAdded = :dateAdded WHERE id=:id").setParameter( "id", 2L).setParameter("dateAdded", cal.getTime()).executeUpdate(); getEntityManager().createQuery("UPDATE Person SET dateAdded = :dateAdded WHERE id=:id") .setParameter("id", 42L).setParameter("dateAdded", cal.getTime()).executeUpdate(); cal.add(Calendar.HOUR, -1); getEntityManager().createQuery("UPDATE DomainGroup SET dateAdded = :dateAdded WHERE id=:id").setParameter( "id", 3L).setParameter("dateAdded", cal.getTime()).executeUpdate(); getEntityManager().clear(); List<StreamDTO> results = sut.execute(null); for (StreamDTO result : results) { System.out.println(result.getEntityType() + " - " + result.getId() + " " + result.getDateAdded()); } Assert.assertEquals(4, results.size()); Assert.assertEquals(EntityType.GROUP, results.get(0).getEntityType()); Assert.assertEquals(5, results.get(0).getId()); Assert.assertEquals(EntityType.GROUP, results.get(1).getEntityType()); Assert.assertEquals(1, results.get(1).getId()); Assert.assertEquals(EntityType.GROUP, results.get(2).getEntityType()); Assert.assertEquals(2, results.get(2).getId()); Assert.assertEquals(EntityType.GROUP, results.get(3).getEntityType()); Assert.assertEquals(3, results.get(3).getId()); } }