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/02/11 09:38:35 UTC

svn commit: r32441 [4/4] - /dev/hbase/hbase-2.1.3RC1/

Added: dev/hbase/hbase-2.1.3RC1/compatibility_report_2.1.2vs2.1.3RC1.html
==============================================================================
--- dev/hbase/hbase-2.1.3RC1/compatibility_report_2.1.2vs2.1.3RC1.html (added)
+++ dev/hbase/hbase-2.1.3RC1/compatibility_report_2.1.2vs2.1.3RC1.html Mon Feb 11 09:38:34 2019
@@ -0,0 +1,833 @@
+<!-- kind:binary;verdict:compatible;affected:0;added:11;removed:0;type_problems_high:0;type_problems_medium:0;type_problems_low:1;method_problems_high:0;method_problems_medium:0;method_problems_low:0;checked_methods:4758;checked_types:427;tool_version:2.4 -->
+<!-- kind:source;verdict:incompatible;affected:0.4;added:11;removed:0;type_problems_high:3;type_problems_medium:0;type_problems_low:1;method_problems_high:0;method_problems_medium:0;method_problems_low:0;checked_methods:4758;checked_types:427;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.1.2 and 2.1.3RC1 versions" />
+<title>hbase: rel/2.1.2 to 2.1.3RC1 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, "[&minus;]");
+    }
+    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.1.2</span> and <span style='color:Red;'>2.1.3RC1</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.1.2</td></tr>
+<tr><th>Version #2</th><td>2.1.3RC1</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;'>14</a></td></tr>
+<tr><th>Total Methods / Classes</th><td>4758 / 427</td></tr>
+<tr><th>Compatibility</th>
+<td class='compatible'>100%</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;'>11</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>0</td></tr>
+<tr><td>Low</td><td class='warning'><a href='#Type_Binary_Problems_Low' style='color:Blue;'>1</a></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>
+<tr><th>Other Changes<br/>in Data Types</th><td>-</td><td class='passed'><a href='#Other_Binary_Changes_In_Types' style='color:Blue;'>4</a></td></tr>
+<tr><th>Other Changes<br/>in Methods</th><td>-</td><td class='passed'><a href='#Other_Binary_Changes_In_Methods' style='color:Blue;'>1</a></td></tr>
+</table>
+
+<a name='Binary_Added'></a><h2>Added Methods <span class='new'>&nbsp;11&nbsp;</span></h2><hr/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.1.3.jar</span>, <span class='cname'>AsyncConnection.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.client</span><br/>
+<span class="section" onclick="sC(this, 'c_1')">
+AsyncConnection.getHbck&#160;<span class='sym_p'>(&#160;)</span> <span class='attr'>[abstract]</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;CompletableFuture&lt;Hbck&gt;</span></span>
+<br/>
+<div id="c_1" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/client/AsyncConnection.getHbck:()Ljava/util/concurrent/CompletableFuture;</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_2')">
+AsyncConnection.getHbck&#160;<span class='sym_p'><span>(&#160;ServerName <span class='color_p'>p1</span></span>&#160;)</span> <span class='attr'>[abstract]</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;Hbck</span></span>
+<br/>
+<div id="c_2" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/client/AsyncConnection.getHbck:(Lorg/apache/hadoop/hbase/ServerName;)Lorg/apache/hadoop/hbase/client/Hbck;</span><br/><br/></div>
+
+<br/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.1.3.jar</span>, <span class='cname'>AsyncTableRegionLocator.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.client</span><br/>
+<span class="section" onclick="sC(this, 'c_3')">
+AsyncTableRegionLocator.getRegionLocation&#160;<span class='sym_p'><span>(&#160;byte[&#160;] <span class='color_p'>p1</span></span>, <span>int <span class='color_p'>p2</span></span>, <span>boolean <span class='color_p'>p3</span></span>&#160;)</span> <span class='attr'>[abstract]</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;CompletableFuture&lt;HRegionLocation&gt;</span></span>
+<br/>
+<div id="c_3" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/client/AsyncTableRegionLocator.getRegionLocation:([BIZ)Ljava/util/concurrent/CompletableFuture;</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_4')">
+AsyncTableRegionLocator.getRegionLocation&#160;<span class='sym_p'><span>(&#160;byte[&#160;] <span class='color_p'>row</span></span>, <span>int <span class='color_p'>replicaId</span></span>&#160;)</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;CompletableFuture&lt;HRegionLocation&gt;</span></span>
+<br/>
+<div id="c_4" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/client/AsyncTableRegionLocator.getRegionLocation:([BI)Ljava/util/concurrent/CompletableFuture;</span><br/><br/></div>
+
+<br/>
+<span class='jar'>hbase-shaded-mapreduce-2.1.3.jar</span>, <span class='cname'>LossyCounting.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_5')">
+LossyCounting.addByOne&#160;<span class='sym_p'><span>(&#160;String <span class='color_p'>key</span></span>&#160;)</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;Set&lt;String&gt;</span></span>
+<br/>
+<div id="c_5" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/util/LossyCounting.addByOne:(Ljava/lang/String;)Ljava/util/Set;</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_6')">
+LossyCounting.contains&#160;<span class='sym_p'><span>(&#160;String <span class='color_p'>key</span></span>&#160;)</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;boolean</span></span>
+<br/>
+<div id="c_6" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/util/LossyCounting.contains:(Ljava/lang/String;)Z</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_7')">
+LossyCounting.getBuketSize&#160;<span class='sym_p'>(&#160;)</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;long</span></span>
+<br/>
+<div id="c_7" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/util/LossyCounting.getBuketSize:()J</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_8')">
+LossyCounting.getCurrentTerm&#160;<span class='sym_p'>(&#160;)</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;long</span></span>
+<br/>
+<div id="c_8" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/util/LossyCounting.getCurrentTerm:()J</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_9')">
+LossyCounting.getDataSize&#160;<span class='sym_p'>(&#160;)</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;long</span></span>
+<br/>
+<div id="c_9" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/util/LossyCounting.getDataSize:()J</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_10')">
+LossyCounting.LossyCounting&#160;<span class='sym_p'>(&#160;)</span></span>
+<br/>
+<div id="c_10" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/util/LossyCounting.&quot;&lt;init&gt;&quot;:()V</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_11')">
+LossyCounting.LossyCounting&#160;<span class='sym_p'><span>(&#160;double <span class='color_p'>errorRate</span></span>&#160;)</span></span>
+<br/>
+<div id="c_11" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/util/LossyCounting.&quot;&lt;init&gt;&quot;:(D)V</span><br/><br/></div>
+
+<br/>
+<a class='top_ref' href='#Top'>to the top</a><br/>
+<a name='Low_Risk_Binary_Problems'></a><a name='Type_Binary_Problems_Low'></a>
+<h2>Problems with Data Types, Low Severity <span class='warning'>&nbsp;1&nbsp;</span></h2><hr/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.1.2.jar</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.ipc</span><br/>
+<span class="section" onclick="sC(this, 'c_12')">
+<span class='ext'>[+]</span> <span class='ttype'>class</span> StoppedRpcClientException <span class='warning'>&nbsp;1&nbsp;</span></span>
+<br/>
+<div id="c_12" 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>Superclass has been changed from <b>org.apache.hadoop.hbase.HBaseIOException</b> to <b>org.apache.hadoop.hbase.DoNotRetryIOException</b>.</td>
+<td>1) Access of a client program to the fields or methods of the old super-class may be interrupted by <b>NoSuchFieldError</b> or <b>NoSuchMethodError</b> exceptions.<br/>2) A static field from a super-interface of a client class may hide a field (with the same name) inherited from new super-class and cause <b>IncompatibleClassChangeError</b> exception.</td>
+</tr>
+</table><span class="sect_aff" onclick="sC(this, 'c_13')">
+[+] affected methods: 2 (0.04%)</span>
+<div id="c_13" style="display:none;">
+<div class='affected'><span class='iname_a'>StoppedRpcClientException.StoppedRpcClientException&#160;<span class='sym_p'>(&#160;)</span></span><br/><div class='affect'>This constructor is from 'StoppedRpcClientException' class.</div>
+<span class='iname_a'>StoppedRpcClientException.StoppedRpcClientException&#160;<span class='sym_p'><span>(&#160;String <i>msg</i></span>&#160;)</span></span><br/><div class='affect'>This constructor is from 'StoppedRpcClientException' class.</div>
+</div></div>
+<br/><br/></div>
+
+<br/><a class='top_ref' href='#Top'>to the top</a><br/>
+<a name='Other_Binary_Changes'></a><a name='Other_Binary_Changes_In_Types'></a>
+<h2>Other Changes in Data Types <span class='passed'>&nbsp;4&nbsp;</span></h2><hr/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.1.2.jar</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.client</span><br/>
+<span class="section" onclick="sC(this, 'c_14')">
+<span class='ext'>[+]</span> <span class='ttype'>interface</span> AsyncConnection <span class='passed'>&nbsp;2&nbsp;</span></span>
+<br/>
+<div id="c_14" 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>CompletableFuture&lt;Hbck&gt;</b> getHbck&#160;<span class='sym_pd'>(&#160;)</span></span> has been added to this interface.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>2</th>
+<td>Abstract method <span class='iname_b'><b>Hbck</b> getHbck&#160;<span class='sym_pd'><span>(&#160;ServerName</span>&#160;)</span></span> has been added to this interface.</td>
+<td>No effect.</td>
+</tr>
+</table><span class="sect_aff" onclick="sC(this, 'c_15')">
+[+] affected methods: 14 (0.3%)</span>
+<div id="c_15" style="display:none;">
+<div class='affected'><span class='iname_a'>AsyncConnection.getAdmin&#160;<span class='sym_p'>(&#160;)</span></span><br/><div class='affect'>This method is from 'AsyncConnection' interface.</div>
+<span class='iname_a'>AsyncConnection.getAdmin&#160;<span class='sym_p'><span>(&#160;ExecutorService <i>pool</i></span>&#160;)</span></span><br/><div class='affect'>This method is from 'AsyncConnection' interface.</div>
+<span class='iname_a'>AsyncConnection.getAdminBuilder&#160;<span class='sym_p'>(&#160;)</span></span><br/><div class='affect'>This abstract method is from 'AsyncConnection' interface.</div>
+<span class='iname_a'>AsyncConnection.getAdminBuilder&#160;<span class='sym_p'><span>(&#160;ExecutorService <i>p1</i></span>&#160;)</span></span><br/><div class='affect'>This abstract method is from 'AsyncConnection' interface.</div>
+<span class='iname_a'>AsyncConnection.getBufferedMutator&#160;<span class='sym_p'><span>(&#160;TableName <i>tableName</i></span>&#160;)</span></span><br/><div class='affect'>This method is from 'AsyncConnection' interface.</div>
+<span class='iname_a'>AsyncConnection.getBufferedMutator&#160;<span class='sym_p'><span>(&#160;TableName <i>tableName</i></span>, <span>ExecutorService <i>pool</i></span>&#160;)</span></span><br/><div class='affect'>This method is from 'AsyncConnection' interface.</div>
+<span class='iname_a'>AsyncConnection.getBufferedMutatorBuilder&#160;<span class='sym_p'><span>(&#160;TableName <i>p1</i></span>&#160;)</span></span><br/><div class='affect'>This abstract method is from 'AsyncConnection' interface.</div>
+<span class='iname_a'>AsyncConnection.getBufferedMutatorBuilder&#160;<span class='sym_p'><span>(&#160;TableName <i>p1</i></span>, <span>ExecutorService <i>p2</i></span>&#160;)</span></span><br/><div class='affect'>This abstract method is from 'AsyncConnection' interface.</div>
+<span class='iname_a'>AsyncConnection.getConfiguration&#160;<span class='sym_p'>(&#160;)</span></span><br/><div class='affect'>This abstract method is from 'AsyncConnection' interface.</div>
+<span class='iname_a'>AsyncConnection.getRegionLocator&#160;<span class='sym_p'><span>(&#160;TableName <i>p1</i></span>&#160;)</span></span><br/><div class='affect'>This abstract method is from 'AsyncConnection' interface.</div>
+ <b>...</b>
+<br/>
+</div></div>
+<br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_16')">
+<span class='ext'>[+]</span> <span class='ttype'>interface</span> AsyncTableRegionLocator <span class='passed'>&nbsp;2&nbsp;</span></span>
+<br/>
+<div id="c_16" 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>CompletableFuture&lt;HRegionLocation&gt;</b> getRegionLocation&#160;<span class='sym_pd'><span>(&#160;byte[&#160;]</span>, <span>int</span>, <span>boolean</span>&#160;)</span></span> has been added to this interface.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>2</th>
+<td>Method <span class='iname_b'><b>CompletableFuture&lt;HRegionLocation&gt;</b> getRegionLocation&#160;<span class='sym_pd'><span>(&#160;byte[&#160;]</span>, <span>boolean</span>&#160;)</span></span> became <b>default</b>.</td>
+<td>No effect.</td>
+</tr>
+</table><span class="sect_aff" onclick="sC(this, 'c_17')">
+[+] affected methods: 4 (0.1%)</span>
+<div id="c_17" style="display:none;">
+<div class='affected'><span class='iname_a'>AsyncConnection.getRegionLocator&#160;<span class='sym_p'><span>(&#160;TableName <i>p1</i></span>&#160;)</span></span><br/><div class='affect'>Return value  of this abstract method is of type 'AsyncTableRegionLocator'.</div>
+<span class='iname_a'>AsyncTableRegionLocator.getName&#160;<span class='sym_p'>(&#160;)</span></span><br/><div class='affect'>This abstract method is from 'AsyncTableRegionLocator' interface.</div>
+<span class='iname_a'>AsyncTableRegionLocator.getRegionLocation&#160;<span class='sym_p'><span>(&#160;byte[&#160;] <i>row</i></span>&#160;)</span></span><br/><div class='affect'>This method is from 'AsyncTableRegionLocator' interface.</div>
+<span class='iname_a'>AsyncTableRegionLocator.getRegionLocation&#160;<span class='sym_p'><span>(&#160;byte[&#160;] <i>p1</i></span>, <span>boolean <i>p2</i></span>&#160;)</span></span><br/><div class='affect'>This abstract method is from 'AsyncTableRegionLocator' interface.</div>
+</div></div>
+<br/><br/></div>
+
+<br/><a class='top_ref' href='#Top'>to the top</a><br/>
+<a name='Other_Binary_Changes_In_Methods'></a>
+<h2>Other Changes in Methods <span class='passed'>&nbsp;1&nbsp;</span></h2><hr/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.1.2.jar</span>, <span class='cname'>AsyncTableRegionLocator.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.client</span><br/>
+<span class="section" onclick="sC(this, 'c_18')">
+<span class='ext'>[+]</span> AsyncTableRegionLocator.getRegionLocation&#160;<span class='sym_p'><span>(&#160;byte[&#160;] <span class='color_p'>p1</span></span>, <span>boolean <span class='color_p'>p2</span></span>&#160;)</span> <span class='attr'>[abstract]</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;CompletableFuture&lt;HRegionLocation&gt;</span> <span class='passed'>&nbsp;1&nbsp;</span></span>
+<br/>
+<div id="c_18" style="display:none;">
+<span class='mngl pleft'>org/apache/hadoop/hbase/client/AsyncTableRegionLocator.getRegionLocation:([BZ)Ljava/util/concurrent/CompletableFuture;</span><br/>
+<table class='ptable'><tr><th width='2%'></th><th width='47%'>Change</th><th>Effect</th></tr><tr>
+<th>1</th>
+<td>Method became <b>default</b>.</td>
+<td>No effect.</td>
+</tr>
+</table><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'>&nbsp;14&nbsp;</span></h2>
+<hr/><div class='jar_list'>
+hbase-client-project-2.1.2.jar<br/>
+hbase-endpoint-2.1.2.jar<br/>
+hbase-error-prone-2.1.2.jar<br/>
+hbase-examples-2.1.2.jar<br/>
+hbase-external-blockcache-2.1.2.jar<br/>
+hbase-protocol-2.1.2.jar<br/>
+hbase-rest-2.1.2.jar<br/>
+hbase-rsgroup-2.1.2.jar<br/>
+hbase-server-2.1.2.jar<br/>
+hbase-shaded-client-2.1.2.jar<br/>
+hbase-shaded-client-byo-hadoop-2.1.2.jar<br/>
+hbase-shaded-client-project-2.1.2.jar<br/>
+hbase-shaded-mapreduce-2.1.2.jar<br/>
+hbase-thrift-2.1.2.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.1.2</td></tr>
+<tr><th>Version #2</th><td>2.1.3RC1</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;'>14</a></td></tr>
+<tr><th>Total Methods / Classes</th><td>4758 / 427</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;'>11</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;'>3</a></td></tr>
+<tr><td>Medium</td><td>0</td></tr>
+<tr><td>Low</td><td class='warning'><a href='#Type_Source_Problems_Low' style='color:Blue;'>1</a></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>
+<tr><th>Other Changes<br/>in Data Types</th><td>-</td><td class='passed'><a href='#Other_Source_Changes_In_Types' style='color:Blue;'>1</a></td></tr>
+<tr><th>Other Changes<br/>in Methods</th><td>-</td><td class='passed'><a href='#Other_Source_Changes_In_Methods' style='color:Blue;'>1</a></td></tr>
+</table>
+
+<a name='Source_Added'></a><h2>Added Methods <span class='new'>&nbsp;11&nbsp;</span></h2><hr/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.1.3.jar</span>, <span class='cname'>AsyncConnection.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.client</span><br/>
+<span class="section" onclick="sC(this, 'c_19')">
+AsyncConnection.getHbck&#160;<span class='sym_p'>(&#160;)</span> <span class='attr'>[abstract]</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;CompletableFuture&lt;Hbck&gt;</span></span>
+<br/>
+<div id="c_19" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/client/AsyncConnection.getHbck:()Ljava/util/concurrent/CompletableFuture;</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_20')">
+AsyncConnection.getHbck&#160;<span class='sym_p'><span>(&#160;ServerName <span class='color_p'>p1</span></span>&#160;)</span> <span class='attr'>[abstract]</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;Hbck</span></span>
+<br/>
+<div id="c_20" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/client/AsyncConnection.getHbck:(Lorg/apache/hadoop/hbase/ServerName;)Lorg/apache/hadoop/hbase/client/Hbck;</span><br/><br/></div>
+
+<br/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.1.3.jar</span>, <span class='cname'>AsyncTableRegionLocator.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.client</span><br/>
+<span class="section" onclick="sC(this, 'c_21')">
+AsyncTableRegionLocator.getRegionLocation&#160;<span class='sym_p'><span>(&#160;byte[&#160;] <span class='color_p'>p1</span></span>, <span>int <span class='color_p'>p2</span></span>, <span>boolean <span class='color_p'>p3</span></span>&#160;)</span> <span class='attr'>[abstract]</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;CompletableFuture&lt;HRegionLocation&gt;</span></span>
+<br/>
+<div id="c_21" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/client/AsyncTableRegionLocator.getRegionLocation:([BIZ)Ljava/util/concurrent/CompletableFuture;</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_22')">
+AsyncTableRegionLocator.getRegionLocation&#160;<span class='sym_p'><span>(&#160;byte[&#160;] <span class='color_p'>row</span></span>, <span>int <span class='color_p'>replicaId</span></span>&#160;)</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;CompletableFuture&lt;HRegionLocation&gt;</span></span>
+<br/>
+<div id="c_22" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/client/AsyncTableRegionLocator.getRegionLocation:([BI)Ljava/util/concurrent/CompletableFuture;</span><br/><br/></div>
+
+<br/>
+<span class='jar'>hbase-shaded-mapreduce-2.1.3.jar</span>, <span class='cname'>LossyCounting.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_23')">
+LossyCounting.addByOne&#160;<span class='sym_p'><span>(&#160;String <span class='color_p'>key</span></span>&#160;)</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;Set&lt;String&gt;</span></span>
+<br/>
+<div id="c_23" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/util/LossyCounting.addByOne:(Ljava/lang/String;)Ljava/util/Set;</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_24')">
+LossyCounting.contains&#160;<span class='sym_p'><span>(&#160;String <span class='color_p'>key</span></span>&#160;)</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;boolean</span></span>
+<br/>
+<div id="c_24" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/util/LossyCounting.contains:(Ljava/lang/String;)Z</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_25')">
+LossyCounting.getBuketSize&#160;<span class='sym_p'>(&#160;)</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;long</span></span>
+<br/>
+<div id="c_25" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/util/LossyCounting.getBuketSize:()J</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_26')">
+LossyCounting.getCurrentTerm&#160;<span class='sym_p'>(&#160;)</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;long</span></span>
+<br/>
+<div id="c_26" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/util/LossyCounting.getCurrentTerm:()J</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_27')">
+LossyCounting.getDataSize&#160;<span class='sym_p'>(&#160;)</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;long</span></span>
+<br/>
+<div id="c_27" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/util/LossyCounting.getDataSize:()J</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_28')">
+LossyCounting.LossyCounting&#160;<span class='sym_p'>(&#160;)</span></span>
+<br/>
+<div id="c_28" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/util/LossyCounting.&quot;&lt;init&gt;&quot;:()V</span><br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_29')">
+LossyCounting.LossyCounting&#160;<span class='sym_p'><span>(&#160;double <span class='color_p'>errorRate</span></span>&#160;)</span></span>
+<br/>
+<div id="c_29" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/util/LossyCounting.&quot;&lt;init&gt;&quot;:(D)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'>&nbsp;3&nbsp;</span></h2><hr/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.1.2.jar</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.client</span><br/>
+<span class="section" onclick="sC(this, 'c_30')">
+<span class='ext'>[+]</span> <span class='ttype'>interface</span> AsyncConnection <span class='failed'>&nbsp;2&nbsp;</span></span>
+<br/>
+<div id="c_30" 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>CompletableFuture&lt;Hbck&gt;</b> getHbck&#160;<span class='sym_pd'>(&#160;)</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'>getHbck&#160;<span class='sym_pd'>(&#160;)</span></span> in <b>AsyncConnection</b>.</td>
+</tr>
+<tr>
+<th>2</th>
+<td>Abstract method <span class='iname_b'><b>Hbck</b> getHbck&#160;<span class='sym_pd'><span>(&#160;ServerName</span>&#160;)</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'>getHbck&#160;<span class='sym_pd'><span>(&#160;ServerName</span>&#160;)</span></span> in <b>AsyncConnection</b>.</td>
+</tr>
+</table><span class="sect_aff" onclick="sC(this, 'c_31')">
+[+] affected methods: 14 (0.3%)</span>
+<div id="c_31" style="display:none;">
+<div class='affected'><span class='iname_a'>AsyncConnection.getAdmin&#160;<span class='sym_p'>(&#160;)</span></span><br/><div class='affect'>This method is from 'AsyncConnection' interface.</div>
+<span class='iname_a'>AsyncConnection.getAdmin&#160;<span class='sym_p'><span>(&#160;ExecutorService <i>pool</i></span>&#160;)</span></span><br/><div class='affect'>This method is from 'AsyncConnection' interface.</div>
+<span class='iname_a'>AsyncConnection.getAdminBuilder&#160;<span class='sym_p'>(&#160;)</span></span><br/><div class='affect'>This abstract method is from 'AsyncConnection' interface.</div>
+<span class='iname_a'>AsyncConnection.getAdminBuilder&#160;<span class='sym_p'><span>(&#160;ExecutorService <i>p1</i></span>&#160;)</span></span><br/><div class='affect'>This abstract method is from 'AsyncConnection' interface.</div>
+<span class='iname_a'>AsyncConnection.getBufferedMutator&#160;<span class='sym_p'><span>(&#160;TableName <i>tableName</i></span>&#160;)</span></span><br/><div class='affect'>This method is from 'AsyncConnection' interface.</div>
+<span class='iname_a'>AsyncConnection.getBufferedMutator&#160;<span class='sym_p'><span>(&#160;TableName <i>tableName</i></span>, <span>ExecutorService <i>pool</i></span>&#160;)</span></span><br/><div class='affect'>This method is from 'AsyncConnection' interface.</div>
+<span class='iname_a'>AsyncConnection.getBufferedMutatorBuilder&#160;<span class='sym_p'><span>(&#160;TableName <i>p1</i></span>&#160;)</span></span><br/><div class='affect'>This abstract method is from 'AsyncConnection' interface.</div>
+<span class='iname_a'>AsyncConnection.getBufferedMutatorBuilder&#160;<span class='sym_p'><span>(&#160;TableName <i>p1</i></span>, <span>ExecutorService <i>p2</i></span>&#160;)</span></span><br/><div class='affect'>This abstract method is from 'AsyncConnection' interface.</div>
+<span class='iname_a'>AsyncConnection.getConfiguration&#160;<span class='sym_p'>(&#160;)</span></span><br/><div class='affect'>This abstract method is from 'AsyncConnection' interface.</div>
+<span class='iname_a'>AsyncConnection.getRegionLocator&#160;<span class='sym_p'><span>(&#160;TableName <i>p1</i></span>&#160;)</span></span><br/><div class='affect'>This abstract method is from 'AsyncConnection' interface.</div>
+ <b>...</b>
+<br/>
+</div></div>
+<br/><br/></div>
+
+<span class="section" onclick="sC(this, 'c_32')">
+<span class='ext'>[+]</span> <span class='ttype'>interface</span> AsyncTableRegionLocator <span class='failed'>&nbsp;1&nbsp;</span></span>
+<br/>
+<div id="c_32" 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>CompletableFuture&lt;HRegionLocation&gt;</b> getRegionLocation&#160;<span class='sym_pd'><span>(&#160;byte[&#160;]</span>, <span>int</span>, <span>boolean</span>&#160;)</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'>getRegionLocation&#160;<span class='sym_pd'><span>(&#160;byte[&#160;]</span>, <span>int</span>, <span>boolean</span>&#160;)</span></span> in <b>AsyncTableRegionLocator</b>.</td>
+</tr>
+</table><span class="sect_aff" onclick="sC(this, 'c_33')">
+[+] affected methods: 4 (0.1%)</span>
+<div id="c_33" style="display:none;">
+<div class='affected'><span class='iname_a'>AsyncConnection.getRegionLocator&#160;<span class='sym_p'><span>(&#160;TableName <i>p1</i></span>&#160;)</span></span><br/><div class='affect'>Return value  of this abstract method is of type 'AsyncTableRegionLocator'.</div>
+<span class='iname_a'>AsyncTableRegionLocator.getName&#160;<span class='sym_p'>(&#160;)</span></span><br/><div class='affect'>This abstract method is from 'AsyncTableRegionLocator' interface.</div>
+<span class='iname_a'>AsyncTableRegionLocator.getRegionLocation&#160;<span class='sym_p'><span>(&#160;byte[&#160;] <i>row</i></span>&#160;)</span></span><br/><div class='affect'>This method is from 'AsyncTableRegionLocator' interface.</div>
+<span class='iname_a'>AsyncTableRegionLocator.getRegionLocation&#160;<span class='sym_p'><span>(&#160;byte[&#160;] <i>p1</i></span>, <span>boolean <i>p2</i></span>&#160;)</span></span><br/><div class='affect'>This abstract method is from 'AsyncTableRegionLocator' interface.</div>
+</div></div>
+<br/><br/></div>
+
+<br/><a class='top_ref' href='#Top'>to the top</a><br/>
+<a name='Low_Risk_Source_Problems'></a><a name='Type_Source_Problems_Low'></a>
+<h2>Problems with Data Types, Low Severity <span class='warning'>&nbsp;1&nbsp;</span></h2><hr/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.1.2.jar</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.ipc</span><br/>
+<span class="section" onclick="sC(this, 'c_34')">
+<span class='ext'>[+]</span> <span class='ttype'>class</span> StoppedRpcClientException <span class='warning'>&nbsp;1&nbsp;</span></span>
+<br/>
+<div id="c_34" 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>Superclass has been changed from <b>org.apache.hadoop.hbase.HBaseIOException</b> to <b>org.apache.hadoop.hbase.DoNotRetryIOException</b>.</td>
+<td>1) Recompilation of a client program may be terminated with the message: cannot find variable (or method) in <b>StoppedRpcClientException</b>.<br/>2) A static field from a super-interface of a client class may hide a field (with the same name) inherited from new super-class. Recompilation of a client class may be terminated with the message: reference to variable is ambiguous.</td>
+</tr>
+</table><span class="sect_aff" onclick="sC(this, 'c_35')">
+[+] affected methods: 2 (0.04%)</span>
+<div id="c_35" style="display:none;">
+<div class='affected'><span class='iname_a'>StoppedRpcClientException.StoppedRpcClientException&#160;<span class='sym_p'>(&#160;)</span></span><br/><div class='affect'>This constructor is from 'StoppedRpcClientException' class.</div>
+<span class='iname_a'>StoppedRpcClientException.StoppedRpcClientException&#160;<span class='sym_p'><span>(&#160;String <i>msg</i></span>&#160;)</span></span><br/><div class='affect'>This constructor is from 'StoppedRpcClientException' class.</div>
+</div></div>
+<br/><br/></div>
+
+<br/><a class='top_ref' href='#Top'>to the top</a><br/>
+<a name='Other_Source_Changes'></a><a name='Other_Source_Changes_In_Types'></a>
+<h2>Other Changes in Data Types <span class='passed'>&nbsp;1&nbsp;</span></h2><hr/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.1.2.jar</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.client</span><br/>
+<span class="section" onclick="sC(this, 'c_36')">
+<span class='ext'>[+]</span> <span class='ttype'>interface</span> AsyncTableRegionLocator <span class='passed'>&nbsp;1&nbsp;</span></span>
+<br/>
+<div id="c_36" 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>Method <span class='iname_b'><b>CompletableFuture&lt;HRegionLocation&gt;</b> getRegionLocation&#160;<span class='sym_pd'><span>(&#160;byte[&#160;]</span>, <span>boolean</span>&#160;)</span></span> became <b>default</b>.</td>
+<td>No effect.</td>
+</tr>
+</table><span class="sect_aff" onclick="sC(this, 'c_37')">
+[+] affected methods: 1 (0.02%)</span>
+<div id="c_37" style="display:none;">
+<div class='affected'><span class='iname_a'>AsyncTableRegionLocator.getRegionLocation&#160;<span class='sym_p'><span>(&#160;byte[&#160;] <i>p1</i></span>, <span>boolean <i>p2</i></span>&#160;)</span></span><br/><div class='affect'>This abstract method is from 'AsyncTableRegionLocator' interface.</div>
+</div></div>
+<br/><br/></div>
+
+<br/><a class='top_ref' href='#Top'>to the top</a><br/>
+<a name='Other_Source_Changes_In_Methods'></a>
+<h2>Other Changes in Methods <span class='passed'>&nbsp;1&nbsp;</span></h2><hr/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.1.2.jar</span>, <span class='cname'>AsyncTableRegionLocator.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.client</span><br/>
+<span class="section" onclick="sC(this, 'c_38')">
+<span class='ext'>[+]</span> AsyncTableRegionLocator.getRegionLocation&#160;<span class='sym_p'><span>(&#160;byte[&#160;] <span class='color_p'>p1</span></span>, <span>boolean <span class='color_p'>p2</span></span>&#160;)</span> <span class='attr'>[abstract]</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;CompletableFuture&lt;HRegionLocation&gt;</span> <span class='passed'>&nbsp;1&nbsp;</span></span>
+<br/>
+<div id="c_38" style="display:none;">
+<span class='mngl pleft'>org/apache/hadoop/hbase/client/AsyncTableRegionLocator.getRegionLocation:([BZ)Ljava/util/concurrent/CompletableFuture;</span><br/>
+<table class='ptable'><tr><th width='2%'></th><th width='47%'>Change</th><th>Effect</th></tr><tr>
+<th>1</th>
+<td>Method became <b>default</b>.</td>
+<td>No effect.</td>
+</tr>
+</table><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'>&nbsp;14&nbsp;</span></h2>
+<hr/><div class='jar_list'>
+hbase-client-project-2.1.2.jar<br/>
+hbase-endpoint-2.1.2.jar<br/>
+hbase-error-prone-2.1.2.jar<br/>
+hbase-examples-2.1.2.jar<br/>
+hbase-external-blockcache-2.1.2.jar<br/>
+hbase-protocol-2.1.2.jar<br/>
+hbase-rest-2.1.2.jar<br/>
+hbase-rsgroup-2.1.2.jar<br/>
+hbase-server-2.1.2.jar<br/>
+hbase-shaded-client-2.1.2.jar<br/>
+hbase-shaded-client-byo-hadoop-2.1.2.jar<br/>
+hbase-shaded-client-project-2.1.2.jar<br/>
+hbase-shaded-mapreduce-2.1.2.jar<br/>
+hbase-thrift-2.1.2.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 &#160;</i></div><br/>
+</body></html>
\ No newline at end of file

Added: dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-bin.tar.gz
==============================================================================
Binary file - no diff available.

Propchange: dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-bin.tar.gz
------------------------------------------------------------------------------
    svn:mime-type = application/octet-stream

Added: dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-bin.tar.gz.asc
==============================================================================
--- dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-bin.tar.gz.asc (added)
+++ dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-bin.tar.gz.asc Mon Feb 11 09:38:34 2019
@@ -0,0 +1,16 @@
+-----BEGIN PGP SIGNATURE-----
+
+iQIzBAABCgAdFiEE5Uu+PpfPpIqvdkfnqskz15rSrkkFAlxhOSUACgkQqskz15rS
+rklYUxAAqFPLHDQxL6rMY0dEGacO03l2W2rk/H5NAFfNHNVVNnk3GuXebCjS9kHX
+rwoEqMTW0UbGaEn2yLgrQx2AoQ2317N8UkgauPY830ksgx71jctGq02zTL5suj8M
+cE4UUxEcwojcYpjxvvJOtFt4zcrdPJ3Cf93RVjuQtZN3ed1Mgv4F+wP7u65DKSVV
+w+WMSzhrKVXqgzSwMv5arVhjp1nXhRNqxsR8L8VrxsjBQtpNmt1f8q+18J9k0zRf
+gQd18AbY8RHc6mXjBCdO5e7PJsSHymSnSvhO+PY4aNA4YeEhsgcETLYbrJsxr+7p
+Kq43YhhoC+uZfldD9vtX22+07cKYRU6qWe0NCZIxi9sCspxM9A8z8BQeztYSIJiK
+qj3szrIF4IJrbRa/zCqboQEHD5ziEV9D+ABfOBsHznolPFcc42Pu1ntm3UAurkt9
+1xAcyaI0Z6FKproLc0bednrEiQxIfMTTkwrZgLOmAPhpEEESOqKrTJJTqpTsa5E3
+Brr8P/m6T5Yqf/h1ExzpkDQxe0pENfNOum9S2lOwpwrCDWrOXKVm2ko3on6bom9R
+g+v67AhSxkXHQELgyDONWfdD7vYecVgH8jMNy8wThjS5ER9pVuPkzTkK7hiVNcVd
+OKeG6Cn1YnW27sujcpXsMJeKgNJCuKzZYoFs621fKy8MXXYOja4=
+=IltS
+-----END PGP SIGNATURE-----

Added: dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-bin.tar.gz.sha512
==============================================================================
--- dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-bin.tar.gz.sha512 (added)
+++ dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-bin.tar.gz.sha512 Mon Feb 11 09:38:34 2019
@@ -0,0 +1,3 @@
+hbase-2.1.3-bin.tar.gz: F8CB92DC E771E198 FD1EADA7 D036896D 7D46CDA5 D896E06E
+                        62321112 E9CC1219 E87FBE2A E20C76CD E60675C2 FEFC729B
+                        0F6E4A84 792F7D6B 8E06EFC4 7DFB851B

Added: dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-client-bin.tar.gz
==============================================================================
Binary file - no diff available.

Propchange: dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-client-bin.tar.gz
------------------------------------------------------------------------------
    svn:mime-type = application/octet-stream

Added: dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-client-bin.tar.gz.asc
==============================================================================
--- dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-client-bin.tar.gz.asc (added)
+++ dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-client-bin.tar.gz.asc Mon Feb 11 09:38:34 2019
@@ -0,0 +1,16 @@
+-----BEGIN PGP SIGNATURE-----
+
+iQIzBAABCgAdFiEE5Uu+PpfPpIqvdkfnqskz15rSrkkFAlxhOScACgkQqskz15rS
+rkkOjg//YZNmqsWNYfAFhBMyOoaAvKCZjQRiN0aIdv/V/6BonAUUMBVAdUWzzf09
+p7wn5XQP7CyGdbpYB61AHI403W1ezdTKAeaZNI0PmvHgYjHnSx08HzDpJVhPJOGR
+Uwvu9jKAcHALJAu0YkSeLwbCtO1ycvEEc5dh5jONNaNuhXy862Z+SxUtgxuIfJ/c
+uPt4rPdQyAFPn5kvowdPppDdDcQauR7XV5an6BDtidM4VuEsgc0akEnYLZBqts+x
+Pt21cSIlHuXcsG/JmnZ6Jd9qGSVK0ufeMZn8BPj923Y6GFZNVDmEZz4CsvUC2vBV
+mkUkLBvH4uFiiLautqa0L6wJtRa8kFX3IKzS8Z5VURKqHMq6XqvOL6sWpbniP/+n
+R/a062WIDtSP7DTRbYD+EEu61CcRBp/n0KqK3s88AtdT8sP4bHw2bm4S+eQsduUY
+vpPn1QVDoD1E90MrnB4wgOf+XzdekJCRKLzs33PemCc8nMhtbnyBtqpctPS+vmHU
+5aq5aLPd/gmR1N57r3JH1WQTQ3UfQ73Qjod+CyhMjxNlhh0OtYX+Vf/VdPRNrFpE
+U/ZV1L+OfUM6xPxo8o+JRv4ouGeVC+Y9MMZqpc2NCXt42JVGjISfFu1s0j2hnoWE
+nLBhrIPfjpmS0+Dv4YBFwrrkhnmPbXNIhPU3aJ6HdRmdY54k48M=
+=EDSo
+-----END PGP SIGNATURE-----

Added: dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-client-bin.tar.gz.sha512
==============================================================================
--- dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-client-bin.tar.gz.sha512 (added)
+++ dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-client-bin.tar.gz.sha512 Mon Feb 11 09:38:34 2019
@@ -0,0 +1,4 @@
+hbase-2.1.3-client-bin.tar.gz: E6313FD7 5B05566E E9E25E0E 0B1EB321 FE452237
+                               F0B490AC 12FE2FFB 1BA967DA 130E0CB6 FBE3BCB6
+                               F0F9A637 322AE236 2C908504 824FA707 A376C568
+                               8341CF6D

Added: dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-src.tar.gz
==============================================================================
Binary file - no diff available.

Propchange: dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-src.tar.gz
------------------------------------------------------------------------------
    svn:mime-type = application/octet-stream

Added: dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-src.tar.gz.asc
==============================================================================
--- dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-src.tar.gz.asc (added)
+++ dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-src.tar.gz.asc Mon Feb 11 09:38:34 2019
@@ -0,0 +1,16 @@
+-----BEGIN PGP SIGNATURE-----
+
+iQIzBAABCgAdFiEE5Uu+PpfPpIqvdkfnqskz15rSrkkFAlxhOScACgkQqskz15rS
+rkng9g//dbzydJzoX4b8QbV7n5iUKndnS8SMHugiic96hinYR+KctJw5D7xQviNQ
+V3EuMabi+xOoTzrd+Z8KCJFcUalZoAdYszieuq32/60Vi07X8uCWXrW6epWHsjva
+eWwc0A5S/BshkM1s8XBmal8NGqZBXZ60kz9wCT9G3bwtYwZBLewYFIPDBVBUIDh+
+BLlf3GeJz86xKbHJXIVAzreei9TY4fGSdWiYfgj7isFp17G6Jixdmmg86805qkcQ
+Cz5NKaXfermbENL64yentBKDW+lhiDKBZGPZVvdemKNzVViJyjA0Q5fKTKwrk/Rp
+5NOqHCPe1+eneUJXtnqFP4qSpF333ImOJ5Z4AhyFVj5tI8FNape1hmdZzLmg4mUJ
+nAt5em5q7/4WxCN0ml6FdTd8WA7OaU1/TJfFV0itr6cBve/viIPWbP8TmSUgDPf3
+O+rxVKV4jDHKLbmlsBuQ0q3auWUhrxDbQS3DZrIljdrZPjwt0Puqzb/39jAuMHMQ
+ClC/kMoMsrfzFIew8yFf5u3kyY+zQ/SQCND5KCQnFgCgDqmsWgHTpnba1oA04Sv1
+naZ9+k3nBMsfO/ee6/n62aIFjySakJsvRXAoIwr0kGojKx0sRFMlRD6UyHXhcXsc
+yLB1gVYonLjxfsWPALImDwbhtgzK3d7KKG170UkDYE1rXoFsf4g=
+=fKVR
+-----END PGP SIGNATURE-----

Added: dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-src.tar.gz.sha512
==============================================================================
--- dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-src.tar.gz.sha512 (added)
+++ dev/hbase/hbase-2.1.3RC1/hbase-2.1.3-src.tar.gz.sha512 Mon Feb 11 09:38:34 2019
@@ -0,0 +1,3 @@
+hbase-2.1.3-src.tar.gz: 4CD4052D ADD27832 6FA0ABA3 C701825E 3C5E4D37 ADEDAC62
+                        635C2A3D BFAA7234 61C6921C 4A90F97F 730416CF 577FE70F
+                        E740F8D4 1866EB1F BCC0D011 B656CBAC