You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@hbase.apache.org by zh...@apache.org on 2019/10/25 04:08:07 UTC
svn commit: r36480 [4/4] - in /release/hbase: 2.2.1/ 2.2.2/
Added: release/hbase/2.2.2/api_compare_2.2.1_to_2.2.2RC0.html
==============================================================================
--- release/hbase/2.2.2/api_compare_2.2.1_to_2.2.2RC0.html (added)
+++ release/hbase/2.2.2/api_compare_2.2.1_to_2.2.2RC0.html Fri Oct 25 04:08:07 2019
@@ -0,0 +1,679 @@
+<!-- kind:binary;verdict:incompatible;affected:0.2;added:10;removed:0;type_problems_high:0;type_problems_medium:1;type_problems_low:0;method_problems_high:0;method_problems_medium:0;method_problems_low:0;checked_methods:5332;checked_types:444;tool_version:2.4 -->
+<!-- kind:source;verdict:incompatible;affected:0.4;added:10;removed:0;type_problems_high:1;type_problems_medium:0;type_problems_low:0;method_problems_high:0;method_problems_medium:0;method_problems_low:0;checked_methods:5332;checked_types:444;tool_version:2.4 -->
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
+<head>
+<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
+<meta name="viewport" content="width=device-width,initial-scale=1" />
+<meta name="keywords" content="hbase, compatibility" />
+<meta name="description" content="Compatibility report for the hbase library between rel/2.2.1 and 2.2.2RC0 versions" />
+<title>hbase: rel/2.2.1 to 2.2.2RC0 compatibility report</title>
+<style type="text/css">
+body {
+ font-family:Arial, sans-serif;
+ background-color:White;
+ color:Black;
+}
+hr {
+ color:Black;
+ background-color:Black;
+ height:1px;
+ border:0;
+}
+h1 {
+ margin-bottom:0px;
+ padding-bottom:0px;
+ font-size:1.625em;
+}
+h2 {
+ margin-bottom:0px;
+ padding-bottom:0px;
+ font-size:1.25em;
+ white-space:nowrap;
+}
+div.symbols {
+ color:#003E69;
+}
+div.symbols i {
+ color:Brown;
+}
+span.section {
+ font-weight:bold;
+ cursor:pointer;
+ color:#003E69;
+ white-space:nowrap;
+ margin-left:0.3125em;
+}
+span:hover.section {
+ color:#336699;
+}
+span.sect_aff {
+ cursor:pointer;
+ padding-left:1.55em;
+ font-size:0.875em;
+ color:#cc3300;
+}
+span.ext {
+ font-weight:normal;
+}
+span.jar {
+ color:#cc3300;
+ font-size:0.875em;
+ font-weight:bold;
+}
+div.jar_list {
+ padding-left:0.4em;
+ font-size:0.94em;
+}
+span.pkg_t {
+ color:#408080;
+ font-size:0.875em;
+}
+span.pkg {
+ color:#408080;
+ font-size:0.875em;
+ font-weight:bold;
+}
+span.cname {
+ color:Green;
+ font-size:0.875em;
+ font-weight:bold;
+}
+span.iname_b {
+ font-weight:bold;
+}
+span.iname_a {
+ color:#333333;
+ font-weight:bold;
+ font-size:0.94em;
+}
+span.sym_p {
+ font-weight:normal;
+ white-space:normal;
+}
+span.sym_pd {
+ white-space:normal;
+}
+span.sym_p span, span.sym_pd span {
+ white-space:nowrap;
+}
+span.attr {
+ color:Black;
+ font-weight:normal;
+}
+span.deprecated {
+ color:Red;
+ font-weight:bold;
+ font-family:Monaco, monospace;
+}
+div.affect {
+ padding-left:1em;
+ padding-bottom:10px;
+ font-size:0.87em;
+ font-style:italic;
+ line-height:0.9em;
+}
+div.affected {
+ padding-left:2em;
+ padding-top:10px;
+}
+table.ptable {
+ border-collapse:collapse;
+ border:1px outset black;
+ margin-left:0.95em;
+ margin-top:3px;
+ margin-bottom:3px;
+ width:56.25em;
+}
+table.ptable td {
+ border:1px solid Gray;
+ padding:3px;
+ font-size:0.875em;
+ text-align:left;
+ vertical-align:top;
+ max-width:28em;
+ word-wrap:break-word;
+}
+table.ptable th {
+ background-color:#eeeeee;
+ font-weight:bold;
+ color:#333333;
+ font-family:Verdana, Arial;
+ font-size:0.875em;
+ border:1px solid Gray;
+ text-align:center;
+ vertical-align:top;
+ white-space:nowrap;
+ padding:3px;
+}
+table.summary {
+ border-collapse:collapse;
+ border:1px outset black;
+}
+table.summary th {
+ background-color:#eeeeee;
+ font-weight:normal;
+ text-align:left;
+ font-size:0.94em;
+ white-space:nowrap;
+ border:1px inset Gray;
+ padding:3px;
+}
+table.summary td {
+ text-align:right;
+ white-space:nowrap;
+ border:1px inset Gray;
+ padding:3px 5px 3px 10px;
+}
+span.mngl {
+ padding-left:1em;
+ font-size:0.875em;
+ cursor:text;
+ color:#444444;
+ font-weight:bold;
+}
+span.pleft {
+ padding-left:2.5em;
+}
+span.color_p {
+ font-style:italic;
+ color:Brown;
+}
+span.param {
+ font-style:italic;
+}
+span.focus_p {
+ font-style:italic;
+ background-color:#DCDCDC;
+}
+span.ttype {
+ font-weight:normal;
+}
+span.nowrap {
+ white-space:nowrap;
+}
+span.value {
+ white-space:nowrap;
+ font-weight:bold;
+}
+.passed {
+ background-color:#CCFFCC;
+ font-weight:normal;
+}
+.warning {
+ background-color:#F4F4AF;
+ font-weight:normal;
+}
+.failed {
+ background-color:#FFCCCC;
+ font-weight:normal;
+}
+.new {
+ background-color:#C6DEFF;
+ font-weight:normal;
+}
+
+.compatible {
+ background-color:#CCFFCC;
+ font-weight:normal;
+}
+.almost_compatible {
+ background-color:#FFDAA3;
+ font-weight:normal;
+}
+.incompatible {
+ background-color:#FFCCCC;
+ font-weight:normal;
+}
+.gray {
+ background-color:#DCDCDC;
+ font-weight:normal;
+}
+
+.top_ref {
+ font-size:0.69em;
+}
+.footer {
+ font-size:0.8125em;
+}
+.tabset {
+ float:left;
+}
+a.tab {
+ border:1px solid Black;
+ float:left;
+ margin:0px 5px -1px 0px;
+ padding:3px 5px 3px 5px;
+ position:relative;
+ font-size:0.875em;
+ background-color:#DDD;
+ text-decoration:none;
+ color:Black;
+}
+a.disabled:hover
+{
+ color:Black;
+ background:#EEE;
+}
+a.active:hover
+{
+ color:Black;
+ background:White;
+}
+a.active {
+ border-bottom-color:White;
+ background-color:White;
+}
+div.tab {
+ border-top:1px solid Black;
+ padding:0px;
+ width:100%;
+ clear:both;
+}
+
+</style>
+<script type="text/javascript" language="JavaScript">
+<!--
+function sC(header, id)
+{
+ e = document.getElementById(id);
+ if(e.style.display == 'none')
+ {
+ e.style.display = 'block';
+ e.style.visibility = 'visible';
+ header.innerHTML = header.innerHTML.replace(/\[[^0-9 ]\]/gi, "[−]");
+ }
+ else
+ {
+ e.style.display = 'none';
+ e.style.visibility = 'hidden';
+ header.innerHTML = header.innerHTML.replace(/\[[^0-9 ]\]/gi, "[+]");
+ }
+}
+function initTabs()
+{
+ var url = window.location.href;
+ if(url.indexOf('_Source_')!=-1 || url.indexOf('#Source')!=-1)
+ {
+ var tab1 = document.getElementById('BinaryID');
+ var tab2 = document.getElementById('SourceID');
+ tab1.className='tab disabled';
+ tab2.className='tab active';
+ }
+
+ var sets = document.getElementsByTagName('div');
+ for (var i = 0; i < sets.length; i++)
+ {
+ if (sets[i].className.indexOf('tabset') != -1)
+ {
+ var tabs = [];
+ var links = sets[i].getElementsByTagName('a');
+ for (var j = 0; j < links.length; j++)
+ {
+ if (links[j].className.indexOf('tab') != -1)
+ {
+ tabs.push(links[j]);
+ links[j].tabs = tabs;
+ var tab = document.getElementById(links[j].href.substr(links[j].href.indexOf('#') + 1));
+ //reset all tabs on start
+ if (tab)
+ {
+ if (links[j].className.indexOf('active')!=-1) {
+ tab.style.display = 'block';
+ }
+ else {
+ tab.style.display = 'none';
+ }
+ }
+ links[j].onclick = function()
+ {
+ var tab = document.getElementById(this.href.substr(this.href.indexOf('#') + 1));
+ if (tab)
+ {
+ //reset all tabs before change
+ for (var k = 0; k < this.tabs.length; k++)
+ {
+ document.getElementById(this.tabs[k].href.substr(this.tabs[k].href.indexOf('#') + 1)).style.display = 'none';
+ this.tabs[k].className = this.tabs[k].className.replace('active', 'disabled');
+ }
+ this.className = 'tab active';
+ tab.style.display = 'block';
+ // window.location.hash = this.id.replace('ID', '');
+ return false;
+ }
+ }
+ }
+ }
+ }
+ }
+
+ if(url.indexOf('#')!=-1) {
+ location.href=location.href;
+ }
+}
+
+if (window.addEventListener) window.addEventListener('load', initTabs, false);
+else if (window.attachEvent) window.attachEvent('onload', initTabs);
+
+-->
+</script>
+</head>
+<body><a name='Source'></a><a name='Binary'></a><a name='Top'></a><h1>API compatibility report for the <span style='color:Blue;'>hbase</span> library between <span style='color:Red;'>rel/2.2.1</span> and <span style='color:Red;'>2.2.2RC0</span> versions</h1>
+<br/><div class='tabset'>
+<a id='BinaryID' href='#BinaryTab' class='tab active'>Binary<br/>Compatibility</a>
+<a id='SourceID' href='#SourceTab' style='margin-left:3px' class='tab disabled'>Source<br/>Compatibility</a>
+</div>
+<div id='BinaryTab' class='tab'>
+<h2>Test Info</h2><hr/>
+<table class='summary'>
+<tr><th>Library Name</th><td>hbase</td></tr>
+<tr><th>Version #1</th><td>rel/2.2.1</td></tr>
+<tr><th>Version #2</th><td>2.2.2RC0</td></tr>
+<tr><th>Subject</th><td width='150px'>Binary Compatibility</td></tr>
+</table>
+<h2>Test Results</h2><hr/>
+<table class='summary'>
+<tr><th>Total Java Modules</th><td><a href='#Checked_Archives' style='color:Blue;'>12</a></td></tr>
+<tr><th>Total Methods / Classes</th><td>5332 / 444</td></tr>
+<tr><th>Compatibility</th>
+<td class='warning'>99.8%</td>
+</tr>
+</table>
+<h2>Problem Summary</h2><hr/>
+<table class='summary'>
+<tr><th></th><th style='text-align:center;'>Severity</th><th style='text-align:center;'>Count</th></tr>
+<tr><th>Added Methods</th><td>-</td><td class='new'><a href='#Binary_Added' style='color:Blue;'>10</a></td></tr>
+<tr><th>Removed Methods</th><td>High</td><td>0</td></tr>
+<tr><th rowspan='3'>Problems with<br/>Data Types</th><td>High</td><td>0</td></tr>
+<tr><td>Medium</td><td class='failed'><a href='#Type_Binary_Problems_Medium' style='color:Blue;'>1</a></td></tr>
+<tr><td>Low</td><td>0</td></tr>
+<tr><th rowspan='3'>Problems with<br/>Methods</th><td>High</td><td>0</td></tr>
+<tr><td>Medium</td><td>0</td></tr>
+<tr><td>Low</td><td>0</td></tr>
+</table>
+
+<a name='Binary_Added'></a><h2>Added Methods <span class='new'> 10 </span></h2><hr/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.2.2.jar</span>, <span class='cname'>ClusterMetrics.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase</span><br/>
+<span class="section" onclick="sC(this, 'c_1')">
+ClusterMetrics.getTableRegionStatesCount <span class='sym_p'>( )</span> <span class='attr'>[abstract]</span><span class='sym_p nowrap'>  <b>:</b>  Map<TableName,RegionStatesCount></span></span>
+<br/>
+<div id="c_1" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/ClusterMetrics.getTableRegionStatesCount:()Ljava/util/Map;</span><br/><br/></div>
+
+<br/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.2.2.jar</span>, <span class='cname'>ClusterStatus.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase</span><br/>
+<span class="section" onclick="sC(this, 'c_2')">
+ClusterStatus.getTableRegionStatesCount <span class='sym_p'>( )</span><span class='sym_p nowrap'>  <b>:</b>  Map<TableName,RegionStatesCount></span></span>
+<br/>
+<div id="c_2" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/ClusterStatus.getTableRegionStatesCount:()Ljava/util/Map;</span><br/><br/></div>
+
+<br/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.2.2.jar</span>, <span class='cname'>VersionInfo.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.util</span><br/>
+<span class="section" onclick="sC(this, 'c_3')">
+VersionInfo.getMajorVersion <span class='sym_p'><span>( String <span class='color_p'>version</span></span> )</span> <span class='attr'>[static]</span><span class='sym_p nowrap'>  <b>:</b>  int</span></span>
+<br/>
+<div id="c_3" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/util/VersionInfo.getMajorVersion:(Ljava/lang/String;)I</span><br/><br/></div>
+
+<br/>
+<span class='jar'>hbase-shaded-testing-util-2.2.2.jar</span>, <span class='cname'>Canary.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.tool</span><br/>
+<span class="section" onclick="sC(this, 'c_4')">
+Canary.checkRegions <span class='sym_p'><span>( String[ ] <span class='color_p'>p1</span></span> )</span> <span class='attr'>[abstract]</span><span class='sym_p nowrap'>  <b>:</b>  int</span></span>
+<br/>
+<div id="c_4" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/tool/Canary.checkRegions:([Ljava/lang/String;)I</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_5')">
+Canary.checkRegionServers <span class='sym_p'><span>( String[ ] <span class='color_p'>p1</span></span> )</span> <span class='attr'>[abstract]</span><span class='sym_p nowrap'>  <b>:</b>  int</span></span>
+<br/>
+<div id="c_5" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/tool/Canary.checkRegionServers:([Ljava/lang/String;)I</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_6')">
+Canary.checkZooKeeper <span class='sym_p'>( )</span> <span class='attr'>[abstract]</span><span class='sym_p nowrap'>  <b>:</b>  int</span></span>
+<br/>
+<div id="c_6" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/tool/Canary.checkZooKeeper:()I</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_7')">
+Canary.create <span class='sym_p'><span>( Configuration <span class='color_p'>conf</span></span>, <span>ExecutorService <span class='color_p'>executor</span></span> )</span> <span class='attr'>[static]</span><span class='sym_p nowrap'>  <b>:</b>  Canary</span></span>
+<br/>
+<div id="c_7" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/tool/Canary.create:(Lorg/apache/hadoop/conf/Configuration;Ljava/util/concurrent/ExecutorService;)Lorg/apache/hadoop/hbase/tool/Canary;</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_8')">
+Canary.create <span class='sym_p'><span>( Configuration <span class='color_p'>conf</span></span>, <span>ExecutorService <span class='color_p'>executor</span></span>, <span>CanaryTool.Sink <span class='color_p'>sink</span></span> )</span> <span class='attr'>[static]</span><span class='sym_p nowrap'>  <b>:</b>  Canary</span></span>
+<br/>
+<div id="c_8" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/tool/Canary.create:(Lorg/apache/hadoop/conf/Configuration;Ljava/util/concurrent/ExecutorService;Lorg/apache/hadoop/hbase/tool/CanaryTool$Sink;)Lorg/apache/hadoop/hbase/tool/Canary;</span><br/><br/></div>
+
+<br/>
+<span class='jar'>hbase-shaded-testing-util-2.2.2.jar</span>, <span class='cname'>HBaseTestingUtility.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase</span><br/>
+<span class="section" onclick="sC(this, 'c_9')">
+HBaseTestingUtility.restartHBaseCluster <span class='sym_p'><span>( StartMiniClusterOption <span class='color_p'>option</span></span> )</span><span class='sym_p nowrap'>  <b>:</b>  void</span></span>
+<br/>
+<div id="c_9" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/HBaseTestingUtility.restartHBaseCluster:(Lorg/apache/hadoop/hbase/StartMiniClusterOption;)V</span><br/><br/></div>
+
+<br/>
+<span class='jar'>hbase-shaded-testing-util-2.2.2.jar</span>, <span class='cname'>LoadIncrementalHFiles.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.tool</span><br/>
+<span class="section" onclick="sC(this, 'c_10')">
+LoadIncrementalHFiles.setClusterIds <span class='sym_p'><span>( List<String> <span class='color_p'>clusterIds</span></span> )</span><span class='sym_p nowrap'>  <b>:</b>  void</span></span>
+<br/>
+<div id="c_10" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/tool/LoadIncrementalHFiles.setClusterIds:(Ljava/util/List;)V</span><br/><br/></div>
+
+<br/>
+<a class='top_ref' href='#Top'>to the top</a><br/>
+<a name='Medium_Risk_Binary_Problems'></a><a name='Type_Binary_Problems_Medium'></a>
+<h2>Problems with Data Types, Medium Severity <span class='failed'> 1 </span></h2><hr/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.2.1.jar</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase</span><br/>
+<span class="section" onclick="sC(this, 'c_11')">
+<span class='ext'>[+]</span> <span class='ttype'>interface</span> ClusterMetrics <span class='failed'> 1 </span></span>
+<br/>
+<div id="c_11" style="display:none;">
+<table class='ptable'><tr><th width='2%'></th><th width='47%'>Change</th><th>Effect</th></tr><tr>
+<th>1</th>
+<td>Abstract method <span class='iname_b'><b>Map<TableName,RegionStatesCount></b> getTableRegionStatesCount <span class='sym_pd'>( )</span></span> has been added to this interface.</td>
+<td>A client program may be interrupted by <b>AbstractMethodError</b> exception. Added abstract method is called in 2nd library version by the method <span class='iname_b'>ClusterMetricsBuilder.toClusterStatus <span class='sym_pd'><span>( ClusterMetrics</span> )</span></span> and may not be implemented by old clients.</td>
+</tr>
+</table><span class="sect_aff" onclick="sC(this, 'c_12')">
+[+] affected methods: 20 (0.4%)</span>
+<div id="c_12" style="display:none;">
+<div class='affected'><span class='iname_a'>client.Admin.getClusterMetrics <span class='sym_p'>( )</span></span><br/><div class='affect'>Return value of this method is of type 'ClusterMetrics'.</div>
+<span class='iname_a'>client.Admin.getClusterMetrics <span class='sym_p'><span>( EnumSet<ClusterMetrics.Option> <i>p1</i></span> )</span></span><br/><div class='affect'>Return value of this abstract method is of type 'ClusterMetrics'.</div>
+<span class='iname_a'>ClusterMetrics.getAverageLoad <span class='sym_p'>( )</span></span><br/><div class='affect'>This method is from 'ClusterMetrics' interface.</div>
+<span class='iname_a'>ClusterMetrics.getBackupMasterNames <span class='sym_p'>( )</span></span><br/><div class='affect'>This abstract method is from 'ClusterMetrics' interface.</div>
+<span class='iname_a'>ClusterMetrics.getBalancerOn <span class='sym_p'>( )</span></span><br/><div class='affect'>This abstract method is from 'ClusterMetrics' interface.</div>
+<span class='iname_a'>ClusterMetrics.getClusterId <span class='sym_p'>( )</span></span><br/><div class='affect'>This abstract method is from 'ClusterMetrics' interface.</div>
+<span class='iname_a'>ClusterMetrics.getDeadServerNames <span class='sym_p'>( )</span></span><br/><div class='affect'>This abstract method is from 'ClusterMetrics' interface.</div>
+<span class='iname_a'>ClusterMetrics.getHBaseVersion <span class='sym_p'>( )</span></span><br/><div class='affect'>This abstract method is from 'ClusterMetrics' interface.</div>
+<span class='iname_a'>ClusterMetrics.getLastMajorCompactionTimestamp <span class='sym_p'><span>( byte[ ] <i>regionName</i></span> )</span></span><br/><div class='affect'>This method is from 'ClusterMetrics' interface.</div>
+<span class='iname_a'>ClusterMetrics.getLastMajorCompactionTimestamp <span class='sym_p'><span>( TableName <i>table</i></span> )</span></span><br/><div class='affect'>This method is from 'ClusterMetrics' interface.</div>
+ <b>...</b>
+<br/>
+</div></div>
+<br/><br/></div>
+
+<br/><a class='top_ref' href='#Top'>to the top</a><br/>
+<a name='Checked_Archives'></a><h2>Java Archives <span class='gray'> 12 </span></h2>
+<hr/><div class='jar_list'>
+hbase-client-project-2.2.1.jar<br/>
+hbase-endpoint-2.2.1.jar<br/>
+hbase-examples-2.2.1.jar<br/>
+hbase-external-blockcache-2.2.1.jar<br/>
+hbase-protocol-2.2.1.jar<br/>
+hbase-rest-2.2.1.jar<br/>
+hbase-rsgroup-2.2.1.jar<br/>
+hbase-shaded-client-byo-hadoop-2.2.1.jar<br/>
+hbase-shaded-client-project-2.2.1.jar<br/>
+hbase-shaded-mapreduce-2.2.1.jar<br/>
+hbase-shaded-testing-util-2.2.1.jar<br/>
+hbase-thrift-2.2.1.jar<br/>
+</div><br/><a class='top_ref' href='#Top'>to the top</a><br/>
+<br/><br/><br/></div><div id='SourceTab' class='tab'>
+<h2>Test Info</h2><hr/>
+<table class='summary'>
+<tr><th>Library Name</th><td>hbase</td></tr>
+<tr><th>Version #1</th><td>rel/2.2.1</td></tr>
+<tr><th>Version #2</th><td>2.2.2RC0</td></tr>
+<tr><th>Subject</th><td width='150px'>Source Compatibility</td></tr>
+</table>
+<h2>Test Results</h2><hr/>
+<table class='summary'>
+<tr><th>Total Java Modules</th><td><a href='#Checked_Archives' style='color:Blue;'>12</a></td></tr>
+<tr><th>Total Methods / Classes</th><td>5332 / 444</td></tr>
+<tr><th>Compatibility</th>
+<td class='warning'>99.6%</td>
+</tr>
+</table>
+<h2>Problem Summary</h2><hr/>
+<table class='summary'>
+<tr><th></th><th style='text-align:center;'>Severity</th><th style='text-align:center;'>Count</th></tr>
+<tr><th>Added Methods</th><td>-</td><td class='new'><a href='#Source_Added' style='color:Blue;'>10</a></td></tr>
+<tr><th>Removed Methods</th><td>High</td><td>0</td></tr>
+<tr><th rowspan='3'>Problems with<br/>Data Types</th><td>High</td><td class='failed'><a href='#Type_Source_Problems_High' style='color:Blue;'>1</a></td></tr>
+<tr><td>Medium</td><td>0</td></tr>
+<tr><td>Low</td><td>0</td></tr>
+<tr><th rowspan='3'>Problems with<br/>Methods</th><td>High</td><td>0</td></tr>
+<tr><td>Medium</td><td>0</td></tr>
+<tr><td>Low</td><td>0</td></tr>
+</table>
+
+<a name='Source_Added'></a><h2>Added Methods <span class='new'> 10 </span></h2><hr/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.2.2.jar</span>, <span class='cname'>ClusterMetrics.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase</span><br/>
+<span class="section" onclick="sC(this, 'c_13')">
+ClusterMetrics.getTableRegionStatesCount <span class='sym_p'>( )</span> <span class='attr'>[abstract]</span><span class='sym_p nowrap'>  <b>:</b>  Map<TableName,RegionStatesCount></span></span>
+<br/>
+<div id="c_13" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/ClusterMetrics.getTableRegionStatesCount:()Ljava/util/Map;</span><br/><br/></div>
+
+<br/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.2.2.jar</span>, <span class='cname'>ClusterStatus.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase</span><br/>
+<span class="section" onclick="sC(this, 'c_14')">
+ClusterStatus.getTableRegionStatesCount <span class='sym_p'>( )</span><span class='sym_p nowrap'>  <b>:</b>  Map<TableName,RegionStatesCount></span></span>
+<br/>
+<div id="c_14" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/ClusterStatus.getTableRegionStatesCount:()Ljava/util/Map;</span><br/><br/></div>
+
+<br/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.2.2.jar</span>, <span class='cname'>VersionInfo.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.util</span><br/>
+<span class="section" onclick="sC(this, 'c_15')">
+VersionInfo.getMajorVersion <span class='sym_p'><span>( String <span class='color_p'>version</span></span> )</span> <span class='attr'>[static]</span><span class='sym_p nowrap'>  <b>:</b>  int</span></span>
+<br/>
+<div id="c_15" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/util/VersionInfo.getMajorVersion:(Ljava/lang/String;)I</span><br/><br/></div>
+
+<br/>
+<span class='jar'>hbase-shaded-testing-util-2.2.2.jar</span>, <span class='cname'>Canary.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.tool</span><br/>
+<span class="section" onclick="sC(this, 'c_16')">
+Canary.checkRegions <span class='sym_p'><span>( String[ ] <span class='color_p'>p1</span></span> )</span> <span class='attr'>[abstract]</span><span class='sym_p nowrap'>  <b>:</b>  int</span></span>
+<br/>
+<div id="c_16" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/tool/Canary.checkRegions:([Ljava/lang/String;)I</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_17')">
+Canary.checkRegionServers <span class='sym_p'><span>( String[ ] <span class='color_p'>p1</span></span> )</span> <span class='attr'>[abstract]</span><span class='sym_p nowrap'>  <b>:</b>  int</span></span>
+<br/>
+<div id="c_17" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/tool/Canary.checkRegionServers:([Ljava/lang/String;)I</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_18')">
+Canary.checkZooKeeper <span class='sym_p'>( )</span> <span class='attr'>[abstract]</span><span class='sym_p nowrap'>  <b>:</b>  int</span></span>
+<br/>
+<div id="c_18" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/tool/Canary.checkZooKeeper:()I</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_19')">
+Canary.create <span class='sym_p'><span>( Configuration <span class='color_p'>conf</span></span>, <span>ExecutorService <span class='color_p'>executor</span></span> )</span> <span class='attr'>[static]</span><span class='sym_p nowrap'>  <b>:</b>  Canary</span></span>
+<br/>
+<div id="c_19" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/tool/Canary.create:(Lorg/apache/hadoop/conf/Configuration;Ljava/util/concurrent/ExecutorService;)Lorg/apache/hadoop/hbase/tool/Canary;</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_20')">
+Canary.create <span class='sym_p'><span>( Configuration <span class='color_p'>conf</span></span>, <span>ExecutorService <span class='color_p'>executor</span></span>, <span>CanaryTool.Sink <span class='color_p'>sink</span></span> )</span> <span class='attr'>[static]</span><span class='sym_p nowrap'>  <b>:</b>  Canary</span></span>
+<br/>
+<div id="c_20" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/tool/Canary.create:(Lorg/apache/hadoop/conf/Configuration;Ljava/util/concurrent/ExecutorService;Lorg/apache/hadoop/hbase/tool/CanaryTool$Sink;)Lorg/apache/hadoop/hbase/tool/Canary;</span><br/><br/></div>
+
+<br/>
+<span class='jar'>hbase-shaded-testing-util-2.2.2.jar</span>, <span class='cname'>HBaseTestingUtility.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase</span><br/>
+<span class="section" onclick="sC(this, 'c_21')">
+HBaseTestingUtility.restartHBaseCluster <span class='sym_p'><span>( StartMiniClusterOption <span class='color_p'>option</span></span> )</span><span class='sym_p nowrap'>  <b>:</b>  void</span></span>
+<br/>
+<div id="c_21" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/HBaseTestingUtility.restartHBaseCluster:(Lorg/apache/hadoop/hbase/StartMiniClusterOption;)V</span><br/><br/></div>
+
+<br/>
+<span class='jar'>hbase-shaded-testing-util-2.2.2.jar</span>, <span class='cname'>LoadIncrementalHFiles.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.tool</span><br/>
+<span class="section" onclick="sC(this, 'c_22')">
+LoadIncrementalHFiles.setClusterIds <span class='sym_p'><span>( List<String> <span class='color_p'>clusterIds</span></span> )</span><span class='sym_p nowrap'>  <b>:</b>  void</span></span>
+<br/>
+<div id="c_22" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/tool/LoadIncrementalHFiles.setClusterIds:(Ljava/util/List;)V</span><br/><br/></div>
+
+<br/>
+<a class='top_ref' href='#Top'>to the top</a><br/>
+<a name='High_Risk_Source_Problems'></a><a name='Type_Source_Problems_High'></a>
+<h2>Problems with Data Types, High Severity <span class='failed'> 1 </span></h2><hr/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.2.1.jar</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase</span><br/>
+<span class="section" onclick="sC(this, 'c_23')">
+<span class='ext'>[+]</span> <span class='ttype'>interface</span> ClusterMetrics <span class='failed'> 1 </span></span>
+<br/>
+<div id="c_23" style="display:none;">
+<table class='ptable'><tr><th width='2%'></th><th width='47%'>Change</th><th>Effect</th></tr><tr>
+<th>1</th>
+<td>Abstract method <span class='iname_b'><b>Map<TableName,RegionStatesCount></b> getTableRegionStatesCount <span class='sym_pd'>( )</span></span> has been added to this interface.</td>
+<td>Recompilation of a client program may be terminated with the message: a client class C is not abstract and does not override abstract method <span class='iname_b'>getTableRegionStatesCount <span class='sym_pd'>( )</span></span> in <b>ClusterMetrics</b>.</td>
+</tr>
+</table><span class="sect_aff" onclick="sC(this, 'c_24')">
+[+] affected methods: 20 (0.4%)</span>
+<div id="c_24" style="display:none;">
+<div class='affected'><span class='iname_a'>client.Admin.getClusterMetrics <span class='sym_p'>( )</span></span><br/><div class='affect'>Return value of this method is of type 'ClusterMetrics'.</div>
+<span class='iname_a'>client.Admin.getClusterMetrics <span class='sym_p'><span>( EnumSet<ClusterMetrics.Option> <i>p1</i></span> )</span></span><br/><div class='affect'>Return value of this abstract method is of type 'ClusterMetrics'.</div>
+<span class='iname_a'>ClusterMetrics.getAverageLoad <span class='sym_p'>( )</span></span><br/><div class='affect'>This method is from 'ClusterMetrics' interface.</div>
+<span class='iname_a'>ClusterMetrics.getBackupMasterNames <span class='sym_p'>( )</span></span><br/><div class='affect'>This abstract method is from 'ClusterMetrics' interface.</div>
+<span class='iname_a'>ClusterMetrics.getBalancerOn <span class='sym_p'>( )</span></span><br/><div class='affect'>This abstract method is from 'ClusterMetrics' interface.</div>
+<span class='iname_a'>ClusterMetrics.getClusterId <span class='sym_p'>( )</span></span><br/><div class='affect'>This abstract method is from 'ClusterMetrics' interface.</div>
+<span class='iname_a'>ClusterMetrics.getDeadServerNames <span class='sym_p'>( )</span></span><br/><div class='affect'>This abstract method is from 'ClusterMetrics' interface.</div>
+<span class='iname_a'>ClusterMetrics.getHBaseVersion <span class='sym_p'>( )</span></span><br/><div class='affect'>This abstract method is from 'ClusterMetrics' interface.</div>
+<span class='iname_a'>ClusterMetrics.getLastMajorCompactionTimestamp <span class='sym_p'><span>( byte[ ] <i>regionName</i></span> )</span></span><br/><div class='affect'>This method is from 'ClusterMetrics' interface.</div>
+<span class='iname_a'>ClusterMetrics.getLastMajorCompactionTimestamp <span class='sym_p'><span>( TableName <i>table</i></span> )</span></span><br/><div class='affect'>This method is from 'ClusterMetrics' interface.</div>
+ <b>...</b>
+<br/>
+</div></div>
+<br/><br/></div>
+
+<br/><a class='top_ref' href='#Top'>to the top</a><br/>
+<a name='Checked_Archives'></a><h2>Java Archives <span class='gray'> 12 </span></h2>
+<hr/><div class='jar_list'>
+hbase-client-project-2.2.1.jar<br/>
+hbase-endpoint-2.2.1.jar<br/>
+hbase-examples-2.2.1.jar<br/>
+hbase-external-blockcache-2.2.1.jar<br/>
+hbase-protocol-2.2.1.jar<br/>
+hbase-rest-2.2.1.jar<br/>
+hbase-rsgroup-2.2.1.jar<br/>
+hbase-shaded-client-byo-hadoop-2.2.1.jar<br/>
+hbase-shaded-client-project-2.2.1.jar<br/>
+hbase-shaded-mapreduce-2.2.1.jar<br/>
+hbase-shaded-testing-util-2.2.1.jar<br/>
+hbase-thrift-2.2.1.jar<br/>
+</div><br/><a class='top_ref' href='#Top'>to the top</a><br/>
+<br/><br/><br/></div><hr/><div class='footer' align='right'><i>Generated by <a href='https://github.com/lvc/japi-compliance-checker'>Java API Compliance Checker</a> 2.4  </i></div><br/>
+</body></html>
\ No newline at end of file
Added: release/hbase/2.2.2/hbase-2.2.2-bin.tar.gz
==============================================================================
Binary file - no diff available.
Propchange: release/hbase/2.2.2/hbase-2.2.2-bin.tar.gz
------------------------------------------------------------------------------
svn:mime-type = application/octet-stream
Added: release/hbase/2.2.2/hbase-2.2.2-bin.tar.gz.asc
==============================================================================
--- release/hbase/2.2.2/hbase-2.2.2-bin.tar.gz.asc (added)
+++ release/hbase/2.2.2/hbase-2.2.2-bin.tar.gz.asc Fri Oct 25 04:08:07 2019
@@ -0,0 +1,16 @@
+-----BEGIN PGP SIGNATURE-----
+
+iQIzBAABCgAdFiEE5Uu+PpfPpIqvdkfnqskz15rSrkkFAl2q6fEACgkQqskz15rS
+rklobg/9GHrf377rZFL6+JnZPwAnJv5X5Rq0GwtLc2cUxoFfPvV4UaADbjJ3s2uK
+RkNtCtjhZAlDCr6gktCCGct6vtYqQr+s1ZJxrzfGdIS4dQV0ktuXGUHsyyyn2P+m
+rakKrN9werDtxZ+eJG3b12Jbz2VIR+jKmLPEN1JCwrlDVJMqGSRV+/+4Rz5a5+m/
+jJtra0Zz5eVY00VCwa4oNXVv5WIs4mjPVEmKGquPZhipJWX/5ZWt4B7VIRb9eYHc
+RiHLXKo7v2IgMCKb821091HbL4nkWLvgp3ImklsIReUOYqLxVSXgyMlLptluoQ3u
+YZLod+YsW3eXkwoV5F0BfhKLFn/7muGUYye4l5/mY59/St4YhQy28EkatklKPk/a
+soBXv6vQ+w3xB/dLgVI6u8cLF6UYOxEWLk4fFDv9/UYQDU+KW43Amvan1GAbzKft
+u+eIDGGLI7fbi4Kg4X40NlYz0EoFjgqOgP14jfYTej0AavRyPnDbdThAbrYGO+E4
+xHfNRu+EaQISb4xKQfX92r7WK6OgQ4F1l8qPUNnd+ItAkB9sXAJReARBN6pCTqcf
+iasEYICNDk7sh34uVnWtOhIskCR6l9qb/ggwR30qzTotiY1ZTbjppD2VntFx8fEv
++yMNmB4Ivj2QBw+mq+hkgfU3TAMZaFuu8EjyNTr+vPBjZVX4otE=
+=lLei
+-----END PGP SIGNATURE-----
Added: release/hbase/2.2.2/hbase-2.2.2-bin.tar.gz.sha512
==============================================================================
--- release/hbase/2.2.2/hbase-2.2.2-bin.tar.gz.sha512 (added)
+++ release/hbase/2.2.2/hbase-2.2.2-bin.tar.gz.sha512 Fri Oct 25 04:08:07 2019
@@ -0,0 +1,3 @@
+hbase-2.2.2-bin.tar.gz: 3D266C10 154BF093 4D43B430 87BFD3D5 251D2DA1 ABD6FE07
+ 7FC0787E 74218B41 FDA134FD B021DA90 39BCDE4D D6CB3D96
+ 0429F38F 8B55E0FF 9076E7E5 747A44BB
Added: release/hbase/2.2.2/hbase-2.2.2-client-bin.tar.gz
==============================================================================
Binary file - no diff available.
Propchange: release/hbase/2.2.2/hbase-2.2.2-client-bin.tar.gz
------------------------------------------------------------------------------
svn:mime-type = application/octet-stream
Added: release/hbase/2.2.2/hbase-2.2.2-client-bin.tar.gz.asc
==============================================================================
--- release/hbase/2.2.2/hbase-2.2.2-client-bin.tar.gz.asc (added)
+++ release/hbase/2.2.2/hbase-2.2.2-client-bin.tar.gz.asc Fri Oct 25 04:08:07 2019
@@ -0,0 +1,16 @@
+-----BEGIN PGP SIGNATURE-----
+
+iQIzBAABCgAdFiEE5Uu+PpfPpIqvdkfnqskz15rSrkkFAl2q6fMACgkQqskz15rS
+rkke0g//UWuqVyfED2QoOfttJkrLQoY2lHory7k6WTp8GOXbx972uUFlKt+ACx/V
+fj1VBKhMvaMSZ+TD79eXKgDwFcoqo6zS7kpS9fkUL4RakO1QYHTQoQJdM8bRqEak
+ePzChtUaymie70EASzTkthdM5tFwHT2XVrdA3klzC3Mc4+sqgzDbSoGFwQytbjon
+SBUdpSyd3T7t3CskNFLsUA0g6BUkAm2DUad0WpFTK7/Tylx936ZIn8y1XY8DqsJg
+iM5u1W7v4aCqN6Cm5a9hqk19NTlo4G3CsxdBs9uRQZb7qfbhnLHkuZNcXnJ0+PBQ
+q1CpzUyLEynJ5+r1vjWhTvRS8HrT+G01AP+Wo1sJfAtH7fAGth5kXhmQ3qw/oB80
+xRLNyuFG9IXjtYxEku8pZb22VDCrV3LP1YSd/pSNzuBy0l7k5Lls7+W36xBYWn8U
+3wfi228CTHQ9I+00G6XoCYC795yc8tI4tahSCOYbtjHGSR3muowyXjcohzTM9Di6
+nwMbnN3ijgqyJz8LqxJnhnlZS0xjKPYteNDzBU6TOj/xNJhKvWhZNpPitkJzlakP
+5NdVum6W06cMofv7kwNhdB118terdoM1Oc6Pn1ziFXiz3kVXYwJ+vIZrZ3IC+t1z
+wkP+MvqHbVXNS5IkozEoX9n/L/6rlki3ZF+M9s2g5mzUEy9YLIo=
+=cin6
+-----END PGP SIGNATURE-----
Added: release/hbase/2.2.2/hbase-2.2.2-client-bin.tar.gz.sha512
==============================================================================
--- release/hbase/2.2.2/hbase-2.2.2-client-bin.tar.gz.sha512 (added)
+++ release/hbase/2.2.2/hbase-2.2.2-client-bin.tar.gz.sha512 Fri Oct 25 04:08:07 2019
@@ -0,0 +1,4 @@
+hbase-2.2.2-client-bin.tar.gz: B0B8DDD1 3B0059F3 D992DE68 F8DD725B DF58E5D5
+ 9EC9075A 0D0C9D17 7BF2E196 A1D43EEA BB5913C2
+ 6317B542 D14056CA 4A987D0E 404F1F97 2979DAFE
+ F840A026
Added: release/hbase/2.2.2/hbase-2.2.2-src.tar.gz
==============================================================================
Binary file - no diff available.
Propchange: release/hbase/2.2.2/hbase-2.2.2-src.tar.gz
------------------------------------------------------------------------------
svn:mime-type = application/octet-stream
Added: release/hbase/2.2.2/hbase-2.2.2-src.tar.gz.asc
==============================================================================
--- release/hbase/2.2.2/hbase-2.2.2-src.tar.gz.asc (added)
+++ release/hbase/2.2.2/hbase-2.2.2-src.tar.gz.asc Fri Oct 25 04:08:07 2019
@@ -0,0 +1,16 @@
+-----BEGIN PGP SIGNATURE-----
+
+iQIzBAABCgAdFiEE5Uu+PpfPpIqvdkfnqskz15rSrkkFAl2q3usACgkQqskz15rS
+rknl7Q/8C9kL/peOW0e8p8Xylb27qJlwsekCLQ/yX1zgPt8prmi26E3Rq5yPlFPE
+P6LVWifp9P5S2PBtbQ8qG9F2DRi8FlsQN6SpkPbYz9UnyJ1lazi7u589nAIjx3lp
+QWCwweI7g/0xVjm+ODazx3TYp+qQ4eTBmMQUGa7RHCEktvW7Vjqv/tYK9qu9ZjIg
+YYj700mWKHeo5sduD3susRpsk6cM0aW5/tmJPzeXcA7pgwzG/iF7fWQC1X/a3xDn
+vbRHs7m0vAS/n3unsmNrVebAA4rl5Ml/lzkJLobqOhfw5GZFnDwF98/vIXMaF/dX
+MkOSQUCPme3O7oSwzwkcF6ZyDcsOr+zMfIid5j+IO/sv8A1OOQE1kI4la9OJ1NyA
+BfF7jg6in90YCYPQnlEewGhPTDF2zK8eW7P2uCOHEQTzZewt2NG1Hpq3610qdC49
+0VGoZQqs0TIzl7wghC+L2YmncJ+JK59vjG4O0xlpKct8yCbyHkuofFkTf+usUJth
+TEj6ASHKa0mfoWkKyknS0K3ykyhG1aQjFr98ze/2nCveDsWmDpAhczh+nF95CJVU
+3wFrNRlmpaFmAIzcfKNkJszHYNP1Ha5Vyn0WGRGMlf3bHvXA4G6v50Bm8/U9+DbH
+hr1nEDJom5pBzj845/YFC3cjpKICnYH4TAT9YiEORm4UiqOepmc=
+=0SRd
+-----END PGP SIGNATURE-----
Added: release/hbase/2.2.2/hbase-2.2.2-src.tar.gz.sha512
==============================================================================
--- release/hbase/2.2.2/hbase-2.2.2-src.tar.gz.sha512 (added)
+++ release/hbase/2.2.2/hbase-2.2.2-src.tar.gz.sha512 Fri Oct 25 04:08:07 2019
@@ -0,0 +1,3 @@
+hbase-2.2.2-src.tar.gz: BF06B387 2E8868CA 67985DDB 7418450E 704C0568 CC912B9D
+ B8AEB78C ADF2AC83 B1CA8353 6B18C67E A206682E 10412C60
+ 74099675 3A3E70BE 5393D299 2221CE3B