Repository: incubator-carbondata Updated Branches: refs/heads/master 343916b56 -> 0265b825c
Added ValueCompressionUtilTest corrected unit test for ValueCompressionUtil added unit tests for value compresion model Updated unit test for ValueCompressionUtil Updated formatting Project: http://git-wip-us.apache.org/repos/asf/incubator-carbondata/repo Commit: http://git-wip-us.apache.org/repos/asf/incubator-carbondata/commit/c5bdd21a Tree: http://git-wip-us.apache.org/repos/asf/incubator-carbondata/tree/c5bdd21a Diff: http://git-wip-us.apache.org/repos/asf/incubator-carbondata/diff/c5bdd21a Branch: refs/heads/master Commit: c5bdd21a4ac91dbf4bfeb55292f3c99d3647d2f0 Parents: 343916b Author: kunal642 <kunal.kap...@knoldus.in> Authored: Wed Nov 2 14:19:24 2016 +0530 Committer: ravipesala <ravi.pes...@gmail.com> Committed: Wed Nov 16 15:14:50 2016 +0530 ---------------------------------------------------------------------- .../core/util/ValueCompressionUtilTest.java | 697 +++++++++++++++++++ 1 file changed, 697 insertions(+) ---------------------------------------------------------------------- http://git-wip-us.apache.org/repos/asf/incubator-carbondata/blob/c5bdd21a/core/src/test/java/org/apache/carbondata/core/util/ValueCompressionUtilTest.java ---------------------------------------------------------------------- diff --git a/core/src/test/java/org/apache/carbondata/core/util/ValueCompressionUtilTest.java b/core/src/test/java/org/apache/carbondata/core/util/ValueCompressionUtilTest.java new file mode 100644 index 0000000..db64011 --- /dev/null +++ b/core/src/test/java/org/apache/carbondata/core/util/ValueCompressionUtilTest.java @@ -0,0 +1,697 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you 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.apache.carbondata.core.util; + +import org.apache.carbondata.core.datastorage.store.compression.MeasureMetaDataModel; +import org.apache.carbondata.core.datastorage.store.compression.ValueCompressionModel; +import org.apache.carbondata.core.datastorage.store.compression.ValueCompressonHolder; +import org.apache.carbondata.core.datastorage.store.compression.type.*; + +import org.junit.Test; + +import java.nio.ByteBuffer; + +import static junit.framework.TestCase.*; +import static org.apache.carbondata.core.util.ValueCompressionUtil.DataType; + +public class ValueCompressionUtilTest { + + @Test public void testGetSize() { + DataType[] dataTypes = + { DataType.DATA_BIGINT, DataType.DATA_INT, DataType.DATA_BYTE, DataType.DATA_SHORT, + DataType.DATA_FLOAT }; + int[] expectedSizes = { 8, 4, 1, 2, 4 }; + for (int i = 0; i < dataTypes.length; i++) { + assertEquals(expectedSizes[i], ValueCompressionUtil.getSize(dataTypes[i])); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeMin_MaxForDataInt() { + double[] values = { 25, 12, 22 }; + int[] result = (int[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.MAX_MIN, values, + DataType.DATA_INT, 22, 0); + int[] expectedResult = { -3, 10, 0 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeMin_MaxForDataByte() { + double[] values = { 20, 21, 22 }; + byte[] result = (byte[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.MAX_MIN, values, + DataType.DATA_BYTE, 22, 0); + byte[] expectedResult = { 2, 1, 0 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeMin_MaxForDataShort() { + double[] values = { 200, 21, 22 }; + short[] result = (short[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.MAX_MIN, values, + DataType.DATA_SHORT, 22, 0); + short[] expectedResult = { -178, 1, 0 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeMin_MaxForDataLong() { + double[] values = { 2000, 2100, 2002 }; + long[] result = (long[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.MAX_MIN, values, + DataType.DATA_LONG, 2125, 0); + long[] expectedResult = { 125, 25, 123 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeMin_MaxForDataFloat() { + double[] values = { 20.121, 21.223, 22.345 }; + float[] result = (float[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.MAX_MIN, values, + DataType.DATA_FLOAT, 22.345, 3); + float[] expectedResult = { 2.224f, 1.122f, 0f }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeMin_MaxForDataDouble() { + double[] values = { 20.121, 21.223, 22.345 }; + double[] result = (double[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.MAX_MIN, values, + DataType.DATA_DOUBLE, 102.345, 3); + double[] expectedResult = { 82.224, 81.122, 80.0 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeNoneForBigInt() { + double[] values = { 20.121, 21.223, 22.345 }; + long[] result = (long[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.NONE, values, + DataType.DATA_BIGINT, 22, 0); + long[] expectedResult = { 20, 21, 22 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeNoneForDataByte() { + double[] values = { 20, 21, 22 }; + byte[] result = (byte[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.NONE, values, DataType.DATA_BYTE, + 22, 0); + byte[] expectedResult = { 20, 21, 22 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeNoneForDataShort() { + double[] values = { 200000, 21, 22 }; + short[] result = (short[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.NONE, values, + DataType.DATA_SHORT, 22, 0); + short[] expectedResult = { 3392, 21, 22 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeNoneForDataInt() { + double[] values = { 20, 21, 22 }; + int[] result = (int[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.NONE, values, DataType.DATA_INT, + 22, 0); + int[] expectedResult = { 20, 21, 22 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeNoneForDataLong() { + double[] values = { 20, 21, 22 }; + long[] result = (long[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.NONE, values, DataType.DATA_LONG, + 22, 0); + long[] expectedResult = { 20, 21, 22 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeNoneForDataFloat() { + double[] values = { 20.121, 21.223, 22.345 }; + float[] result = (float[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.NONE, values, + DataType.DATA_FLOAT, 22, 3); + float[] expectedResult = { 20.121f, 21.223f, 22.345f }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeNoneForDataDouble() { + double[] values = { 20.121, 21.223, 22.345 }; + double[] result = (double[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.NONE, values, + DataType.DATA_DOUBLE, 22, 3); + double[] expectedResult = { 20.121, 21.223, 22.345 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeNon_DecimalForFloat() { + double[] values = { 20.1, 21.2, 22.3 }; + float[] result = (float[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.NON_DECIMAL_CONVERT, values, + DataType.DATA_FLOAT, 22, 1); + float[] expectedResult = { 201f, 212f, 223f }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeNon_DecimalForByte() { + double[] values = { 20.1, 21.2, 22.3 }; + byte[] result = (byte[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.NON_DECIMAL_CONVERT, values, + DataType.DATA_BYTE, 22, 1); + byte[] expectedResult = { -55, -44, -33 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeNon_DecimalForShort() { + double[] values = { 20.1, 21.2, 22.3 }; + short[] result = (short[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.NON_DECIMAL_CONVERT, values, + DataType.DATA_SHORT, 22, 1); + short[] expectedResult = { 201, 212, 223 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeNon_DecimalForInt() { + double[] values = { 20.1, 21.2, 22.3 }; + int[] result = (int[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.NON_DECIMAL_CONVERT, values, + DataType.DATA_INT, 22, 1); + int[] expectedResult = { 201, 212, 223 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeNon_DecimalForLong() { + double[] values = { 20.1, 21.2, 22.3 }; + long[] result = (long[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.NON_DECIMAL_CONVERT, values, + DataType.DATA_LONG, 22, 1); + long[] expectedResult = { 201, 212, 223 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeNon_DecimalForDouble() { + double[] values = { 20.1, 21.2, 22.3 }; + double[] result = (double[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.NON_DECIMAL_CONVERT, values, + DataType.DATA_DOUBLE, 22, 1); + double[] expectedResult = { 201, 212, 223 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeMax_Min_NDCForByte() { + double[] values = { 20, 21, 22 }; + byte[] result = (byte[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.MAX_MIN_NDC, values, + DataType.DATA_BYTE, 22, 1); + byte[] expectedResult = { 20, 10, 0 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeMax_Min_NDCForInt() { + double[] values = { 20, 21, 22 }; + int[] result = (int[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.MAX_MIN_NDC, values, + DataType.DATA_INT, 22, 1); + int[] expectedResult = { 20, 10, 0 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeMax_Min_NDCForDouble() { + double[] values = { 20, 21, 22 }; + double[] result = (double[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.MAX_MIN_NDC, values, + DataType.DATA_DOUBLE, 22, 1); + double[] expectedResult = { 20, 10, 0 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeMax_Min_NDCForShort() { + double[] values = { 20000, 21, 22 }; + short[] result = (short[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.MAX_MIN_NDC, values, + DataType.DATA_SHORT, 22, 1); + short[] expectedResult = { -3172, 10, 0 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeMax_Min_NDCForLong() { + double[] values = { 20, 21, 22 }; + long[] result = (long[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.MAX_MIN_NDC, values, + DataType.DATA_LONG, 22, 1); + long[] expectedResult = { 20, 10, 0 }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToGetCompressedValuesWithCompressionTypeMax_Min_NDCForFloat() { + double[] values = { 20, 21, 22 }; + float[] result = (float[]) ValueCompressionUtil + .getCompressedValues(ValueCompressionUtil.COMPRESSION_TYPE.MAX_MIN_NDC, values, + DataType.DATA_FLOAT, 22, 1); + float[] expectedResult = { 20f, 10f, 0f }; + for (int i = 0; i < result.length; i++) { + assertEquals(result[i], expectedResult[i]); + } + } + + @Test public void testToUnCompressNone() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressNone(DataType.DATA_BIGINT, DataType.DATA_BIGINT); + assertEquals(result.getClass(), UnCompressDefaultLong.class); + } + + @Test public void testToUnCompressNoneForByte() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressNone(DataType.DATA_BYTE, DataType.DATA_FLOAT); + assertEquals(result.getClass(), UnCompressNoneByte.class); + } + + @Test public void testToUnCompressNoneForLong() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressNone(DataType.DATA_LONG, DataType.DATA_FLOAT); + assertEquals(result.getClass(), UnCompressNoneLong.class); + } + + @Test public void testToUnCompressNoneForShort() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressNone(DataType.DATA_SHORT, DataType.DATA_FLOAT); + assertEquals(result.getClass(), UnCompressNoneShort.class); + } + + @Test public void testToUnCompressNoneForFloat() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressNone(DataType.DATA_FLOAT, DataType.DATA_FLOAT); + assertEquals(result.getClass(), UnCompressNoneFloat.class); + } + + @Test public void testToUnCompressNoneForInt() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressNone(DataType.DATA_INT, DataType.DATA_FLOAT); + assertEquals(result.getClass(), UnCompressNoneInt.class); + } + + @Test public void testToUnCompressNoneForDouble() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressNone(DataType.DATA_DOUBLE, DataType.DATA_FLOAT); + assertEquals(result.getClass(), UnCompressNoneDefault.class); + } + + @Test public void testToUnCompressMaxMinForDouble() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressMaxMin(DataType.DATA_DOUBLE, null); + assertEquals(result.getClass(), UnCompressMaxMinDefault.class); + } + + @Test public void testToUnCompressMaxMinForInt() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressMaxMin(DataType.DATA_INT, null); + assertEquals(result.getClass(), UnCompressMaxMinInt.class); + } + + @Test public void testToUnCompressMaxMinForFloat() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressMaxMin(DataType.DATA_FLOAT, null); + assertEquals(result.getClass(), UnCompressMaxMinFloat.class); + } + + @Test public void testToUnCompressMaxMinForLong() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressMaxMin(DataType.DATA_LONG, null); + assertEquals(result.getClass(), UnCompressMaxMinLong.class); + } + + @Test public void testToUnCompressMaxMinForByte() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressMaxMin(DataType.DATA_BYTE, null); + assertEquals(result.getClass(), UnCompressMaxMinByte.class); + } + + @Test public void testToUnCompressMaxMinForShort() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressMaxMin(DataType.DATA_SHORT, null); + assertEquals(result.getClass(), UnCompressMaxMinShort.class); + } + + @Test public void testToUnCompressNonDecimalForDouble() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressNonDecimal(DataType.DATA_DOUBLE, null); + assertEquals(result.getClass(), UnCompressNonDecimalDefault.class); + } + + @Test public void testToUnCompressNonDecimalForInt() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressNonDecimal(DataType.DATA_INT, null); + assertEquals(result.getClass(), UnCompressNonDecimalInt.class); + } + + @Test public void testToUnCompressNonDecimalForFloat() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressNonDecimal(DataType.DATA_FLOAT, null); + assertEquals(result.getClass(), UnCompressNonDecimalFloat.class); + } + + @Test public void testToUnCompressNonDecimalForLong() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressNonDecimal(DataType.DATA_LONG, null); + assertEquals(result.getClass(), UnCompressNonDecimalLong.class); + } + + @Test public void testToUnCompressNonDecimalForByte() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressNonDecimal(DataType.DATA_BYTE, null); + assertEquals(result.getClass(), UnCompressNonDecimalByte.class); + } + + @Test public void testToUnCompressNonDecimalForShort() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressNonDecimal(DataType.DATA_SHORT, null); + assertEquals(result.getClass(), UnCompressNonDecimalShort.class); + } + + @Test public void testToUnCompressNonDecimalMaxMinForDouble() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressNonDecimalMaxMin(DataType.DATA_DOUBLE, null); + assertEquals(result.getClass(), UnCompressNonDecimalMaxMinDefault.class); + } + + @Test public void testToUnCompressNonDecimalMaxMinForInt() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressNonDecimalMaxMin(DataType.DATA_INT, null); + assertEquals(result.getClass(), UnCompressNonDecimalMaxMinInt.class); + } + + @Test public void testToUnCompressNonDecimalMaxMinForFloat() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressNonDecimalMaxMin(DataType.DATA_FLOAT, null); + assertEquals(result.getClass(), UnCompressNonDecimalMaxMinFloat.class); + } + + @Test public void testToUnCompressNonDecimalMaxMinForLong() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressNonDecimalMaxMin(DataType.DATA_LONG, null); + assertEquals(result.getClass(), UnCompressNonDecimalMaxMinLong.class); + } + + @Test public void testToUnCompressNonDecimalMaxMinForByte() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressNonDecimalMaxMin(DataType.DATA_BYTE, null); + assertEquals(result.getClass(), UnCompressNonDecimalMaxMinByte.class); + } + + @Test public void testToUnCompressNonDecimalMaxMinForShort() { + ValueCompressonHolder.UnCompressValue result = + ValueCompressionUtil.unCompressNonDecimalMaxMin(DataType.DATA_SHORT, null); + assertEquals(result.getClass(), UnCompressNonDecimalMaxMinShort.class); + } + + @Test public void testToConvertToBytesForInt() { + int[] input = { 120000, 200000, 300000 }; + byte[] result = ValueCompressionUtil.convertToBytes(input); + byte[] expectedResult = { 0, 1, -44 }; + for (int i = 0; i < input.length; i++) { + assertEquals(expectedResult[i], result[i]); + } + } + + @Test public void testToConvertToInt() { + ByteBuffer byteBuffer = ByteBuffer.allocate(4); + byteBuffer.putInt(123); + int[] result = ValueCompressionUtil.convertToIntArray(byteBuffer, 4); + int[] expectedResult = { 123 }; + for (int i = 0; i < result.length; i++) { + assertEquals(expectedResult[i], result[i]); + } + } + + @Test public void testToConvertToBytesForFloat() { + float[] input = { 120.001f, 200.012f, 300.123f }; + byte[] result = ValueCompressionUtil.convertToBytes(input); + byte[] expectedResult = { 66, -16, 0, -125, 67, 72, 3, 18, 67, -106, 15, -66 }; + for (int i = 0; i < result.length; i++) { + assertEquals(expectedResult[i], result[i]); + } + } + + @Test public void testToConvertToFloat() { + ByteBuffer byteBuffer = ByteBuffer.allocate(4); + byteBuffer.putFloat(123.23f); + float[] result = ValueCompressionUtil.convertToFloatArray(byteBuffer, 4); + float[] expectedResult = { 123.23f }; + for (int i = 0; i < result.length; i++) { + assertEquals(expectedResult[i], result[i]); + } + } + + @Test public void testToConvertToBytesForShort() { + short[] input = { 20000, -30000, 23 }; + byte[] result = ValueCompressionUtil.convertToBytes(input); + byte[] expectedResult = { 78, 32, -118, -48, 0, 23 }; + for (int i = 0; i < result.length; i++) { + assertEquals(expectedResult[i], result[i]); + } + } + + @Test public void testToConvertToShort() { + ByteBuffer byteBuffer = ByteBuffer.allocate(2); + byteBuffer.putShort((short) 3); + short[] result = ValueCompressionUtil.convertToShortArray(byteBuffer, 2); + short[] expectedResult = { 3 }; + for (int i = 0; i < result.length; i++) { + assertEquals(expectedResult[i], result[i]); + } + } + + @Test public void testToConvertToBytesForLong() { + long[] input = { 2000000, 300654 }; + byte[] result = ValueCompressionUtil.convertToBytes(input); + byte[] expectedResult = { 0, 0, 0, 0, 0, 30, -124, -128, 0, 0, 0, 0, 0, 4, -106, 110 }; + for (int i = 0; i < result.length; i++) { + assertEquals(expectedResult[i], result[i]); + } + } + + @Test public void testToConvertToLong() { + ByteBuffer byteBuffer = ByteBuffer.allocate(8); + byteBuffer.putLong(321654987); + long[] result = ValueCompressionUtil.convertToLongArray(byteBuffer, 8); + long[] expectedResult = { 321654987 }; + for (int i = 0; i < result.length; i++) { + assertEquals(expectedResult[i], result[i]); + } + } + + @Test public void testToConvertToBytesForDouble() { + double[] input = { 20.236, 30.001 }; + byte[] result = ValueCompressionUtil.convertToBytes(input); + byte[] expectedResult = { 64, 52, 60, 106, 126, -7, -37, 35, 64, 62, 0, 65, -119, 55, 75, -57 }; + for (int i = 0; i < result.length; i++) { + assertEquals(expectedResult[i], result[i]); + } + } + + @Test public void testToConvertToDouble() { + ByteBuffer byteBuffer = ByteBuffer.allocate(8); + byteBuffer.putDouble(3216.54987); + double[] result = ValueCompressionUtil.convertToDoubleArray(byteBuffer, 8); + double[] expectedResult = { 3216.54987 }; + for (int i = 0; i < result.length; i++) { + assertEquals(expectedResult[i], result[i]); + } + } + + @Test public void testToGetValueCompressionModel() { + Object[] maxValues = { 10, 20, 30 }; + Object[] minValues = { 1, 2, 3 }; + int[] decimalLength = { 0, 0, 0 }; + Object[] uniqueValues = { 5, 3, 2 }; + char[] types = { 'c', 'b', 'l' }; + byte[] dataTypeSelected = { 1, 2, 4 }; + MeasureMetaDataModel measureMetaDataModel = + new MeasureMetaDataModel(maxValues, minValues, decimalLength, 3, uniqueValues, types, + dataTypeSelected); + ValueCompressionModel valueCompressionModel = + ValueCompressionUtil.getValueCompressionModel(measureMetaDataModel); + assertEquals(ValueCompressionUtil.COMPRESSION_TYPE.CUSTOM, + valueCompressionModel.getCompType()[0]); + assertEquals(ValueCompressionUtil.COMPRESSION_TYPE.CUSTOM_BIGDECIMAL, + valueCompressionModel.getCompType()[1]); + assertEquals(ValueCompressionUtil.COMPRESSION_TYPE.NONE, + valueCompressionModel.getCompType()[2]); + } + + @Test public void testToGetValueCompressionModelForDefaultAggregatorType() { + Object[] maxValues = { 10.0 }; + Object[] minValues = { 1.0 }; + int[] decimalLength = { 0 }; + Object[] uniqueValues = { 5 }; + char[] types = { 'n' }; + byte[] dataTypeSelected = { 1 }; + MeasureMetaDataModel measureMetaDataModel = + new MeasureMetaDataModel(maxValues, minValues, decimalLength, 1, uniqueValues, types, + dataTypeSelected); + ValueCompressionModel valueCompressionModel = + ValueCompressionUtil.getValueCompressionModel(measureMetaDataModel); + assertEquals(ValueCompressionUtil.COMPRESSION_TYPE.NONE, + valueCompressionModel.getCompType()[0]); + } + + @Test public void testToGetValueCompressionModelForShortAndByte() { + Object[] maxValues = { 32600.00 }; + Object[] minValues = { 32500.00 }; + int[] decimalLength = { 0 }; + Object[] uniqueValues = { 5 }; + char[] types = { 'n' }; + byte[] dataTypeSelected = { 1 }; + MeasureMetaDataModel measureMetaDataModel = + new MeasureMetaDataModel(maxValues, minValues, decimalLength, 1, uniqueValues, types, + dataTypeSelected); + ValueCompressionModel valueCompressionModel = + ValueCompressionUtil.getValueCompressionModel(measureMetaDataModel); + assertEquals(ValueCompressionUtil.COMPRESSION_TYPE.MAX_MIN, + valueCompressionModel.getCompType()[0]); + } + + @Test public void testToGetValueCompressionModelForIntAndShort() { + Object[] maxValues = { 1111111111.0 }; + Object[] minValues = { 1111078433.0 }; + int[] decimalLength = { 0 }; + Object[] uniqueValues = { 5 }; + char[] types = { 'n' }; + byte[] dataTypeSelected = { 1 }; + MeasureMetaDataModel measureMetaDataModel = + new MeasureMetaDataModel(maxValues, minValues, decimalLength, 1, uniqueValues, types, + dataTypeSelected); + ValueCompressionModel valueCompressionModel = + ValueCompressionUtil.getValueCompressionModel(measureMetaDataModel); + assertEquals(ValueCompressionUtil.COMPRESSION_TYPE.MAX_MIN, + valueCompressionModel.getCompType()[0]); + } + + @Test public void testToGetValueCompressionModelForByteAndInt() { + Object[] maxValues = { -32766.00 }; + Object[] minValues = { 32744.0 }; + int[] decimalLength = { 0 }; + Object[] uniqueValues = { 5 }; + char[] types = { 'n' }; + byte[] dataTypeSelected = { 1 }; + MeasureMetaDataModel measureMetaDataModel = + new MeasureMetaDataModel(maxValues, minValues, decimalLength, 1, uniqueValues, types, + dataTypeSelected); + ValueCompressionModel valueCompressionModel = + ValueCompressionUtil.getValueCompressionModel(measureMetaDataModel); + assertEquals(ValueCompressionUtil.COMPRESSION_TYPE.NONE, + valueCompressionModel.getCompType()[0]); + } + + @Test public void testToGetValueCompressionModelForByteAndIntAndDecimal1() { + Object[] maxValues = { -32766.00 }; + Object[] minValues = { 32744.0 }; + int[] decimalLength = { 1 }; + Object[] uniqueValues = { 5 }; + char[] types = { 'n' }; + byte[] dataTypeSelected = { 1 }; + MeasureMetaDataModel measureMetaDataModel = + new MeasureMetaDataModel(maxValues, minValues, decimalLength, 1, uniqueValues, types, + dataTypeSelected); + ValueCompressionModel valueCompressionModel = + ValueCompressionUtil.getValueCompressionModel(measureMetaDataModel); + assertEquals(ValueCompressionUtil.COMPRESSION_TYPE.MAX_MIN, + valueCompressionModel.getCompType()[0]); + } + + @Test public void testToGetValueCompressionModelForByteAndIntAndDataTypeSelected0() { + Object[] maxValues = { -32766.00 }; + Object[] minValues = { 32744.0 }; + int[] decimalLength = { 1 }; + Object[] uniqueValues = { 5 }; + char[] types = { 'n' }; + byte[] dataTypeSelected = { 0 }; + MeasureMetaDataModel measureMetaDataModel = + new MeasureMetaDataModel(maxValues, minValues, decimalLength, 1, uniqueValues, types, + dataTypeSelected); + ValueCompressionModel valueCompressionModel = + ValueCompressionUtil.getValueCompressionModel(measureMetaDataModel); + assertEquals(ValueCompressionUtil.COMPRESSION_TYPE.NON_DECIMAL_CONVERT, + valueCompressionModel.getCompType()[0]); + } + + @Test public void testToGetValueCompressionModelForFloatAndDataTypeSelected1() { + Object[] maxValues = { 32725566.00 }; + Object[] minValues = { 32744.0 }; + int[] decimalLength = { 1 }; + Object[] uniqueValues = { 5 }; + char[] types = { 'n' }; + byte[] dataTypeSelected = { 1 }; + MeasureMetaDataModel measureMetaDataModel = + new MeasureMetaDataModel(maxValues, minValues, decimalLength, 1, uniqueValues, types, + dataTypeSelected); + ValueCompressionModel valueCompressionModel = + ValueCompressionUtil.getValueCompressionModel(measureMetaDataModel); + assertEquals(ValueCompressionUtil.COMPRESSION_TYPE.NONE, + valueCompressionModel.getCompType()[0]); + } + +}