Package info.archinnov.achilles.internal.statement.cache

Source Code of info.archinnov.achilles.internal.statement.cache.CacheManagerTest

/*
* Copyright (C) 2012-2014 DuyHai DOAN
*
*  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 info.archinnov.achilles.internal.statement.cache;

import static com.google.common.collect.Sets.newHashSet;
import static info.archinnov.achilles.internal.metadata.holder.PropertyType.SIMPLE;
import static info.archinnov.achilles.internal.persistence.operations.CollectionAndMapChangeType.ADD_TO_SET;
import static info.archinnov.achilles.internal.metadata.holder.PropertyMetaTestBuilder.completeBean;
import static info.archinnov.achilles.type.OptionsBuilder.noOptions;
import static java.util.Arrays.asList;
import static org.fest.assertions.api.Assertions.assertThat;
import static org.mockito.Mockito.RETURNS_DEEP_STUBS;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.never;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.verifyZeroInteractions;
import static org.mockito.Mockito.when;
import java.util.List;

import org.fest.util.Sets;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Answers;
import org.mockito.ArgumentCaptor;
import org.mockito.Captor;
import org.mockito.InjectMocks;
import org.mockito.Mock;
import org.mockito.runners.MockitoJUnitRunner;
import com.datastax.driver.core.PreparedStatement;
import com.datastax.driver.core.Session;
import com.google.common.cache.Cache;
import info.archinnov.achilles.internal.context.PersistenceContext;
import info.archinnov.achilles.internal.metadata.holder.EntityMeta;
import info.archinnov.achilles.internal.metadata.holder.PropertyMeta;
import info.archinnov.achilles.internal.proxy.dirtycheck.DirtyCheckChangeSet;
import info.archinnov.achilles.internal.statement.prepared.PreparedStatementGenerator;
import info.archinnov.achilles.query.slice.SliceQueryProperties;
import info.archinnov.achilles.internal.metadata.holder.PropertyMetaTestBuilder;
import info.archinnov.achilles.test.mapping.entity.CompleteBean;

@RunWith(MockitoJUnitRunner.class)
public class CacheManagerTest {
    @InjectMocks
    private CacheManager manager = new CacheManager(100);

    @Mock
    private PreparedStatementGenerator generator;

    @Mock
    private Session session;

    @Mock
    private Cache<StatementCacheKey, PreparedStatement> cache;

    @Mock
    private PersistenceContext.StateHolderFacade context;

    @Mock
    private PreparedStatement ps;

    @Mock(answer = Answers.RETURNS_DEEP_STUBS)
    private SliceQueryProperties<CompleteBean> sliceQueryProperties;

    @Captor
    ArgumentCaptor<StatementCacheKey> cacheKeyCaptor;

    @Before
    public void setUp() {
        when(context.getOptions()).thenReturn(noOptions());
    }

    @Test
    public void should_get_cache_for_simple_field() throws Exception {
        EntityMeta meta = new EntityMeta();

        PropertyMeta pm = PropertyMetaTestBuilder.valueClass(String.class)
                .propertyName("name").cqlColumnName("name").type(SIMPLE)
                .build();

        when(context.<CompleteBean>getEntityClass()).thenReturn(CompleteBean.class);
        when(context.getEntityMeta()).thenReturn(meta);
        when(cache.getIfPresent(cacheKeyCaptor.capture())).thenReturn(ps);

        PreparedStatement actual = manager.getCacheForFieldSelect(session, cache, context, pm);

        assertThat(actual).isSameAs(ps);
        StatementCacheKey cacheKey = cacheKeyCaptor.getValue();
        assertThat(cacheKey.<CompleteBean>getEntityClass()).isSameAs(CompleteBean.class);
        assertThat(cacheKey.getType()).isEqualTo(CacheType.SELECT_FIELD);
        assertThat(cacheKey.getFields()).containsExactly("name");
    }

    @Test
    public void should_get_cache_for_clustered_id() throws Exception {
        EntityMeta meta = new EntityMeta();
        PropertyMeta pm = mock(PropertyMeta.class, RETURNS_DEEP_STUBS);

        when(context.<CompleteBean>getEntityClass()).thenReturn(CompleteBean.class);
        when(context.getEntityMeta()).thenReturn(meta);
        when(pm.forCache().extractClusteredFieldsIfNecessary()).thenReturn(Sets.newLinkedHashSet("id", "a", "b"));
        when(cache.getIfPresent(cacheKeyCaptor.capture())).thenReturn(ps);

        PreparedStatement actual = manager.getCacheForFieldSelect(session, cache, context, pm);

        assertThat(actual).isSameAs(ps);
        StatementCacheKey cacheKey = cacheKeyCaptor.getValue();
        assertThat(cacheKey.getFields()).containsOnly("id", "a", "b");
    }

    @Test
    public void should_generate_select_prepared_statement_when_not_found_in_cache() throws Exception {
        EntityMeta meta = new EntityMeta();
//        meta.setTableName("table");

        PropertyMeta pm = PropertyMetaTestBuilder.valueClass(String.class).propertyName("name").type(SIMPLE)
                .build();

        when(context.<CompleteBean>getEntityClass()).thenReturn(CompleteBean.class);
        when(context.getEntityMeta()).thenReturn(meta);
        when(cache.getIfPresent(cacheKeyCaptor.capture())).thenReturn(null);
        when(generator.prepareSelectField(session, meta, pm)).thenReturn(ps);

        PreparedStatement actual = manager.getCacheForFieldSelect(session, cache, context, pm);

        assertThat(actual).isSameAs(ps);
        StatementCacheKey cacheKey = cacheKeyCaptor.getValue();
        verify(cache).put(cacheKey, ps);
    }

    @Test
    public void should_get_cache_for_entity_insert() throws Exception {
        EntityMeta meta = new EntityMeta();
//        meta.setTableName("table");

        PropertyMeta nameMeta = completeBean(Void.class, String.class).propertyName("name").type(SIMPLE).build();
        PropertyMeta ageMeta = completeBean(Void.class, String.class).propertyName("age").type(SIMPLE).build();

        when(context.<CompleteBean>getEntityClass()).thenReturn(CompleteBean.class);
        when(context.getEntityMeta()).thenReturn(meta);
        when(cache.getIfPresent(cacheKeyCaptor.capture())).thenReturn(ps);

        PreparedStatement actual = manager.getCacheForEntityInsert(session, cache, context, asList(nameMeta, ageMeta));

        assertThat(actual).isSameAs(ps);
        StatementCacheKey cacheKey = cacheKeyCaptor.getValue();
        assertThat(cacheKey.<CompleteBean>getEntityClass()).isSameAs(CompleteBean.class);
        assertThat(cacheKey.getType()).isEqualTo(CacheType.INSERT);
        assertThat(cacheKey.getFields()).containsOnly("name", "age");
    }

    @Test
    public void should_generate_insert_prepared_statement_when_not_found_in_cache() throws Exception {
        EntityMeta meta = new EntityMeta();
//        meta.setTableName("table");

        PropertyMeta nameMeta = completeBean(Void.class, String.class).propertyName("name").type(SIMPLE).build();

        PropertyMeta ageMeta = completeBean(Void.class, String.class).propertyName("age").type(SIMPLE).build();

        List<PropertyMeta> pms = asList(nameMeta, ageMeta);

        when(context.<CompleteBean>getEntityClass()).thenReturn(CompleteBean.class);
        when(context.getEntityMeta()).thenReturn(meta);
        when(cache.getIfPresent(cacheKeyCaptor.capture())).thenReturn(null);
        when(generator.prepareInsert(session, meta, pms, noOptions())).thenReturn(ps);

        PreparedStatement actual = manager.getCacheForEntityInsert(session, cache, context, pms);

        assertThat(actual).isSameAs(ps);
        StatementCacheKey cacheKey = cacheKeyCaptor.getValue();
        assertThat(cacheKey.<CompleteBean>getEntityClass()).isSameAs(CompleteBean.class);
        assertThat(cacheKey.getType()).isEqualTo(CacheType.INSERT);
        assertThat(cacheKey.getFields()).containsOnly("name", "age");
    }

    @Test
    public void should_get_cache_for_fields_update() throws Exception {
        EntityMeta meta = new EntityMeta();
//        meta.setTableName("table");

        PropertyMeta nameMeta = completeBean(Void.class, String.class).propertyName("name").type(SIMPLE).build();
        PropertyMeta ageMeta = completeBean(Void.class, String.class).propertyName("age").type(SIMPLE).build();

        when(context.<CompleteBean>getEntityClass()).thenReturn(CompleteBean.class);
        when(context.getEntityMeta()).thenReturn(meta);
        when(cache.getIfPresent(cacheKeyCaptor.capture())).thenReturn(ps);

        PreparedStatement actual = manager.getCacheForFieldsUpdate(session, cache, context, asList(nameMeta, ageMeta));

        assertThat(actual).isSameAs(ps);
        StatementCacheKey cacheKey = cacheKeyCaptor.getValue();
        assertThat(cacheKey.<CompleteBean>getEntityClass()).isSameAs(CompleteBean.class);
        assertThat(cacheKey.getType()).isEqualTo(CacheType.UPDATE_FIELDS);
        assertThat(cacheKey.getFields()).containsOnly("name", "age");
    }

    @Test
    public void should_generate_update_prepared_statement_when_not_found_in_cache() throws Exception {
        EntityMeta meta = new EntityMeta();
//        meta.setTableName("table");

        PropertyMeta nameMeta = completeBean(Void.class, String.class).propertyName("name").type(SIMPLE).build();
        PropertyMeta ageMeta = completeBean(Void.class, String.class).propertyName("age").type(SIMPLE).build();

        List<PropertyMeta> pms = asList(nameMeta, ageMeta);

        when(context.<CompleteBean>getEntityClass()).thenReturn(CompleteBean.class);
        when(context.getEntityMeta()).thenReturn(meta);
        when(cache.getIfPresent(cacheKeyCaptor.capture())).thenReturn(null);
        when(generator.prepareUpdateFields(session, meta, pms, noOptions())).thenReturn(ps);

        PreparedStatement actual = manager.getCacheForFieldsUpdate(session, cache, context, pms);

        assertThat(actual).isSameAs(ps);
        StatementCacheKey cacheKey = cacheKeyCaptor.getValue();
        assertThat(cacheKey.<CompleteBean>getEntityClass()).isSameAs(CompleteBean.class);
        assertThat(cacheKey.getType()).isEqualTo(CacheType.UPDATE_FIELDS);
        assertThat(cacheKey.getFields()).containsOnly("name", "age");
    }

    @Test
    public void should_prepare_message_for_collection_and_map_operation() throws Exception {
        //Given
        EntityMeta meta = mock(EntityMeta.class);
        PropertyMeta pm = mock(PropertyMeta.class);
        DirtyCheckChangeSet changeSet = new DirtyCheckChangeSet(pm, ADD_TO_SET);

        when(context.<CompleteBean>getEntityClass()).thenReturn(CompleteBean.class);
        when(context.getEntityMeta()).thenReturn(meta);
        when(pm.getPropertyName()).thenReturn("property");
        StatementCacheKey cacheKey = new StatementCacheKey(CacheType.ADD_TO_SET, newHashSet("property"), CompleteBean.class, noOptions());

        when(cache.getIfPresent(cacheKey)).thenReturn(null);
        when(generator.prepareCollectionAndMapUpdate(session, meta, changeSet, noOptions())).thenReturn(ps);

        //When
        final PreparedStatement actual = manager.getCacheForCollectionAndMapOperation(session, cache, context, pm, changeSet);

        //Then
        assertThat(actual).isSameAs(ps);
        verify(cache).put(cacheKey, ps);
    }

    @Test
    public void should_get_collection_and_map_operation_from_cache() throws Exception {
        //Given
        EntityMeta meta = mock(EntityMeta.class);
        PropertyMeta pm = mock(PropertyMeta.class);
        DirtyCheckChangeSet changeSet = new DirtyCheckChangeSet(pm, ADD_TO_SET);

        when(context.<CompleteBean>getEntityClass()).thenReturn(CompleteBean.class);
        when(context.getEntityMeta()).thenReturn(meta);
        when(pm.getPropertyName()).thenReturn("property");
        StatementCacheKey cacheKey = new StatementCacheKey(CacheType.ADD_TO_SET, newHashSet("property"), CompleteBean.class, noOptions());
        when(cache.getIfPresent(cacheKey)).thenReturn(ps);

        //When
        final PreparedStatement actual = manager.getCacheForCollectionAndMapOperation(session, cache, context, pm,
                changeSet);

        //Then
        assertThat(actual).isSameAs(ps);
        verify(cache, never()).put(cacheKey, ps);
        verifyZeroInteractions(generator);
    }

    @Test
    public void should_get_select_for_slice_query_from_cache() throws Exception {
        //Given
        StatementCacheKey cacheKey = new StatementCacheKey(CacheType.SLICE_QUERY_SELECT, sliceQueryProperties);

        when(sliceQueryProperties.getEntityClass()).thenReturn(CompleteBean.class);
        when(cache.getIfPresent(cacheKey)).thenReturn(ps);

        //When
        final PreparedStatement actual = manager.getCacheForSliceSelectAndIterator(session, cache, sliceQueryProperties);

        //Then
        assertThat(actual).isSameAs(ps);
    }

    @Test
    public void should_generate_select_for_slice_query() throws Exception {
        //Given
        StatementCacheKey cacheKey = new StatementCacheKey(CacheType.SLICE_QUERY_SELECT, sliceQueryProperties);

        when(sliceQueryProperties.getEntityClass()).thenReturn(CompleteBean.class);
        when(cache.getIfPresent(cacheKey)).thenReturn(null);
        when(generator.prepareSelectSliceQuery(session,sliceQueryProperties)).thenReturn(ps);

        //When
        final PreparedStatement actual = manager.getCacheForSliceSelectAndIterator(session, cache, sliceQueryProperties);

        //Then
        assertThat(actual).isSameAs(ps);
        verify(cache).put(cacheKey,ps);
    }

    @Test
    public void should_get_delete_for_slice_query_from_cache() throws Exception {
        //Given
        StatementCacheKey cacheKey = new StatementCacheKey(CacheType.SLICE_QUERY_DELETE, sliceQueryProperties);

        when(sliceQueryProperties.getEntityClass()).thenReturn(CompleteBean.class);
        when(cache.getIfPresent(cacheKey)).thenReturn(ps);

        //When
        final PreparedStatement actual = manager.getCacheForSliceDelete(session, cache, sliceQueryProperties);

        //Then
        assertThat(actual).isSameAs(ps);
    }

    @Test
    public void should_generate_delete_for_slice_query() throws Exception {
        //Given
        StatementCacheKey cacheKey = new StatementCacheKey(CacheType.SLICE_QUERY_DELETE, sliceQueryProperties);

        when(sliceQueryProperties.getEntityClass()).thenReturn(CompleteBean.class);
        when(cache.getIfPresent(cacheKey)).thenReturn(null);
        when(generator.prepareDeleteSliceQuery(session,sliceQueryProperties)).thenReturn(ps);

        //When
        final PreparedStatement actual = manager.getCacheForSliceDelete(session, cache, sliceQueryProperties);

        //Then
        assertThat(actual).isSameAs(ps);
        verify(cache).put(cacheKey,ps);
    }
}
TOP

Related Classes of info.archinnov.achilles.internal.statement.cache.CacheManagerTest

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.