View Javadoc

1   /*
2    * Licensed to the Apache Software Foundation (ASF) under one or more
3    * contributor license agreements. See the NOTICE file distributed with this
4    * work for additional information regarding copyright ownership. The ASF
5    * licenses this file to you under the Apache License, Version 2.0 (the
6    * "License"); you may not use this file except in compliance with the License.
7    * You may obtain a copy of the License at
8    *
9    * http://www.apache.org/licenses/LICENSE-2.0
10   *
11   * Unless required by applicable law or agreed to in writing, software
12   * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
13   * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
14   * License for the specific language governing permissions and limitations
15   * under the License.
16   */
17  package org.apache.hadoop.hbase.io.encoding;
18  
19  import static org.junit.Assert.assertTrue;
20  import static org.junit.Assert.fail;
21  
22  import org.apache.hadoop.hbase.testclassification.SmallTests;
23  import org.junit.Test;
24  import org.junit.experimental.categories.Category;
25  
26  @Category(SmallTests.class)
27  public class TestDataBlockEncoding {
28  
29    @Test
30    public void testGetDataBlockEncoder() throws Exception {
31      for (DataBlockEncoding algo : DataBlockEncoding.values()) {
32        DataBlockEncoder encoder = DataBlockEncoding.getDataBlockEncoderById(algo.getId());
33        if (algo.getId() != 0) {
34          assertTrue(DataBlockEncoding.isCorrectEncoder(encoder, algo.getId()));
35        }
36      }
37      try {
38        DataBlockEncoding.getDataBlockEncoderById((short) -1);
39        fail("Illegal encoderId, should get IllegalArgumentException.");
40      } catch (IllegalArgumentException ie) {
41      }
42      try {
43        DataBlockEncoding.getDataBlockEncoderById(Byte.MAX_VALUE);
44        // fail because idArray[Byte.MAX_VALUE] = null
45        fail("Illegal encoderId, should get IllegalArgumentException.");
46      } catch (IllegalArgumentException ie) {
47      }
48    }
49  
50  }