diff --git a/hbase-common/src/main/java/org/apache/hadoop/hbase/io/hfile/HFileContextBuilder.java b/hbase-common/src/main/java/org/apache/hadoop/hbase/io/hfile/HFileContextBuilder.java index f2131951000a..0394f12144e3 100644 --- a/hbase-common/src/main/java/org/apache/hadoop/hbase/io/hfile/HFileContextBuilder.java +++ b/hbase-common/src/main/java/org/apache/hadoop/hbase/io/hfile/HFileContextBuilder.java @@ -84,6 +84,7 @@ public HFileContextBuilder(final HFileContext hfc) { this.columnFamily = hfc.getColumnFamily(); this.tableName = hfc.getTableName(); this.cellComparator = hfc.getCellComparator(); + this.indexBlockEncoding = hfc.getIndexBlockEncoding(); } public HFileContextBuilder withHBaseCheckSum(boolean useHBaseCheckSum) { diff --git a/hbase-server/src/test/java/org/apache/hadoop/hbase/io/hfile/TestHFile.java b/hbase-server/src/test/java/org/apache/hadoop/hbase/io/hfile/TestHFile.java index c1114770786e..e33708022203 100644 --- a/hbase-server/src/test/java/org/apache/hadoop/hbase/io/hfile/TestHFile.java +++ b/hbase-server/src/test/java/org/apache/hadoop/hbase/io/hfile/TestHFile.java @@ -70,6 +70,7 @@ import org.apache.hadoop.hbase.io.compress.Compression; import org.apache.hadoop.hbase.io.encoding.DataBlockEncoder; import org.apache.hadoop.hbase.io.encoding.DataBlockEncoding; +import org.apache.hadoop.hbase.io.encoding.IndexBlockEncoding; import org.apache.hadoop.hbase.io.hfile.HFile.Reader; import org.apache.hadoop.hbase.io.hfile.HFile.Writer; import org.apache.hadoop.hbase.io.hfile.ReaderContext.ReaderType; @@ -1061,4 +1062,11 @@ private void testReaderCombinedCache(final String l1CachePolicy) throws Exceptio alloc.clean(); } + @Test + public void testHFileContextBuilderWithIndexEncoding() throws IOException { + HFileContext context = + new HFileContextBuilder().withIndexBlockEncoding(IndexBlockEncoding.PREFIX_TREE).build(); + HFileContext newContext = new HFileContextBuilder(context).build(); + assertTrue(newContext.getIndexBlockEncoding() == IndexBlockEncoding.PREFIX_TREE); + } }