View Javadoc

1   /*
2    *
3    * Licensed to the Apache Software Foundation (ASF) under one
4    * or more contributor license agreements.  See the NOTICE file
5    * distributed with this work for additional information
6    * regarding copyright ownership.  The ASF licenses this file
7    * to you under the Apache License, Version 2.0 (the
8    * "License"); you may not use this file except in compliance
9    * with the License.  You may obtain a copy of the License at
10   *
11   *     http://www.apache.org/licenses/LICENSE-2.0
12   *
13   * Unless required by applicable law or agreed to in writing, software
14   * distributed under the License is distributed on an "AS IS" BASIS,
15   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16   * See the License for the specific language governing permissions and
17   * limitations under the License.
18   */
19  
20  package org.apache.hadoop.hbase.rest.model;
21  
22  import java.util.Iterator;
23  
24  import org.apache.hadoop.hbase.testclassification.SmallTests;
25  import org.apache.hadoop.hbase.TableName;
26  import org.apache.hadoop.hbase.util.Bytes;
27  
28  import org.junit.experimental.categories.Category;
29  
30  @Category(SmallTests.class)
31  public class TestStorageClusterStatusModel extends TestModelBase<StorageClusterStatusModel> {
32  
33    public TestStorageClusterStatusModel() throws Exception {
34      super(StorageClusterStatusModel.class);
35  
36      AS_XML =
37        "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>" +
38        "<ClusterStatus averageLoad=\"1.0\" regions=\"2\" requests=\"0\">" +
39        "<DeadNodes/><LiveNodes>" +
40        "<Node heapSizeMB=\"128\" maxHeapSizeMB=\"1024\" name=\"test1\" requests=\"0\" startCode=\"1245219839331\">" +
41        "<Region currentCompactedKVs=\"1\" memstoreSizeMB=\"0\" name=\"aGJhc2U6cm9vdCwsMA==\" readRequestsCount=\"1\" " +
42        "rootIndexSizeKB=\"1\" storefileIndexSizeMB=\"0\" storefileSizeMB=\"0\" storefiles=\"1\" stores=\"1\" " +
43        "totalCompactingKVs=\"1\" totalStaticBloomSizeKB=\"1\" totalStaticIndexSizeKB=\"1\" writeRequestsCount=\"2\"/>" +
44        "</Node>" +
45        "<Node heapSizeMB=\"512\" maxHeapSizeMB=\"1024\" name=\"test2\" requests=\"0\" startCode=\"1245239331198\">" +
46        "<Region currentCompactedKVs=\"1\" memstoreSizeMB=\"0\" name=\"aGJhc2U6bWV0YSwsMTI0NjAwMDA0MzcyNA==\" " +
47        "readRequestsCount=\"1\" rootIndexSizeKB=\"1\" storefileIndexSizeMB=\"0\" storefileSizeMB=\"0\" " +
48        "storefiles=\"1\" stores=\"1\" totalCompactingKVs=\"1\" totalStaticBloomSizeKB=\"1\" " +
49        "totalStaticIndexSizeKB=\"1\" writeRequestsCount=\"2\"/></Node></LiveNodes></ClusterStatus>";
50  
51      AS_PB =
52        "Cj8KBXRlc3QxEOO6i+eeJBgAIIABKIAIMicKDWhiYXNlOnJvb3QsLDAQARgBIAAoADAAOAFAAkgB" +
53        "UAFYAWABaAEKSwoFdGVzdDIQ/pKx8J4kGAAggAQogAgyMwoZaGJhc2U6bWV0YSwsMTI0NjAwMDA0" +
54        "MzcyNBABGAEgACgAMAA4AUACSAFQAVgBYAFoARgCIAApAAAAAAAA8D8=";
55  
56  
57      //Using jackson will break json backward compatibilty for this representation
58      //but the original one was broken as it would only print one Node element
59      //so the format itself was broken
60      AS_JSON =
61        "{\"regions\":2,\"requests\":0,\"averageLoad\":1.0,\"LiveNodes\":[{\"name\":\"test1\"," +
62            "\"Region\":[{\"name\":\"aGJhc2U6cm9vdCwsMA==\",\"stores\":1,\"storefiles\":1," +
63            "\"storefileSizeMB\":0,\"memstoreSizeMB\":0,\"storefileIndexSizeMB\":0," +
64            "\"readRequestsCount\":1,\"writeRequestsCount\":2,\"rootIndexSizeKB\":1," +
65            "\"totalStaticIndexSizeKB\":1,\"totalStaticBloomSizeKB\":1,\"totalCompactingKVs\":1," +
66            "\"currentCompactedKVs\":1}],\"requests\":0,\"startCode\":1245219839331," +
67            "\"heapSizeMB\":128,\"maxHeapSizeMB\":1024},{\"name\":\"test2\"," +
68            "\"Region\":[{\"name\":\"aGJhc2U6bWV0YSwsMTI0NjAwMDA0MzcyNA==\",\"stores\":1," +
69            "\"storefiles\":1,\"storefileSizeMB\":0,\"memstoreSizeMB\":0,\"storefileIndexSizeMB\":0," +
70            "\"readRequestsCount\":1,\"writeRequestsCount\":2,\"rootIndexSizeKB\":1," +
71            "\"totalStaticIndexSizeKB\":1,\"totalStaticBloomSizeKB\":1,\"totalCompactingKVs\":1," +
72            "\"currentCompactedKVs\":1}],\"requests\":0,\"startCode\":1245239331198," +
73            "\"heapSizeMB\":512,\"maxHeapSizeMB\":1024}],\"DeadNodes\":[]}";
74    }
75  
76    protected StorageClusterStatusModel buildTestModel() {
77      StorageClusterStatusModel model = new StorageClusterStatusModel();
78      model.setRegions(2);
79      model.setRequests(0);
80      model.setAverageLoad(1.0);
81      model.addLiveNode("test1", 1245219839331L, 128, 1024)
82        .addRegion(Bytes.toBytes("hbase:root,,0"), 1, 1, 0, 0, 0, 1, 2, 1, 1, 1, 1, 1);
83      model.addLiveNode("test2", 1245239331198L, 512, 1024)
84        .addRegion(Bytes.toBytes(TableName.META_TABLE_NAME+",,1246000043724"),1, 1, 0, 0, 0,
85            1, 2, 1, 1, 1, 1, 1);
86      return model;
87    }
88  
89    protected void checkModel(StorageClusterStatusModel model) {
90      assertEquals(model.getRegions(), 2);
91      assertEquals(model.getRequests(), 0);
92      assertEquals(model.getAverageLoad(), 1.0);
93      Iterator<StorageClusterStatusModel.Node> nodes =
94        model.getLiveNodes().iterator();
95      StorageClusterStatusModel.Node node = nodes.next();
96      assertEquals(node.getName(), "test1");
97      assertEquals(node.getStartCode(), 1245219839331L);
98      assertEquals(node.getHeapSizeMB(), 128);
99      assertEquals(node.getMaxHeapSizeMB(), 1024);
100     Iterator<StorageClusterStatusModel.Node.Region> regions = 
101       node.getRegions().iterator();
102     StorageClusterStatusModel.Node.Region region = regions.next();
103     assertTrue(Bytes.toString(region.getName()).equals(
104         "hbase:root,,0"));
105     assertEquals(region.getStores(), 1);
106     assertEquals(region.getStorefiles(), 1);
107     assertEquals(region.getStorefileSizeMB(), 0);
108     assertEquals(region.getMemstoreSizeMB(), 0);
109     assertEquals(region.getStorefileIndexSizeMB(), 0);
110     assertEquals(region.getReadRequestsCount(), 1);
111     assertEquals(region.getWriteRequestsCount(), 2);
112     assertEquals(region.getRootIndexSizeKB(), 1);
113     assertEquals(region.getTotalStaticIndexSizeKB(), 1);
114     assertEquals(region.getTotalStaticBloomSizeKB(), 1);
115     assertEquals(region.getTotalCompactingKVs(), 1);
116     assertEquals(region.getCurrentCompactedKVs(), 1);
117     assertFalse(regions.hasNext());
118     node = nodes.next();
119     assertEquals(node.getName(), "test2");
120     assertEquals(node.getStartCode(), 1245239331198L);
121     assertEquals(node.getHeapSizeMB(), 512);
122     assertEquals(node.getMaxHeapSizeMB(), 1024);
123     regions = node.getRegions().iterator();
124     region = regions.next();
125     assertEquals(Bytes.toString(region.getName()),
126         TableName.META_TABLE_NAME+",,1246000043724");
127     assertEquals(region.getStores(), 1);
128     assertEquals(region.getStorefiles(), 1);
129     assertEquals(region.getStorefileSizeMB(), 0);
130     assertEquals(region.getMemstoreSizeMB(), 0);
131     assertEquals(region.getStorefileIndexSizeMB(), 0);
132     assertEquals(region.getReadRequestsCount(), 1);
133     assertEquals(region.getWriteRequestsCount(), 2);
134     assertEquals(region.getRootIndexSizeKB(), 1);
135     assertEquals(region.getTotalStaticIndexSizeKB(), 1);
136     assertEquals(region.getTotalStaticBloomSizeKB(), 1);
137     assertEquals(region.getTotalCompactingKVs(), 1);
138     assertEquals(region.getCurrentCompactedKVs(), 1);
139     
140     assertFalse(regions.hasNext());
141     assertFalse(nodes.hasNext());
142   }
143 }
144