Package com.impetus.client.hbase.crud

Source Code of com.impetus.client.hbase.crud.HBaseBatchProcessorTest

/*******************************************************************************
* * Copyright 2012 Impetus Infotech.
*  *
*  * 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 com.impetus.client.hbase.crud;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.Query;

import junit.framework.Assert;

import org.junit.After;
import org.junit.Before;
import org.junit.Test;

import com.impetus.client.hbase.junits.HBaseCli;
import com.impetus.kundera.client.Client;
import com.impetus.kundera.persistence.api.Batcher;

/**
* Batch processing test case for cassandra.
*
* @author vivek.mishra
*
*/
public class HBaseBatchProcessorTest
{

    /**
     * persistence unit.
     */
    private static final String PERSISTENCE_UNIT = "HbaseBatchTest";

    /** The emf. */
    private static EntityManagerFactory emf;

    /** The em. */
    private static EntityManager em;

    /** Rows. */
    private List<PersonBatchHBaseEntity> rows;

    private HBaseCli cli;

    /**
     * @throws java.lang.Exception
     */
    @Before
    public void setUp() throws Exception
    {
        cli = new HBaseCli();
        cli.startCluster();
        emf = Persistence.createEntityManagerFactory(PERSISTENCE_UNIT);
        em = emf.createEntityManager();
    }

    /**
     * Test case for batch operation.
     */
    @Test
    public void onBatch()
    {
        int counter = 0;
        rows = prepareData(10);
        for (PersonBatchHBaseEntity entity : rows)
        {
            em.persist(entity);

            // check for implicit flush.
            if (++counter == 5)
            {
                Map<String, Client> clients = (Map<String, Client>) em.getDelegate();

                Batcher client = (Batcher) clients.get(PERSISTENCE_UNIT);
                Assert.assertEquals(5, client.getBatchSize());
                em.clear();
                for (int i = 0; i < 5; i++)
                {

                    // assert on each batch size record
                    Assert.assertNotNull(em.find(PersonBatchHBaseEntity.class, rows.get(i).getPersonId()));

                    // as batch size is 5.
                    Assert.assertNull(em.find(PersonBatchHBaseEntity.class, rows.get(6).getPersonId()));
                }
                // means implicit flush must happen
            }
        }

        // flush all on close.
        // explicit flush on close
        em.clear();
        em.flush();

        String sql = " Select p from PersonBatchHBaseEntity p";
        Query query = em.createQuery(sql);
        List<PersonBatchHBaseEntity> results = query.getResultList();
        Assert.assertNotNull(results);
        Assert.assertEquals(10, results.size());
    }

    /**
     * @throws java.lang.Exception
     */
    @After
    public void tearDown() throws Exception
    {
        for (PersonBatchHBaseEntity o : rows)
        {
            em.remove(o);
        }

        em.close();
        emf.close();

        if (cli != null )
        {
            cli.dropTable("KunderaHbaseDataType");
            cli.stopCluster("KunderaHbaseDataType");
        }

    }

    /**
     * @param noOfRecords
     * @return
     */
    private List<PersonBatchHBaseEntity> prepareData(Integer noOfRecords)
    {
        List<PersonBatchHBaseEntity> persons = new ArrayList<PersonBatchHBaseEntity>();
        for (int i = 1; i <= noOfRecords; i++)
        {
            PersonBatchHBaseEntity o = new PersonBatchHBaseEntity();
            o.setPersonId(i + "");
            o.setPersonName("vivek" + i);
            o.setAge(10);
            persons.add(o);
        }

        return persons;
    }

}
TOP

Related Classes of com.impetus.client.hbase.crud.HBaseBatchProcessorTest

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.