com.smartitengineering.dao.hbase.ddl.TableGenerationTest.java Source code

Java tutorial

Introduction

Here is the source code for com.smartitengineering.dao.hbase.ddl.TableGenerationTest.java

Source

/*
 * This is a common dao with basic CRUD operations and is not limited to any
 * persistent layer implementation
 *
 * Copyright (C) 2010  Imran M Yousuf (imyousuf@smartitengineering.com)
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 3 of the License, or (at your option) any later version.
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
 */
package com.smartitengineering.dao.hbase.ddl;

import com.google.inject.AbstractModule;
import com.smartitengineering.dao.hbase.ddl.config.json.ConfigurationJsonParser;
import com.smartitengineering.util.bean.guice.GuiceUtil;
import java.io.IOException;
import java.io.InputStream;
import java.util.Collection;
import java.util.Date;
import java.util.Properties;
import org.apache.commons.lang.StringUtils;
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.HBaseTestingUtility;
import org.apache.hadoop.hbase.HTableDescriptor;
import org.apache.hadoop.hbase.client.HBaseAdmin;
import org.apache.hadoop.hbase.client.HTable;
import org.apache.hadoop.hbase.client.Put;
import org.apache.hadoop.hbase.client.Result;
import org.apache.hadoop.hbase.client.ResultScanner;
import org.apache.hadoop.hbase.client.Scan;
import org.apache.hadoop.hbase.util.Bytes;
import org.junit.Assert;
import org.junit.BeforeClass;
import org.junit.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 *
 * @author imyousuf
 */
public class TableGenerationTest {

    private static final HBaseTestingUtility TEST_UTIL = new HBaseTestingUtility();
    private static final Logger LOGGER = LoggerFactory.getLogger(TableGenerationTest.class);

    @BeforeClass
    public static void globalSetup() throws Exception {
        /*
         * Start HBase and initialize tables
         */
        //-Djavax.xml.parsers.DocumentBuilderFactory=com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderFactoryImpl
        System.setProperty("javax.xml.parsers.DocumentBuilderFactory",
                "com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderFactoryImpl");
        try {
            TEST_UTIL.startMiniCluster();
        } catch (Exception ex) {
            LOGGER.error(ex.getMessage(), ex);
        }

        Properties properties = new Properties();
        properties.setProperty(GuiceUtil.CONTEXT_NAME_PROP, "com.smartitengineering.dao.impl.hbase");
        properties.setProperty(GuiceUtil.IGNORE_MISSING_DEP_PROP, Boolean.TRUE.toString());
        properties.setProperty(GuiceUtil.MODULES_LIST_PROP, TestModule.class.getName());
        GuiceUtil.getInstance(properties).register();
    }

    @Test
    public void testTableCreation() throws Exception {
        InputStream classpathResource = getClass().getClassLoader().getResourceAsStream("ddl-config-sample1.json");
        Collection<HBaseTableConfiguration> configs = ConfigurationJsonParser.getConfigurations(classpathResource);
        try {
            new HBaseTableGenerator(configs, TEST_UTIL.getConfiguration(), true).generateTables();
        } catch (Exception ex) {
            LOGGER.error("Could not create table!", ex);
            Assert.fail(ex.getMessage());
        }
        HBaseAdmin admin = new HBaseAdmin(TEST_UTIL.getConfiguration());
        for (HBaseTableConfiguration tableConfiguration : configs) {
            Assert.assertTrue(admin.tableExists(tableConfiguration.getTableName()));
            HTableDescriptor descriptor = admin
                    .getTableDescriptor(Bytes.toBytes(tableConfiguration.getTableName()));
            for (int i = 1; i < 4; ++i) {
                Assert.assertTrue(descriptor.hasFamily(Bytes.toBytes("family" + i)));
            }
        }
    }

    @Test
    public void testRowIdGeneration() throws IOException {
        HTable table = new HTable(TEST_UTIL.getConfiguration(), "test");
        Put put = new Put(Bytes.toBytes(getPaddedId(1l)));
        final byte[] family = Bytes.toBytes("family2");
        put.add(family, Bytes.toBytes("cell"), Bytes.toBytes(new Date().getTime()));
        table.put(put);
        put = new Put(Bytes.toBytes(getPaddedId(2l)));
        put.add(family, Bytes.toBytes("cell"), Bytes.toBytes(new Date().getTime()));
        table.put(put);
        logResultRowId(table, family);
        for (long l = 30; l > 2; --l) {
            LOGGER.info("Setting Row ID: " + l);
            put = new Put(Bytes.toBytes(getPaddedId(l)));
            put.add(family, Bytes.toBytes("cell"), Bytes.toBytes(new Date().getTime()));
            table.put(put);
        }
        logResultRowId(table, family);
        for (long l = 31; l < 60; ++l) {
            put = new Put(Bytes.toBytes(getPaddedId(l)));
            put.add(family, Bytes.toBytes("cell"), Bytes.toBytes(new Date().getTime()));
            table.put(put);
        }
        logResultRowId(table, family);
        Scan scan = new Scan();
        ResultScanner scanner = table.getScanner(scan);
        Result result[];
        result = scanner.next(1);
        if (result != null && result.length > 0) {
            LOGGER.info("ROW ID: " + Bytes.toString(result[0].getRow()));
        }
    }

    protected void logResultRowId(HTable table, final byte[] family) throws IOException {
        ResultScanner scanner = table.getScanner(family);
        logScannerResults(scanner);
    }

    protected void logScannerResults(ResultScanner scanner) throws IOException {
        Result result;
        do {
            result = scanner.next();
            if (result != null) {
                LOGGER.info("ROW ID: " + Bytes.toString(result.getRow()));
            }
        } while (result != null);
    }

    protected String getPaddedId(long longId) {
        return StringUtils.leftPad(String.valueOf(longId), 10, '0');
    }

    public static class TestModule extends AbstractModule {

        @Override
        protected void configure() {
            bind(Configuration.class).toInstance(TEST_UTIL.getConfiguration());
        }
    }
}