[jira] [HBASE-6007] Make getTableRegions return an empty list if the table does not exist

Summary:
Making the getTableRegions Thrift API method handle TableNotFoundException and return an empty list in that case. Without this the behavior is dependent on whether an HTable object is present in the thread-local cache in case a table was deleted.

Test Plan: Unit tests

Reviewers: kannan, liyintang

Reviewed By: liyintang

CC: stack

Differential Revision: https://reviews.facebook.net/D3243

git-svn-id: https://svn.apache.org/repos/asf/hbase/trunk@1340310 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
mbautin 2012-05-19 00:01:15 +00:00
parent ca81969a4f
commit 1a90a79658
1 changed files with 9 additions and 1 deletions

View File

@ -583,11 +583,19 @@ public class ThriftServerRunner implements Runnable {
} }
} }
/**
* @return the list of regions in the given table, or an empty list if the table does not exist
*/
@Override @Override
public List<TRegionInfo> getTableRegions(ByteBuffer tableName) public List<TRegionInfo> getTableRegions(ByteBuffer tableName)
throws IOError { throws IOError {
try { try {
HTable table = getTable(tableName); HTable table;
try {
table = getTable(tableName);
} catch (TableNotFoundException ex) {
return new ArrayList<TRegionInfo>();
}
Map<HRegionInfo, ServerName> regionLocations = Map<HRegionInfo, ServerName> regionLocations =
table.getRegionLocations(); table.getRegionLocations();
List<TRegionInfo> results = new ArrayList<TRegionInfo>(); List<TRegionInfo> results = new ArrayList<TRegionInfo>();