TestThriftHiveMetastoreUtil.java

/*
 * 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.facebook.presto.hive.metastore.thrift;

import com.facebook.presto.hive.HiveBasicStatistics;
import com.facebook.presto.hive.metastore.BooleanStatistics;
import com.facebook.presto.hive.metastore.DateStatistics;
import com.facebook.presto.hive.metastore.DecimalStatistics;
import com.facebook.presto.hive.metastore.DoubleStatistics;
import com.facebook.presto.hive.metastore.HiveColumnStatistics;
import com.facebook.presto.hive.metastore.IntegerStatistics;
import com.google.common.collect.ImmutableMap;
import org.apache.hadoop.hive.metastore.api.BinaryColumnStatsData;
import org.apache.hadoop.hive.metastore.api.BooleanColumnStatsData;
import org.apache.hadoop.hive.metastore.api.ColumnStatisticsObj;
import org.apache.hadoop.hive.metastore.api.Date;
import org.apache.hadoop.hive.metastore.api.DateColumnStatsData;
import org.apache.hadoop.hive.metastore.api.DecimalColumnStatsData;
import org.apache.hadoop.hive.metastore.api.DoubleColumnStatsData;
import org.apache.hadoop.hive.metastore.api.LongColumnStatsData;
import org.apache.hadoop.hive.metastore.api.Partition;
import org.apache.hadoop.hive.metastore.api.StringColumnStatsData;
import org.testng.annotations.Test;

import java.math.BigDecimal;
import java.time.LocalDate;
import java.util.Optional;
import java.util.OptionalDouble;
import java.util.OptionalLong;

import static com.facebook.presto.hive.metastore.MetastoreUtil.getHiveBasicStatistics;
import static com.facebook.presto.hive.metastore.MetastoreUtil.updateStatisticsParameters;
import static com.facebook.presto.hive.metastore.thrift.ThriftMetastoreUtil.fromMetastoreApiColumnStatistics;
import static com.facebook.presto.hive.metastore.thrift.ThriftMetastoreUtil.toMetastoreDecimal;
import static org.apache.hadoop.hive.metastore.api.ColumnStatisticsData.binaryStats;
import static org.apache.hadoop.hive.metastore.api.ColumnStatisticsData.booleanStats;
import static org.apache.hadoop.hive.metastore.api.ColumnStatisticsData.dateStats;
import static org.apache.hadoop.hive.metastore.api.ColumnStatisticsData.decimalStats;
import static org.apache.hadoop.hive.metastore.api.ColumnStatisticsData.doubleStats;
import static org.apache.hadoop.hive.metastore.api.ColumnStatisticsData.longStats;
import static org.apache.hadoop.hive.metastore.api.ColumnStatisticsData.stringStats;
import static org.apache.hadoop.hive.serde.serdeConstants.BIGINT_TYPE_NAME;
import static org.apache.hadoop.hive.serde.serdeConstants.BINARY_TYPE_NAME;
import static org.apache.hadoop.hive.serde.serdeConstants.BOOLEAN_TYPE_NAME;
import static org.apache.hadoop.hive.serde.serdeConstants.DATE_TYPE_NAME;
import static org.apache.hadoop.hive.serde.serdeConstants.DECIMAL_TYPE_NAME;
import static org.apache.hadoop.hive.serde.serdeConstants.DOUBLE_TYPE_NAME;
import static org.apache.hadoop.hive.serde.serdeConstants.STRING_TYPE_NAME;
import static org.testng.Assert.assertEquals;
import static org.testng.Assert.assertFalse;

public class TestThriftHiveMetastoreUtil
{
    @Test
    public void testLongStatsToColumnStatistics()
    {
        LongColumnStatsData longColumnStatsData = new LongColumnStatsData();
        longColumnStatsData.setLowValue(0);
        longColumnStatsData.setHighValue(100);
        longColumnStatsData.setNumNulls(1);
        longColumnStatsData.setNumDVs(20);
        ColumnStatisticsObj columnStatisticsObj = new ColumnStatisticsObj("my_col", BIGINT_TYPE_NAME, longStats(longColumnStatsData));
        HiveColumnStatistics actual = fromMetastoreApiColumnStatistics(columnStatisticsObj, OptionalLong.of(1000));

        assertEquals(actual.getIntegerStatistics(), Optional.of(new IntegerStatistics(OptionalLong.of(0), OptionalLong.of(100))));
        assertEquals(actual.getDoubleStatistics(), Optional.empty());
        assertEquals(actual.getDecimalStatistics(), Optional.empty());
        assertEquals(actual.getDateStatistics(), Optional.empty());
        assertEquals(actual.getBooleanStatistics(), Optional.empty());
        assertEquals(actual.getMaxValueSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getTotalSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getNullsCount(), OptionalLong.of(1));
        assertEquals(actual.getDistinctValuesCount(), OptionalLong.of(19));
    }

    @Test
    public void testEmptyLongStatsToColumnStatistics()
    {
        LongColumnStatsData emptyLongColumnStatsData = new LongColumnStatsData();
        ColumnStatisticsObj columnStatisticsObj = new ColumnStatisticsObj("my_col", BIGINT_TYPE_NAME, longStats(emptyLongColumnStatsData));
        HiveColumnStatistics actual = fromMetastoreApiColumnStatistics(columnStatisticsObj, OptionalLong.empty());

        assertEquals(actual.getIntegerStatistics(), Optional.of(new IntegerStatistics(OptionalLong.empty(), OptionalLong.empty())));
        assertEquals(actual.getDoubleStatistics(), Optional.empty());
        assertEquals(actual.getDecimalStatistics(), Optional.empty());
        assertEquals(actual.getDateStatistics(), Optional.empty());
        assertEquals(actual.getBooleanStatistics(), Optional.empty());
        assertEquals(actual.getMaxValueSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getTotalSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getNullsCount(), OptionalLong.empty());
        assertEquals(actual.getDistinctValuesCount(), OptionalLong.empty());
    }

    @Test
    public void testDoubleStatsToColumnStatistics()
    {
        DoubleColumnStatsData doubleColumnStatsData = new DoubleColumnStatsData();
        doubleColumnStatsData.setLowValue(0);
        doubleColumnStatsData.setHighValue(100);
        doubleColumnStatsData.setNumNulls(1);
        doubleColumnStatsData.setNumDVs(20);
        ColumnStatisticsObj columnStatisticsObj = new ColumnStatisticsObj("my_col", DOUBLE_TYPE_NAME, doubleStats(doubleColumnStatsData));
        HiveColumnStatistics actual = fromMetastoreApiColumnStatistics(columnStatisticsObj, OptionalLong.of(1000));

        assertEquals(actual.getIntegerStatistics(), Optional.empty());
        assertEquals(actual.getDoubleStatistics(), Optional.of(new DoubleStatistics(OptionalDouble.of(0), OptionalDouble.of(100))));
        assertEquals(actual.getDecimalStatistics(), Optional.empty());
        assertEquals(actual.getDateStatistics(), Optional.empty());
        assertEquals(actual.getBooleanStatistics(), Optional.empty());
        assertEquals(actual.getMaxValueSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getTotalSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getNullsCount(), OptionalLong.of(1));
        assertEquals(actual.getDistinctValuesCount(), OptionalLong.of(19));
    }

    @Test
    public void testEmptyDoubleStatsToColumnStatistics()
    {
        DoubleColumnStatsData emptyDoubleColumnStatsData = new DoubleColumnStatsData();
        ColumnStatisticsObj columnStatisticsObj = new ColumnStatisticsObj("my_col", DOUBLE_TYPE_NAME, doubleStats(emptyDoubleColumnStatsData));
        HiveColumnStatistics actual = fromMetastoreApiColumnStatistics(columnStatisticsObj, OptionalLong.empty());

        assertEquals(actual.getIntegerStatistics(), Optional.empty());
        assertEquals(actual.getDoubleStatistics(), Optional.of(new DoubleStatistics(OptionalDouble.empty(), OptionalDouble.empty())));
        assertEquals(actual.getDecimalStatistics(), Optional.empty());
        assertEquals(actual.getDateStatistics(), Optional.empty());
        assertEquals(actual.getBooleanStatistics(), Optional.empty());
        assertEquals(actual.getMaxValueSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getTotalSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getNullsCount(), OptionalLong.empty());
        assertEquals(actual.getDistinctValuesCount(), OptionalLong.empty());
    }

    @Test
    public void testDecimalStatsToColumnStatistics()
    {
        DecimalColumnStatsData decimalColumnStatsData = new DecimalColumnStatsData();
        BigDecimal low = new BigDecimal("0");
        decimalColumnStatsData.setLowValue(toMetastoreDecimal(low));
        BigDecimal high = new BigDecimal("100");
        decimalColumnStatsData.setHighValue(toMetastoreDecimal(high));
        decimalColumnStatsData.setNumNulls(1);
        decimalColumnStatsData.setNumDVs(20);
        ColumnStatisticsObj columnStatisticsObj = new ColumnStatisticsObj("my_col", DECIMAL_TYPE_NAME, decimalStats(decimalColumnStatsData));
        HiveColumnStatistics actual = fromMetastoreApiColumnStatistics(columnStatisticsObj, OptionalLong.of(1000));

        assertEquals(actual.getIntegerStatistics(), Optional.empty());
        assertEquals(actual.getDoubleStatistics(), Optional.empty());
        assertEquals(actual.getDecimalStatistics(), Optional.of(new DecimalStatistics(Optional.of(low), Optional.of(high))));
        assertEquals(actual.getDateStatistics(), Optional.empty());
        assertEquals(actual.getBooleanStatistics(), Optional.empty());
        assertEquals(actual.getMaxValueSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getTotalSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getNullsCount(), OptionalLong.of(1));
        assertEquals(actual.getDistinctValuesCount(), OptionalLong.of(19));
    }

    @Test
    public void testEmptyDecimalStatsToColumnStatistics()
    {
        DecimalColumnStatsData emptyDecimalColumnStatsData = new DecimalColumnStatsData();
        ColumnStatisticsObj columnStatisticsObj = new ColumnStatisticsObj("my_col", DECIMAL_TYPE_NAME, decimalStats(emptyDecimalColumnStatsData));
        HiveColumnStatistics actual = fromMetastoreApiColumnStatistics(columnStatisticsObj, OptionalLong.empty());

        assertEquals(actual.getIntegerStatistics(), Optional.empty());
        assertEquals(actual.getDoubleStatistics(), Optional.empty());
        assertEquals(actual.getDecimalStatistics(), Optional.of(new DecimalStatistics(Optional.empty(), Optional.empty())));
        assertEquals(actual.getDateStatistics(), Optional.empty());
        assertEquals(actual.getBooleanStatistics(), Optional.empty());
        assertEquals(actual.getMaxValueSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getTotalSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getNullsCount(), OptionalLong.empty());
        assertEquals(actual.getDistinctValuesCount(), OptionalLong.empty());
    }

    @Test
    public void testBooleanStatsToColumnStatistics()
    {
        BooleanColumnStatsData booleanColumnStatsData = new BooleanColumnStatsData();
        booleanColumnStatsData.setNumTrues(100);
        booleanColumnStatsData.setNumFalses(10);
        booleanColumnStatsData.setNumNulls(0);
        ColumnStatisticsObj columnStatisticsObj = new ColumnStatisticsObj("my_col", BOOLEAN_TYPE_NAME, booleanStats(booleanColumnStatsData));
        HiveColumnStatistics actual = fromMetastoreApiColumnStatistics(columnStatisticsObj, OptionalLong.empty());

        assertEquals(actual.getIntegerStatistics(), Optional.empty());
        assertEquals(actual.getDoubleStatistics(), Optional.empty());
        assertEquals(actual.getDecimalStatistics(), Optional.empty());
        assertEquals(actual.getDateStatistics(), Optional.empty());
        assertEquals(actual.getBooleanStatistics(), Optional.of(new BooleanStatistics(OptionalLong.of(100), OptionalLong.of(10))));
        assertEquals(actual.getMaxValueSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getTotalSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getNullsCount(), OptionalLong.of(0));
        assertEquals(actual.getDistinctValuesCount(), OptionalLong.empty());
    }

    @Test
    public void testEmptyBooleanStatsToColumnStatistics()
    {
        BooleanColumnStatsData emptyBooleanColumnStatsData = new BooleanColumnStatsData();
        ColumnStatisticsObj columnStatisticsObj = new ColumnStatisticsObj("my_col", BOOLEAN_TYPE_NAME, booleanStats(emptyBooleanColumnStatsData));
        HiveColumnStatistics actual = fromMetastoreApiColumnStatistics(columnStatisticsObj, OptionalLong.empty());

        assertEquals(actual.getIntegerStatistics(), Optional.empty());
        assertEquals(actual.getDoubleStatistics(), Optional.empty());
        assertEquals(actual.getDecimalStatistics(), Optional.empty());
        assertEquals(actual.getDateStatistics(), Optional.empty());
        assertEquals(actual.getBooleanStatistics(), Optional.of(new BooleanStatistics(OptionalLong.empty(), OptionalLong.empty())));
        assertEquals(actual.getMaxValueSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getTotalSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getNullsCount(), OptionalLong.empty());
        assertEquals(actual.getDistinctValuesCount(), OptionalLong.empty());
    }

    @Test
    public void testDateStatsToColumnStatistics()
    {
        DateColumnStatsData dateColumnStatsData = new DateColumnStatsData();
        dateColumnStatsData.setLowValue(new Date(1000));
        dateColumnStatsData.setHighValue(new Date(2000));
        dateColumnStatsData.setNumNulls(1);
        dateColumnStatsData.setNumDVs(20);
        ColumnStatisticsObj columnStatisticsObj = new ColumnStatisticsObj("my_col", DATE_TYPE_NAME, dateStats(dateColumnStatsData));
        HiveColumnStatistics actual = fromMetastoreApiColumnStatistics(columnStatisticsObj, OptionalLong.of(1000));

        assertEquals(actual.getIntegerStatistics(), Optional.empty());
        assertEquals(actual.getDoubleStatistics(), Optional.empty());
        assertEquals(actual.getDecimalStatistics(), Optional.empty());
        assertEquals(actual.getDateStatistics(), Optional.of(new DateStatistics(Optional.of(LocalDate.ofEpochDay(1000)), Optional.of(LocalDate.ofEpochDay(2000)))));
        assertEquals(actual.getBooleanStatistics(), Optional.empty());
        assertEquals(actual.getMaxValueSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getTotalSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getNullsCount(), OptionalLong.of(1));
        assertEquals(actual.getDistinctValuesCount(), OptionalLong.of(19));
    }

    @Test
    public void testEmptyDateStatsToColumnStatistics()
    {
        DateColumnStatsData emptyDateColumnStatsData = new DateColumnStatsData();
        ColumnStatisticsObj columnStatisticsObj = new ColumnStatisticsObj("my_col", DATE_TYPE_NAME, dateStats(emptyDateColumnStatsData));
        HiveColumnStatistics actual = fromMetastoreApiColumnStatistics(columnStatisticsObj, OptionalLong.empty());

        assertEquals(actual.getIntegerStatistics(), Optional.empty());
        assertEquals(actual.getDoubleStatistics(), Optional.empty());
        assertEquals(actual.getDecimalStatistics(), Optional.empty());
        assertEquals(actual.getDateStatistics(), Optional.of(new DateStatistics(Optional.empty(), Optional.empty())));
        assertEquals(actual.getBooleanStatistics(), Optional.empty());
        assertEquals(actual.getMaxValueSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getTotalSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getNullsCount(), OptionalLong.empty());
        assertEquals(actual.getDistinctValuesCount(), OptionalLong.empty());
    }

    @Test
    public void testStringStatsToColumnStatistics()
    {
        StringColumnStatsData stringColumnStatsData = new StringColumnStatsData();
        stringColumnStatsData.setMaxColLen(100);
        stringColumnStatsData.setAvgColLen(23.333);
        stringColumnStatsData.setNumNulls(1);
        stringColumnStatsData.setNumDVs(20);
        ColumnStatisticsObj columnStatisticsObj = new ColumnStatisticsObj("my_col", STRING_TYPE_NAME, stringStats(stringColumnStatsData));
        HiveColumnStatistics actual = fromMetastoreApiColumnStatistics(columnStatisticsObj, OptionalLong.of(2));

        assertEquals(actual.getIntegerStatistics(), Optional.empty());
        assertEquals(actual.getDoubleStatistics(), Optional.empty());
        assertEquals(actual.getDecimalStatistics(), Optional.empty());
        assertEquals(actual.getDateStatistics(), Optional.empty());
        assertEquals(actual.getBooleanStatistics(), Optional.empty());
        assertEquals(actual.getMaxValueSizeInBytes(), OptionalLong.of(100));
        assertEquals(actual.getTotalSizeInBytes(), OptionalLong.of(23));
        assertEquals(actual.getNullsCount(), OptionalLong.of(1));
        assertEquals(actual.getDistinctValuesCount(), OptionalLong.of(1));
    }

    @Test
    public void testEmptyStringColumnStatsData()
    {
        StringColumnStatsData emptyStringColumnStatsData = new StringColumnStatsData();
        ColumnStatisticsObj columnStatisticsObj = new ColumnStatisticsObj("my_col", STRING_TYPE_NAME, stringStats(emptyStringColumnStatsData));
        HiveColumnStatistics actual = fromMetastoreApiColumnStatistics(columnStatisticsObj, OptionalLong.empty());

        assertEquals(actual.getIntegerStatistics(), Optional.empty());
        assertEquals(actual.getDoubleStatistics(), Optional.empty());
        assertEquals(actual.getDecimalStatistics(), Optional.empty());
        assertEquals(actual.getDateStatistics(), Optional.empty());
        assertEquals(actual.getBooleanStatistics(), Optional.empty());
        assertEquals(actual.getMaxValueSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getTotalSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getNullsCount(), OptionalLong.empty());
        assertEquals(actual.getDistinctValuesCount(), OptionalLong.empty());
    }

    @Test
    public void testBinaryStatsToColumnStatistics()
    {
        BinaryColumnStatsData binaryColumnStatsData = new BinaryColumnStatsData();
        binaryColumnStatsData.setMaxColLen(100);
        binaryColumnStatsData.setAvgColLen(22.2);
        binaryColumnStatsData.setNumNulls(2);
        ColumnStatisticsObj columnStatisticsObj = new ColumnStatisticsObj("my_col", BINARY_TYPE_NAME, binaryStats(binaryColumnStatsData));
        HiveColumnStatistics actual = fromMetastoreApiColumnStatistics(columnStatisticsObj, OptionalLong.of(4));

        assertEquals(actual.getIntegerStatistics(), Optional.empty());
        assertEquals(actual.getDoubleStatistics(), Optional.empty());
        assertEquals(actual.getDecimalStatistics(), Optional.empty());
        assertEquals(actual.getDateStatistics(), Optional.empty());
        assertEquals(actual.getBooleanStatistics(), Optional.empty());
        assertEquals(actual.getMaxValueSizeInBytes(), OptionalLong.of(100));
        assertEquals(actual.getTotalSizeInBytes(), OptionalLong.of(44));
        assertEquals(actual.getNullsCount(), OptionalLong.of(2));
        assertEquals(actual.getDistinctValuesCount(), OptionalLong.empty());
    }

    @Test
    public void testEmptyBinaryStatsToColumnStatistics()
    {
        BinaryColumnStatsData emptyBinaryColumnStatsData = new BinaryColumnStatsData();
        ColumnStatisticsObj columnStatisticsObj = new ColumnStatisticsObj("my_col", BINARY_TYPE_NAME, binaryStats(emptyBinaryColumnStatsData));
        HiveColumnStatistics actual = fromMetastoreApiColumnStatistics(columnStatisticsObj, OptionalLong.empty());

        assertEquals(actual.getIntegerStatistics(), Optional.empty());
        assertEquals(actual.getDoubleStatistics(), Optional.empty());
        assertEquals(actual.getDecimalStatistics(), Optional.empty());
        assertEquals(actual.getDateStatistics(), Optional.empty());
        assertEquals(actual.getBooleanStatistics(), Optional.empty());
        assertEquals(actual.getMaxValueSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getTotalSizeInBytes(), OptionalLong.empty());
        assertEquals(actual.getNullsCount(), OptionalLong.empty());
        assertEquals(actual.getDistinctValuesCount(), OptionalLong.empty());
    }

    @Test
    public void testSingleDistinctValue()
    {
        DoubleColumnStatsData doubleColumnStatsData = new DoubleColumnStatsData();
        doubleColumnStatsData.setNumNulls(10);
        doubleColumnStatsData.setNumDVs(1);
        ColumnStatisticsObj columnStatisticsObj = new ColumnStatisticsObj("my_col", DOUBLE_TYPE_NAME, doubleStats(doubleColumnStatsData));
        HiveColumnStatistics actual = fromMetastoreApiColumnStatistics(columnStatisticsObj, OptionalLong.of(10));

        assertEquals(actual.getNullsCount(), OptionalLong.of(10));
        assertEquals(actual.getDistinctValuesCount(), OptionalLong.of(0));

        doubleColumnStatsData = new DoubleColumnStatsData();
        doubleColumnStatsData.setNumNulls(10);
        doubleColumnStatsData.setNumDVs(1);
        columnStatisticsObj = new ColumnStatisticsObj("my_col", DOUBLE_TYPE_NAME, doubleStats(doubleColumnStatsData));
        actual = fromMetastoreApiColumnStatistics(columnStatisticsObj, OptionalLong.of(11));

        assertEquals(actual.getNullsCount(), OptionalLong.of(10));
        assertEquals(actual.getDistinctValuesCount(), OptionalLong.of(1));
    }

    @Test
    public void testBasicStatisticsRoundTrip()
    {
        testBasicStatisticsRoundTrip(new HiveBasicStatistics(OptionalLong.empty(), OptionalLong.empty(), OptionalLong.empty(), OptionalLong.empty()));
        testBasicStatisticsRoundTrip(new HiveBasicStatistics(OptionalLong.of(1), OptionalLong.empty(), OptionalLong.of(2), OptionalLong.empty()));
        testBasicStatisticsRoundTrip(new HiveBasicStatistics(OptionalLong.of(1), OptionalLong.of(2), OptionalLong.of(3), OptionalLong.of(4)));
    }

    private static void testBasicStatisticsRoundTrip(HiveBasicStatistics expected)
    {
        assertEquals(getHiveBasicStatistics(updateStatisticsParameters(ImmutableMap.of(), expected)), expected);
    }

    @Test
    public void testGetLastDataCommitTimeFromParams()
    {
        Partition partition = new Partition();
        assertEquals(ThriftMetastoreUtil.getLastDataCommitTime(partition), 0);

        partition.setParameters(ImmutableMap.of("lastDataCommitTime", "1"));
        assertEquals(ThriftMetastoreUtil.getLastDataCommitTime(partition), 1);

        partition.setParameters(ImmutableMap.of("lastDataCommitTime", "a"));
        assertEquals(ThriftMetastoreUtil.getLastDataCommitTime(partition), 0);
    }

    @Test
    public void testGetRowIDPartitionComponent()
    {
        Partition partition = new Partition();
        assertFalse(ThriftMetastoreUtil.getRowIDPartitionComponent(partition).isPresent());

        partition.setParameters(ImmutableMap.of("rowIDPartitionComponent", "\u0000\u0001\u00FF"));
        byte[] expected = {0, 1, (byte) 255};
        assertEquals(ThriftMetastoreUtil.getRowIDPartitionComponent(partition).get(), expected);
    }
}