Package com.asakusafw.dmdl.directio.hive.common

Source Code of com.asakusafw.dmdl.directio.hive.common.HiveDecimalDriverTest

/**
* Copyright 2011-2014 Asakusa Framework Team.
*
* 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.asakusafw.dmdl.directio.hive.common;

import static org.hamcrest.Matchers.*;
import static org.junit.Assert.*;

import org.apache.hadoop.hive.common.type.HiveDecimal;
import org.junit.Test;

import com.asakusafw.dmdl.semantics.ModelDeclaration;
import com.asakusafw.dmdl.semantics.PropertyDeclaration;

/**
* Test for {@link HiveDecimalDriver}.
*/
public class HiveDecimalDriverTest extends GeneratorTesterRoot {

    /**
     * simple case.
     */
    @Test
    public void simple() {
        ModelDeclaration model = analyze(new String[] {
                "model = {",
                "  @directio.hive.decimal(precision = 10, scale = 2)",
                "  simple : DECIMAL;",
                "};"
        }).findModelDeclaration("model");
        PropertyDeclaration property = model.findPropertyDeclaration("simple");
        HiveFieldTrait trait = property.getTrait(HiveFieldTrait.class);
        assertThat(trait, is(notNullValue()));
        assertThat(trait.getTypeKind(), is(HiveFieldTrait.TypeKind.DECIMAL));
        assertThat(trait.getDecimalPrecision(), is(10));
        assertThat(trait.getDecimalScale(), is(2));
    }

    /**
     * minimum case.
     */
    @Test
    public void minimum() {
        ModelDeclaration model = analyze(new String[] {
                "model = {",
                "  @directio.hive.decimal(precision = 1, scale = 0)",
                "  simple : DECIMAL;",
                "};"
        }).findModelDeclaration("model");
        PropertyDeclaration property = model.findPropertyDeclaration("simple");
        HiveFieldTrait trait = property.getTrait(HiveFieldTrait.class);
        assertThat(trait, is(notNullValue()));
        assertThat(trait.getDecimalPrecision(), is(1));
        assertThat(trait.getDecimalScale(), is(0));
    }

    /**
     * maximum case.
     */
    @Test
    public void maximum() {
        ModelDeclaration model = analyze(new String[] {
                "model = {",
                String.format("  @directio.hive.decimal(precision = %d, scale = %d)",
                        HiveDecimal.MAX_PRECISION,
                        HiveDecimal.MAX_SCALE),
                "  simple : DECIMAL;",
                "};"
        }).findModelDeclaration("model");
        PropertyDeclaration property = model.findPropertyDeclaration("simple");
        HiveFieldTrait trait = property.getTrait(HiveFieldTrait.class);
        assertThat(trait, is(notNullValue()));
        assertThat(trait.getDecimalPrecision(), is(HiveDecimal.MAX_PRECISION));
        assertThat(trait.getDecimalScale(), is(HiveDecimal.MAX_SCALE));
    }

    /**
     * with invalid type.
     */
    @Test
    public void invalid_type() {
        shouldSemanticError(new String[] {
                "model = {",
                "  @directio.hive.decimal(precision = 10, scale = 2)",
                "  simple : INT;",
                "};"
        });
    }

    /**
     * w/o precision.
     */
    @Test
    public void invalid_wo_precision() {
        shouldSemanticError(new String[] {
                "model = {",
                "  @directio.hive.decimal(scale = 2)",
                "  simple : DECIMAL;",
                "};"
        });
    }

    /**
     * w/ small precision.
     */
    @Test
    public void invalid_precision_small() {
        shouldSemanticError(new String[] {
                "model = {",
                "  @directio.hive.decimal(precision = 0, scale = 2)",
                "  simple : DECIMAL;",
                "};"
        });
    }

    /**
     * w/ large precision.
     */
    @Test
    public void invalid_precision_large() {
        shouldSemanticError(new String[] {
                "model = {",
                String.format("  @directio.hive.decimal(precision = %d, scale = %d)",
                        HiveDecimal.MAX_PRECISION + 1,
                        0),
                "  simple : DECIMAL;",
                "};"
        });
    }

    /**
     * w/o scale.
     */
    @Test
    public void invalid_wo_scale() {
        shouldSemanticError(new String[] {
                "model = {",
                "  @directio.hive.decimal(precision = 10)",
                "  simple : DECIMAL;",
                "};"
        });
    }

    /**
     * w/ small scale.
     */
    @Test
    public void invalid_scale_small() {
        shouldSemanticError(new String[] {
                "model = {",
                "  @directio.hive.decimal(precision = 10, scale = -1)",
                "  simple : DECIMAL;",
                "};"
        });
    }

    /**
     * w/ large scale.
     */
    @Test
    public void invalid_scale_large() {
        shouldSemanticError(new String[] {
                "model = {",
                String.format("  @directio.hive.decimal(precision = %d, scale = %d)",
                        HiveDecimal.MAX_PRECISION,
                        HiveDecimal.MAX_SCALE + 1),
                "  simple : DECIMAL;",
                "};"
        });
    }

    /**
     * w/ precision {@code <} scale.
     */
    @Test
    public void invalid_precision_lt_scale() {
        shouldSemanticError(new String[] {
                "model = {",
                "  @directio.hive.decimal(precision = 10, scale = 11)",
                "  simple : DECIMAL;",
                "};"
        });
    }
}
TOP

Related Classes of com.asakusafw.dmdl.directio.hive.common.HiveDecimalDriverTest

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.