From ee4ae11695bc0c806585c279011890e370dae70b Mon Sep 17 00:00:00 2001 From: eomiks Date: Tue, 12 Apr 2022 21:46:21 +0900 Subject: [PATCH] HBASE-26895 on hbase shell, 'delete/deleteall' for a columnfamily is not working (#4283) Signed-off-by: Duo Zhang (cherry picked from commit ea9bc92ce2aa43a18c944b10153678f86eca2d7a) --- hbase-shell/src/main/ruby/hbase/table.rb | 12 ++++++++++-- hbase-shell/src/test/ruby/hbase/table_test.rb | 15 +++++++++++++++ 2 files changed, 25 insertions(+), 2 deletions(-) diff --git a/hbase-shell/src/main/ruby/hbase/table.rb b/hbase-shell/src/main/ruby/hbase/table.rb index c93e75fc285..fc63785d689 100644 --- a/hbase-shell/src/main/ruby/hbase/table.rb +++ b/hbase-shell/src/main/ruby/hbase/table.rb @@ -189,10 +189,18 @@ EOF if column != "" if column && all_version family, qualifier = parse_column_name(column) - d.addColumns(family, qualifier, timestamp) + if qualifier + d.addColumns(family, qualifier, timestamp) + else + d.addFamily(family, timestamp) + end elsif column && !all_version family, qualifier = parse_column_name(column) - d.addColumn(family, qualifier, timestamp) + if qualifier + d.addColumn(family, qualifier, timestamp) + else + d.addFamilyVersion(family, timestamp) + end end end d diff --git a/hbase-shell/src/test/ruby/hbase/table_test.rb b/hbase-shell/src/test/ruby/hbase/table_test.rb index cb274f814aa..05b80725efc 100644 --- a/hbase-shell/src/test/ruby/hbase/table_test.rb +++ b/hbase-shell/src/test/ruby/hbase/table_test.rb @@ -164,6 +164,21 @@ module Hbase assert_nil(res) end + define_test "delete should set proper cell type" do + del = @test_table._createdelete_internal('104', 'x:a', 1212) + assert_equal(del.get('x'.to_java_bytes, 'a'.to_java_bytes).get(0).getType.getCode, + org.apache.hadoop.hbase::KeyValue::Type::DeleteColumn.getCode) + del = @test_table._createdelete_internal('104', 'x:a', 1212, [], false) + assert_equal(del.get('x'.to_java_bytes, 'a'.to_java_bytes).get(0).getType.getCode, + org.apache.hadoop.hbase::KeyValue::Type::Delete.getCode) + del = @test_table._createdelete_internal('104', 'x', 1212) + assert_equal(del.get('x'.to_java_bytes, nil).get(0).getType.getCode, + org.apache.hadoop.hbase::KeyValue::Type::DeleteFamily.getCode) + del = @test_table._createdelete_internal('104', 'x', 1212, [], false) + assert_equal(del.get('x'.to_java_bytes, nil).get(0).getType.getCode, + org.apache.hadoop.hbase::KeyValue::Type::DeleteFamilyVersion.getCode) + end + #------------------------------------------------------------------------------- define_test "deleteall should work w/o columns and timestamps" do