/* * Copyright (c) 2010 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.cache; import org.eurekastreams.server.domain.Person; import org.jmock.Expectations; import org.jmock.Mockery; import org.jmock.integration.junit4.JUnit4Mockery; import org.jmock.lib.legacy.ClassImposteriser; import org.junit.Before; import org.junit.Test; /** * Test for PersonEntityCacheUpdater. * */ public class PersonEntityCacheUpdaterTest { /** * Context for building mock objects. */ private final Mockery context = new JUnit4Mockery() { { setImposteriser(ClassImposteriser.INSTANCE); } }; /** * System under test. */ private PersonEntityCacheUpdater sut = new PersonEntityCacheUpdater(); /** * Entity mock. */ private Person entity = context.mock(Person.class, "group"); /** * Cache mock. */ private Cache cache = context.mock(Cache.class); /** * Test set up. */ @Before public void setUp() { sut.setCache(cache); } /** * Test. */ @Test public void testPostPersist() { context.checking(new Expectations() { { allowing(entity).getAccountId(); will(returnValue("accountId")); } }); sut.onPostPersist(entity); context.assertIsSatisfied(); } /** * Test. */ @Test public void testPostUpdate() { context.checking(new Expectations() { { allowing(entity).getId(); will(returnValue(2L)); oneOf(cache).delete(CacheKeys.PERSON_BY_ID + 2L); } }); sut.onPostUpdate(entity); context.assertIsSatisfied(); } }