|
|
@ -56,6 +56,7 @@ public class ColumnFamilyTest { |
|
|
|
public void defaultColumnFamily() throws RocksDBException { |
|
|
|
public void defaultColumnFamily() throws RocksDBException { |
|
|
|
RocksDB db = null; |
|
|
|
RocksDB db = null; |
|
|
|
Options options = null; |
|
|
|
Options options = null; |
|
|
|
|
|
|
|
ColumnFamilyHandle cfh = null; |
|
|
|
try { |
|
|
|
try { |
|
|
|
options = new Options(); |
|
|
|
options = new Options(); |
|
|
|
options.setCreateIfMissing(true); |
|
|
|
options.setCreateIfMissing(true); |
|
|
@ -64,7 +65,7 @@ public class ColumnFamilyTest { |
|
|
|
dbOptions.setCreateIfMissing(true); |
|
|
|
dbOptions.setCreateIfMissing(true); |
|
|
|
|
|
|
|
|
|
|
|
db = RocksDB.open(options, dbFolder.getRoot().getAbsolutePath()); |
|
|
|
db = RocksDB.open(options, dbFolder.getRoot().getAbsolutePath()); |
|
|
|
ColumnFamilyHandle cfh = db.getDefaultColumnFamily(); |
|
|
|
cfh = db.getDefaultColumnFamily(); |
|
|
|
assertThat(cfh).isNotNull(); |
|
|
|
assertThat(cfh).isNotNull(); |
|
|
|
|
|
|
|
|
|
|
|
final byte[] key = "key".getBytes(); |
|
|
|
final byte[] key = "key".getBytes(); |
|
|
@ -77,6 +78,9 @@ public class ColumnFamilyTest { |
|
|
|
assertThat(cfh).isNotNull(); |
|
|
|
assertThat(cfh).isNotNull(); |
|
|
|
assertThat(actualValue).isEqualTo(value); |
|
|
|
assertThat(actualValue).isEqualTo(value); |
|
|
|
} finally { |
|
|
|
} finally { |
|
|
|
|
|
|
|
if (cfh != null) { |
|
|
|
|
|
|
|
cfh.dispose(); |
|
|
|
|
|
|
|
} |
|
|
|
if (db != null) { |
|
|
|
if (db != null) { |
|
|
|
db.close(); |
|
|
|
db.close(); |
|
|
|
} |
|
|
|
} |
|
|
@ -90,16 +94,14 @@ public class ColumnFamilyTest { |
|
|
|
public void createColumnFamily() throws RocksDBException { |
|
|
|
public void createColumnFamily() throws RocksDBException { |
|
|
|
RocksDB db = null; |
|
|
|
RocksDB db = null; |
|
|
|
Options options = null; |
|
|
|
Options options = null; |
|
|
|
|
|
|
|
ColumnFamilyHandle columnFamilyHandle = null; |
|
|
|
try { |
|
|
|
try { |
|
|
|
options = new Options(); |
|
|
|
options = new Options(); |
|
|
|
options.setCreateIfMissing(true); |
|
|
|
options.setCreateIfMissing(true); |
|
|
|
|
|
|
|
|
|
|
|
DBOptions dbOptions = new DBOptions(); |
|
|
|
|
|
|
|
dbOptions.setCreateIfMissing(true); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
db = RocksDB.open(options, dbFolder.getRoot().getAbsolutePath()); |
|
|
|
db = RocksDB.open(options, dbFolder.getRoot().getAbsolutePath()); |
|
|
|
db.createColumnFamily(new ColumnFamilyDescriptor("new_cf".getBytes(), |
|
|
|
columnFamilyHandle = db.createColumnFamily( |
|
|
|
new ColumnFamilyOptions())); |
|
|
|
new ColumnFamilyDescriptor("new_cf".getBytes(), new ColumnFamilyOptions())); |
|
|
|
db.close(); |
|
|
|
db.close(); |
|
|
|
List<byte[]> columnFamilyNames; |
|
|
|
List<byte[]> columnFamilyNames; |
|
|
|
columnFamilyNames = RocksDB.listColumnFamilies(options, dbFolder.getRoot().getAbsolutePath()); |
|
|
|
columnFamilyNames = RocksDB.listColumnFamilies(options, dbFolder.getRoot().getAbsolutePath()); |
|
|
@ -109,6 +111,9 @@ public class ColumnFamilyTest { |
|
|
|
assertThat(new String(columnFamilyNames.get(0))).isEqualTo("default"); |
|
|
|
assertThat(new String(columnFamilyNames.get(0))).isEqualTo("default"); |
|
|
|
assertThat(new String(columnFamilyNames.get(1))).isEqualTo("new_cf"); |
|
|
|
assertThat(new String(columnFamilyNames.get(1))).isEqualTo("new_cf"); |
|
|
|
} finally { |
|
|
|
} finally { |
|
|
|
|
|
|
|
if (columnFamilyHandle != null) { |
|
|
|
|
|
|
|
columnFamilyHandle.dispose(); |
|
|
|
|
|
|
|
} |
|
|
|
if (db != null) { |
|
|
|
if (db != null) { |
|
|
|
db.close(); |
|
|
|
db.close(); |
|
|
|
} |
|
|
|
} |
|
|
@ -122,15 +127,15 @@ public class ColumnFamilyTest { |
|
|
|
public void openWithColumnFamilies() throws RocksDBException { |
|
|
|
public void openWithColumnFamilies() throws RocksDBException { |
|
|
|
RocksDB db = null; |
|
|
|
RocksDB db = null; |
|
|
|
DBOptions options = null; |
|
|
|
DBOptions options = null; |
|
|
|
|
|
|
|
List<ColumnFamilyDescriptor> cfNames = |
|
|
|
|
|
|
|
new ArrayList<>(); |
|
|
|
|
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
|
|
|
|
new ArrayList<>(); |
|
|
|
try { |
|
|
|
try { |
|
|
|
options = new DBOptions(); |
|
|
|
options = new DBOptions(); |
|
|
|
options.setCreateIfMissing(true); |
|
|
|
options.setCreateIfMissing(true); |
|
|
|
options.setCreateMissingColumnFamilies(true); |
|
|
|
options.setCreateMissingColumnFamilies(true); |
|
|
|
// Test open database with column family names
|
|
|
|
// Test open database with column family names
|
|
|
|
List<ColumnFamilyDescriptor> cfNames = |
|
|
|
|
|
|
|
new ArrayList<>(); |
|
|
|
|
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
|
|
|
|
new ArrayList<>(); |
|
|
|
|
|
|
|
cfNames.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
|
|
|
|
|
|
|
@ -156,6 +161,9 @@ public class ColumnFamilyTest { |
|
|
|
assertThat(db.get(columnFamilyHandleList.get(0), new ReadOptions(), |
|
|
|
assertThat(db.get(columnFamilyHandleList.get(0), new ReadOptions(), |
|
|
|
"dfkey2".getBytes())).isNull(); |
|
|
|
"dfkey2".getBytes())).isNull(); |
|
|
|
} finally { |
|
|
|
} finally { |
|
|
|
|
|
|
|
for (ColumnFamilyHandle columnFamilyHandle : columnFamilyHandleList) { |
|
|
|
|
|
|
|
columnFamilyHandle.dispose(); |
|
|
|
|
|
|
|
} |
|
|
|
if (db != null) { |
|
|
|
if (db != null) { |
|
|
|
db.close(); |
|
|
|
db.close(); |
|
|
|
} |
|
|
|
} |
|
|
@ -169,15 +177,15 @@ public class ColumnFamilyTest { |
|
|
|
public void getWithOutValueAndCf() throws RocksDBException { |
|
|
|
public void getWithOutValueAndCf() throws RocksDBException { |
|
|
|
RocksDB db = null; |
|
|
|
RocksDB db = null; |
|
|
|
DBOptions options = null; |
|
|
|
DBOptions options = null; |
|
|
|
|
|
|
|
List<ColumnFamilyDescriptor> cfDescriptors = |
|
|
|
|
|
|
|
new ArrayList<>(); |
|
|
|
|
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
|
|
|
|
new ArrayList<>(); |
|
|
|
try { |
|
|
|
try { |
|
|
|
options = new DBOptions(); |
|
|
|
options = new DBOptions(); |
|
|
|
options.setCreateIfMissing(true); |
|
|
|
options.setCreateIfMissing(true); |
|
|
|
options.setCreateMissingColumnFamilies(true); |
|
|
|
options.setCreateMissingColumnFamilies(true); |
|
|
|
// Test open database with column family names
|
|
|
|
// Test open database with column family names
|
|
|
|
List<ColumnFamilyDescriptor> cfDescriptors = |
|
|
|
|
|
|
|
new ArrayList<>(); |
|
|
|
|
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
|
|
|
|
new ArrayList<>(); |
|
|
|
|
|
|
|
cfDescriptors.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfDescriptors.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
db = RocksDB.open(options, dbFolder.getRoot().getAbsolutePath(), |
|
|
|
db = RocksDB.open(options, dbFolder.getRoot().getAbsolutePath(), |
|
|
|
cfDescriptors, columnFamilyHandleList); |
|
|
|
cfDescriptors, columnFamilyHandleList); |
|
|
@ -198,6 +206,9 @@ public class ColumnFamilyTest { |
|
|
|
assertThat(getResult).isNotEqualTo(RocksDB.NOT_FOUND); |
|
|
|
assertThat(getResult).isNotEqualTo(RocksDB.NOT_FOUND); |
|
|
|
assertThat(outValue).isEqualTo("12345".getBytes()); |
|
|
|
assertThat(outValue).isEqualTo("12345".getBytes()); |
|
|
|
} finally { |
|
|
|
} finally { |
|
|
|
|
|
|
|
for (ColumnFamilyHandle columnFamilyHandle : columnFamilyHandleList) { |
|
|
|
|
|
|
|
columnFamilyHandle.dispose(); |
|
|
|
|
|
|
|
} |
|
|
|
if (db != null) { |
|
|
|
if (db != null) { |
|
|
|
db.close(); |
|
|
|
db.close(); |
|
|
|
} |
|
|
|
} |
|
|
@ -212,14 +223,14 @@ public class ColumnFamilyTest { |
|
|
|
RocksDB db = null; |
|
|
|
RocksDB db = null; |
|
|
|
DBOptions opt = null; |
|
|
|
DBOptions opt = null; |
|
|
|
ColumnFamilyHandle tmpColumnFamilyHandle = null; |
|
|
|
ColumnFamilyHandle tmpColumnFamilyHandle = null; |
|
|
|
try { |
|
|
|
|
|
|
|
opt = new DBOptions(); |
|
|
|
|
|
|
|
opt.setCreateIfMissing(true); |
|
|
|
|
|
|
|
opt.setCreateMissingColumnFamilies(true); |
|
|
|
|
|
|
|
List<ColumnFamilyDescriptor> cfNames = |
|
|
|
List<ColumnFamilyDescriptor> cfNames = |
|
|
|
new ArrayList<>(); |
|
|
|
new ArrayList<>(); |
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
new ArrayList<>(); |
|
|
|
new ArrayList<>(); |
|
|
|
|
|
|
|
try { |
|
|
|
|
|
|
|
opt = new DBOptions(); |
|
|
|
|
|
|
|
opt.setCreateIfMissing(true); |
|
|
|
|
|
|
|
opt.setCreateMissingColumnFamilies(true); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
|
|
|
|
|
|
|
@ -231,6 +242,9 @@ public class ColumnFamilyTest { |
|
|
|
db.dropColumnFamily(tmpColumnFamilyHandle); |
|
|
|
db.dropColumnFamily(tmpColumnFamilyHandle); |
|
|
|
tmpColumnFamilyHandle.dispose(); |
|
|
|
tmpColumnFamilyHandle.dispose(); |
|
|
|
} finally { |
|
|
|
} finally { |
|
|
|
|
|
|
|
for (ColumnFamilyHandle columnFamilyHandle : columnFamilyHandleList) { |
|
|
|
|
|
|
|
columnFamilyHandle.dispose(); |
|
|
|
|
|
|
|
} |
|
|
|
if (tmpColumnFamilyHandle != null) { |
|
|
|
if (tmpColumnFamilyHandle != null) { |
|
|
|
tmpColumnFamilyHandle.dispose(); |
|
|
|
tmpColumnFamilyHandle.dispose(); |
|
|
|
} |
|
|
|
} |
|
|
@ -247,14 +261,15 @@ public class ColumnFamilyTest { |
|
|
|
public void writeBatch() throws RocksDBException { |
|
|
|
public void writeBatch() throws RocksDBException { |
|
|
|
RocksDB db = null; |
|
|
|
RocksDB db = null; |
|
|
|
DBOptions opt = null; |
|
|
|
DBOptions opt = null; |
|
|
|
try { |
|
|
|
|
|
|
|
opt = new DBOptions(); |
|
|
|
|
|
|
|
opt.setCreateIfMissing(true); |
|
|
|
|
|
|
|
opt.setCreateMissingColumnFamilies(true); |
|
|
|
|
|
|
|
List<ColumnFamilyDescriptor> cfNames = |
|
|
|
List<ColumnFamilyDescriptor> cfNames = |
|
|
|
new ArrayList<>(); |
|
|
|
new ArrayList<>(); |
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
new ArrayList<>(); |
|
|
|
new ArrayList<>(); |
|
|
|
|
|
|
|
try { |
|
|
|
|
|
|
|
opt = new DBOptions(); |
|
|
|
|
|
|
|
opt.setCreateIfMissing(true); |
|
|
|
|
|
|
|
opt.setCreateMissingColumnFamilies(true); |
|
|
|
|
|
|
|
|
|
|
|
cfNames.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY, |
|
|
|
cfNames.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY, |
|
|
|
new ColumnFamilyOptions().setMergeOperator(new StringAppendOperator()))); |
|
|
|
new ColumnFamilyOptions().setMergeOperator(new StringAppendOperator()))); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
@ -288,6 +303,9 @@ public class ColumnFamilyTest { |
|
|
|
assertThat(new String(db.get(db.getDefaultColumnFamily(), |
|
|
|
assertThat(new String(db.get(db.getDefaultColumnFamily(), |
|
|
|
"mergeKey".getBytes()))).isEqualTo("merge,merge"); |
|
|
|
"mergeKey".getBytes()))).isEqualTo("merge,merge"); |
|
|
|
} finally { |
|
|
|
} finally { |
|
|
|
|
|
|
|
for (ColumnFamilyHandle columnFamilyHandle : columnFamilyHandleList) { |
|
|
|
|
|
|
|
columnFamilyHandle.dispose(); |
|
|
|
|
|
|
|
} |
|
|
|
if (db != null) { |
|
|
|
if (db != null) { |
|
|
|
db.close(); |
|
|
|
db.close(); |
|
|
|
} |
|
|
|
} |
|
|
@ -302,14 +320,15 @@ public class ColumnFamilyTest { |
|
|
|
RocksDB db = null; |
|
|
|
RocksDB db = null; |
|
|
|
DBOptions options = null; |
|
|
|
DBOptions options = null; |
|
|
|
RocksIterator rocksIterator = null; |
|
|
|
RocksIterator rocksIterator = null; |
|
|
|
try { |
|
|
|
|
|
|
|
options = new DBOptions(); |
|
|
|
|
|
|
|
options.setCreateIfMissing(true); |
|
|
|
|
|
|
|
options.setCreateMissingColumnFamilies(true); |
|
|
|
|
|
|
|
List<ColumnFamilyDescriptor> cfNames = |
|
|
|
List<ColumnFamilyDescriptor> cfNames = |
|
|
|
new ArrayList<>(); |
|
|
|
new ArrayList<>(); |
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
new ArrayList<>(); |
|
|
|
new ArrayList<>(); |
|
|
|
|
|
|
|
try { |
|
|
|
|
|
|
|
options = new DBOptions(); |
|
|
|
|
|
|
|
options.setCreateIfMissing(true); |
|
|
|
|
|
|
|
options.setCreateMissingColumnFamilies(true); |
|
|
|
|
|
|
|
|
|
|
|
cfNames.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
|
|
|
|
|
|
|
@ -338,6 +357,9 @@ public class ColumnFamilyTest { |
|
|
|
if (rocksIterator != null) { |
|
|
|
if (rocksIterator != null) { |
|
|
|
rocksIterator.dispose(); |
|
|
|
rocksIterator.dispose(); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
for (ColumnFamilyHandle columnFamilyHandle : columnFamilyHandleList) { |
|
|
|
|
|
|
|
columnFamilyHandle.dispose(); |
|
|
|
|
|
|
|
} |
|
|
|
if (db != null) { |
|
|
|
if (db != null) { |
|
|
|
db.close(); |
|
|
|
db.close(); |
|
|
|
} |
|
|
|
} |
|
|
@ -351,14 +373,15 @@ public class ColumnFamilyTest { |
|
|
|
public void multiGet() throws RocksDBException { |
|
|
|
public void multiGet() throws RocksDBException { |
|
|
|
RocksDB db = null; |
|
|
|
RocksDB db = null; |
|
|
|
DBOptions options = null; |
|
|
|
DBOptions options = null; |
|
|
|
try { |
|
|
|
|
|
|
|
options = new DBOptions(); |
|
|
|
|
|
|
|
options.setCreateIfMissing(true); |
|
|
|
|
|
|
|
options.setCreateMissingColumnFamilies(true); |
|
|
|
|
|
|
|
List<ColumnFamilyDescriptor> cfDescriptors = |
|
|
|
List<ColumnFamilyDescriptor> cfDescriptors = |
|
|
|
new ArrayList<>(); |
|
|
|
new ArrayList<>(); |
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
new ArrayList<>(); |
|
|
|
new ArrayList<>(); |
|
|
|
|
|
|
|
try { |
|
|
|
|
|
|
|
options = new DBOptions(); |
|
|
|
|
|
|
|
options.setCreateIfMissing(true); |
|
|
|
|
|
|
|
options.setCreateMissingColumnFamilies(true); |
|
|
|
|
|
|
|
|
|
|
|
cfDescriptors.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfDescriptors.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfDescriptors.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
cfDescriptors.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
|
|
|
|
|
|
|
@ -383,6 +406,9 @@ public class ColumnFamilyTest { |
|
|
|
assertThat(new String(retValues.get(keys.get(1)))) |
|
|
|
assertThat(new String(retValues.get(keys.get(1)))) |
|
|
|
.isEqualTo("value"); |
|
|
|
.isEqualTo("value"); |
|
|
|
} finally { |
|
|
|
} finally { |
|
|
|
|
|
|
|
for (ColumnFamilyHandle columnFamilyHandle : columnFamilyHandleList) { |
|
|
|
|
|
|
|
columnFamilyHandle.dispose(); |
|
|
|
|
|
|
|
} |
|
|
|
if (db != null) { |
|
|
|
if (db != null) { |
|
|
|
db.close(); |
|
|
|
db.close(); |
|
|
|
} |
|
|
|
} |
|
|
@ -396,14 +422,15 @@ public class ColumnFamilyTest { |
|
|
|
public void properties() throws RocksDBException { |
|
|
|
public void properties() throws RocksDBException { |
|
|
|
RocksDB db = null; |
|
|
|
RocksDB db = null; |
|
|
|
DBOptions options = null; |
|
|
|
DBOptions options = null; |
|
|
|
try { |
|
|
|
|
|
|
|
options = new DBOptions(); |
|
|
|
|
|
|
|
options.setCreateIfMissing(true); |
|
|
|
|
|
|
|
options.setCreateMissingColumnFamilies(true); |
|
|
|
|
|
|
|
List<ColumnFamilyDescriptor> cfNames = |
|
|
|
List<ColumnFamilyDescriptor> cfNames = |
|
|
|
new ArrayList<>(); |
|
|
|
new ArrayList<>(); |
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
new ArrayList<>(); |
|
|
|
new ArrayList<>(); |
|
|
|
|
|
|
|
try { |
|
|
|
|
|
|
|
options = new DBOptions(); |
|
|
|
|
|
|
|
options.setCreateIfMissing(true); |
|
|
|
|
|
|
|
options.setCreateMissingColumnFamilies(true); |
|
|
|
|
|
|
|
|
|
|
|
cfNames.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
|
|
|
|
|
|
|
@ -423,6 +450,9 @@ public class ColumnFamilyTest { |
|
|
|
assertThat(db.getProperty(columnFamilyHandleList.get(1), |
|
|
|
assertThat(db.getProperty(columnFamilyHandleList.get(1), |
|
|
|
"rocksdb.sstables")).isNotNull(); |
|
|
|
"rocksdb.sstables")).isNotNull(); |
|
|
|
} finally { |
|
|
|
} finally { |
|
|
|
|
|
|
|
for (ColumnFamilyHandle columnFamilyHandle : columnFamilyHandleList) { |
|
|
|
|
|
|
|
columnFamilyHandle.dispose(); |
|
|
|
|
|
|
|
} |
|
|
|
if (db != null) { |
|
|
|
if (db != null) { |
|
|
|
db.close(); |
|
|
|
db.close(); |
|
|
|
} |
|
|
|
} |
|
|
@ -437,15 +467,15 @@ public class ColumnFamilyTest { |
|
|
|
public void iterators() throws RocksDBException { |
|
|
|
public void iterators() throws RocksDBException { |
|
|
|
RocksDB db = null; |
|
|
|
RocksDB db = null; |
|
|
|
DBOptions options = null; |
|
|
|
DBOptions options = null; |
|
|
|
|
|
|
|
List<ColumnFamilyDescriptor> cfNames = |
|
|
|
|
|
|
|
new ArrayList<>(); |
|
|
|
|
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
|
|
|
|
new ArrayList<>(); |
|
|
|
try { |
|
|
|
try { |
|
|
|
options = new DBOptions(); |
|
|
|
options = new DBOptions(); |
|
|
|
options.setCreateIfMissing(true); |
|
|
|
options.setCreateIfMissing(true); |
|
|
|
options.setCreateMissingColumnFamilies(true); |
|
|
|
options.setCreateMissingColumnFamilies(true); |
|
|
|
|
|
|
|
|
|
|
|
List<ColumnFamilyDescriptor> cfNames = |
|
|
|
|
|
|
|
new ArrayList<>(); |
|
|
|
|
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
|
|
|
|
new ArrayList<>(); |
|
|
|
|
|
|
|
cfNames.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
|
|
|
|
|
|
|
@ -476,6 +506,9 @@ public class ColumnFamilyTest { |
|
|
|
iter.next(); |
|
|
|
iter.next(); |
|
|
|
} |
|
|
|
} |
|
|
|
} finally { |
|
|
|
} finally { |
|
|
|
|
|
|
|
for (ColumnFamilyHandle columnFamilyHandle : columnFamilyHandleList) { |
|
|
|
|
|
|
|
columnFamilyHandle.dispose(); |
|
|
|
|
|
|
|
} |
|
|
|
if (db != null) { |
|
|
|
if (db != null) { |
|
|
|
db.close(); |
|
|
|
db.close(); |
|
|
|
} |
|
|
|
} |
|
|
@ -489,13 +522,14 @@ public class ColumnFamilyTest { |
|
|
|
public void failPutDisposedCF() throws RocksDBException { |
|
|
|
public void failPutDisposedCF() throws RocksDBException { |
|
|
|
RocksDB db = null; |
|
|
|
RocksDB db = null; |
|
|
|
DBOptions options = null; |
|
|
|
DBOptions options = null; |
|
|
|
try { |
|
|
|
|
|
|
|
options = new DBOptions(); |
|
|
|
|
|
|
|
options.setCreateIfMissing(true); |
|
|
|
|
|
|
|
List<ColumnFamilyDescriptor> cfNames = |
|
|
|
List<ColumnFamilyDescriptor> cfNames = |
|
|
|
new ArrayList<>(); |
|
|
|
new ArrayList<>(); |
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
new ArrayList<>(); |
|
|
|
new ArrayList<>(); |
|
|
|
|
|
|
|
try { |
|
|
|
|
|
|
|
options = new DBOptions(); |
|
|
|
|
|
|
|
options.setCreateIfMissing(true); |
|
|
|
|
|
|
|
|
|
|
|
cfNames.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
|
|
|
|
|
|
|
@ -504,6 +538,9 @@ public class ColumnFamilyTest { |
|
|
|
db.dropColumnFamily(columnFamilyHandleList.get(1)); |
|
|
|
db.dropColumnFamily(columnFamilyHandleList.get(1)); |
|
|
|
db.put(columnFamilyHandleList.get(1), "key".getBytes(), "value".getBytes()); |
|
|
|
db.put(columnFamilyHandleList.get(1), "key".getBytes(), "value".getBytes()); |
|
|
|
} finally { |
|
|
|
} finally { |
|
|
|
|
|
|
|
for (ColumnFamilyHandle columnFamilyHandle : columnFamilyHandleList) { |
|
|
|
|
|
|
|
columnFamilyHandle.dispose(); |
|
|
|
|
|
|
|
} |
|
|
|
if (db != null) { |
|
|
|
if (db != null) { |
|
|
|
db.close(); |
|
|
|
db.close(); |
|
|
|
} |
|
|
|
} |
|
|
@ -517,13 +554,14 @@ public class ColumnFamilyTest { |
|
|
|
public void failRemoveDisposedCF() throws RocksDBException { |
|
|
|
public void failRemoveDisposedCF() throws RocksDBException { |
|
|
|
RocksDB db = null; |
|
|
|
RocksDB db = null; |
|
|
|
DBOptions options = null; |
|
|
|
DBOptions options = null; |
|
|
|
try { |
|
|
|
|
|
|
|
options = new DBOptions(); |
|
|
|
|
|
|
|
options.setCreateIfMissing(true); |
|
|
|
|
|
|
|
List<ColumnFamilyDescriptor> cfNames = |
|
|
|
List<ColumnFamilyDescriptor> cfNames = |
|
|
|
new ArrayList<>(); |
|
|
|
new ArrayList<>(); |
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
new ArrayList<>(); |
|
|
|
new ArrayList<>(); |
|
|
|
|
|
|
|
try { |
|
|
|
|
|
|
|
options = new DBOptions(); |
|
|
|
|
|
|
|
options.setCreateIfMissing(true); |
|
|
|
|
|
|
|
|
|
|
|
cfNames.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
|
|
|
|
|
|
|
@ -532,6 +570,9 @@ public class ColumnFamilyTest { |
|
|
|
db.dropColumnFamily(columnFamilyHandleList.get(1)); |
|
|
|
db.dropColumnFamily(columnFamilyHandleList.get(1)); |
|
|
|
db.remove(columnFamilyHandleList.get(1), "key".getBytes()); |
|
|
|
db.remove(columnFamilyHandleList.get(1), "key".getBytes()); |
|
|
|
} finally { |
|
|
|
} finally { |
|
|
|
|
|
|
|
for (ColumnFamilyHandle columnFamilyHandle : columnFamilyHandleList) { |
|
|
|
|
|
|
|
columnFamilyHandle.dispose(); |
|
|
|
|
|
|
|
} |
|
|
|
if (db != null) { |
|
|
|
if (db != null) { |
|
|
|
db.close(); |
|
|
|
db.close(); |
|
|
|
} |
|
|
|
} |
|
|
@ -545,13 +586,14 @@ public class ColumnFamilyTest { |
|
|
|
public void failGetDisposedCF() throws RocksDBException { |
|
|
|
public void failGetDisposedCF() throws RocksDBException { |
|
|
|
RocksDB db = null; |
|
|
|
RocksDB db = null; |
|
|
|
DBOptions options = null; |
|
|
|
DBOptions options = null; |
|
|
|
try { |
|
|
|
|
|
|
|
options = new DBOptions(); |
|
|
|
|
|
|
|
options.setCreateIfMissing(true); |
|
|
|
|
|
|
|
List<ColumnFamilyDescriptor> cfNames = |
|
|
|
List<ColumnFamilyDescriptor> cfNames = |
|
|
|
new ArrayList<>(); |
|
|
|
new ArrayList<>(); |
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
new ArrayList<>(); |
|
|
|
new ArrayList<>(); |
|
|
|
|
|
|
|
try { |
|
|
|
|
|
|
|
options = new DBOptions(); |
|
|
|
|
|
|
|
options.setCreateIfMissing(true); |
|
|
|
|
|
|
|
|
|
|
|
cfNames.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
|
|
|
|
|
|
|
@ -560,6 +602,9 @@ public class ColumnFamilyTest { |
|
|
|
db.dropColumnFamily(columnFamilyHandleList.get(1)); |
|
|
|
db.dropColumnFamily(columnFamilyHandleList.get(1)); |
|
|
|
db.get(columnFamilyHandleList.get(1), "key".getBytes()); |
|
|
|
db.get(columnFamilyHandleList.get(1), "key".getBytes()); |
|
|
|
} finally { |
|
|
|
} finally { |
|
|
|
|
|
|
|
for (ColumnFamilyHandle columnFamilyHandle : columnFamilyHandleList) { |
|
|
|
|
|
|
|
columnFamilyHandle.dispose(); |
|
|
|
|
|
|
|
} |
|
|
|
if (db != null) { |
|
|
|
if (db != null) { |
|
|
|
db.close(); |
|
|
|
db.close(); |
|
|
|
} |
|
|
|
} |
|
|
@ -573,13 +618,14 @@ public class ColumnFamilyTest { |
|
|
|
public void failMultiGetWithoutCorrectNumberOfCF() throws RocksDBException { |
|
|
|
public void failMultiGetWithoutCorrectNumberOfCF() throws RocksDBException { |
|
|
|
RocksDB db = null; |
|
|
|
RocksDB db = null; |
|
|
|
DBOptions options = null; |
|
|
|
DBOptions options = null; |
|
|
|
try { |
|
|
|
|
|
|
|
options = new DBOptions(); |
|
|
|
|
|
|
|
options.setCreateIfMissing(true); |
|
|
|
|
|
|
|
List<ColumnFamilyDescriptor> cfNames = |
|
|
|
List<ColumnFamilyDescriptor> cfNames = |
|
|
|
new ArrayList<>(); |
|
|
|
new ArrayList<>(); |
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
List<ColumnFamilyHandle> columnFamilyHandleList = |
|
|
|
new ArrayList<>(); |
|
|
|
new ArrayList<>(); |
|
|
|
|
|
|
|
try { |
|
|
|
|
|
|
|
options = new DBOptions(); |
|
|
|
|
|
|
|
options.setCreateIfMissing(true); |
|
|
|
|
|
|
|
|
|
|
|
cfNames.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor(RocksDB.DEFAULT_COLUMN_FAMILY)); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
cfNames.add(new ColumnFamilyDescriptor("new_cf".getBytes())); |
|
|
|
|
|
|
|
|
|
|
@ -592,6 +638,9 @@ public class ColumnFamilyTest { |
|
|
|
db.multiGet(cfCustomList, keys); |
|
|
|
db.multiGet(cfCustomList, keys); |
|
|
|
|
|
|
|
|
|
|
|
} finally { |
|
|
|
} finally { |
|
|
|
|
|
|
|
for (ColumnFamilyHandle columnFamilyHandle : columnFamilyHandleList) { |
|
|
|
|
|
|
|
columnFamilyHandle.dispose(); |
|
|
|
|
|
|
|
} |
|
|
|
if (db != null) { |
|
|
|
if (db != null) { |
|
|
|
db.close(); |
|
|
|
db.close(); |
|
|
|
} |
|
|
|
} |
|
|
@ -605,6 +654,7 @@ public class ColumnFamilyTest { |
|
|
|
public void testByteCreateFolumnFamily() throws RocksDBException { |
|
|
|
public void testByteCreateFolumnFamily() throws RocksDBException { |
|
|
|
RocksDB db = null; |
|
|
|
RocksDB db = null; |
|
|
|
Options options = null; |
|
|
|
Options options = null; |
|
|
|
|
|
|
|
ColumnFamilyHandle cf1 = null, cf2 = null, cf3 = null; |
|
|
|
try { |
|
|
|
try { |
|
|
|
options = new Options().setCreateIfMissing(true); |
|
|
|
options = new Options().setCreateIfMissing(true); |
|
|
|
db = RocksDB.open(options, dbFolder.getRoot().getAbsolutePath()); |
|
|
|
db = RocksDB.open(options, dbFolder.getRoot().getAbsolutePath()); |
|
|
@ -612,12 +662,21 @@ public class ColumnFamilyTest { |
|
|
|
byte[] b0 = new byte[] { (byte)0x00 }; |
|
|
|
byte[] b0 = new byte[] { (byte)0x00 }; |
|
|
|
byte[] b1 = new byte[] { (byte)0x01 }; |
|
|
|
byte[] b1 = new byte[] { (byte)0x01 }; |
|
|
|
byte[] b2 = new byte[] { (byte)0x02 }; |
|
|
|
byte[] b2 = new byte[] { (byte)0x02 }; |
|
|
|
db.createColumnFamily(new ColumnFamilyDescriptor(b0)); |
|
|
|
cf1 = db.createColumnFamily(new ColumnFamilyDescriptor(b0)); |
|
|
|
db.createColumnFamily(new ColumnFamilyDescriptor(b1)); |
|
|
|
cf2 = db.createColumnFamily(new ColumnFamilyDescriptor(b1)); |
|
|
|
List<byte[]> families = RocksDB.listColumnFamilies(options, dbFolder.getRoot().getAbsolutePath()); |
|
|
|
List<byte[]> families = RocksDB.listColumnFamilies(options, dbFolder.getRoot().getAbsolutePath()); |
|
|
|
assertThat(families).contains("default".getBytes(), b0, b1); |
|
|
|
assertThat(families).contains("default".getBytes(), b0, b1); |
|
|
|
db.createColumnFamily(new ColumnFamilyDescriptor(b2)); |
|
|
|
cf3 = db.createColumnFamily(new ColumnFamilyDescriptor(b2)); |
|
|
|
} finally { |
|
|
|
} finally { |
|
|
|
|
|
|
|
if (cf1 != null) { |
|
|
|
|
|
|
|
cf1.dispose(); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
if (cf2 != null) { |
|
|
|
|
|
|
|
cf2.dispose(); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
if (cf3 != null) { |
|
|
|
|
|
|
|
cf3.dispose(); |
|
|
|
|
|
|
|
} |
|
|
|
if (db != null) { |
|
|
|
if (db != null) { |
|
|
|
db.close(); |
|
|
|
db.close(); |
|
|
|
} |
|
|
|
} |
|
|
@ -631,17 +690,24 @@ public class ColumnFamilyTest { |
|
|
|
public void testCFNamesWithZeroBytes() throws RocksDBException { |
|
|
|
public void testCFNamesWithZeroBytes() throws RocksDBException { |
|
|
|
RocksDB db = null; |
|
|
|
RocksDB db = null; |
|
|
|
Options options = null; |
|
|
|
Options options = null; |
|
|
|
|
|
|
|
ColumnFamilyHandle cf1 = null, cf2 = null; |
|
|
|
try { |
|
|
|
try { |
|
|
|
options = new Options().setCreateIfMissing(true); |
|
|
|
options = new Options().setCreateIfMissing(true); |
|
|
|
db = RocksDB.open(options, dbFolder.getRoot().getAbsolutePath()); |
|
|
|
db = RocksDB.open(options, dbFolder.getRoot().getAbsolutePath()); |
|
|
|
|
|
|
|
|
|
|
|
byte[] b0 = new byte[] { 0, 0 }; |
|
|
|
byte[] b0 = new byte[] { 0, 0 }; |
|
|
|
byte[] b1 = new byte[] { 0, 1 }; |
|
|
|
byte[] b1 = new byte[] { 0, 1 }; |
|
|
|
db.createColumnFamily(new ColumnFamilyDescriptor(b0)); |
|
|
|
cf1 = db.createColumnFamily(new ColumnFamilyDescriptor(b0)); |
|
|
|
db.createColumnFamily(new ColumnFamilyDescriptor(b1)); |
|
|
|
cf2 = db.createColumnFamily(new ColumnFamilyDescriptor(b1)); |
|
|
|
List<byte[]> families = RocksDB.listColumnFamilies(options, dbFolder.getRoot().getAbsolutePath()); |
|
|
|
List<byte[]> families = RocksDB.listColumnFamilies(options, dbFolder.getRoot().getAbsolutePath()); |
|
|
|
assertThat(families).contains("default".getBytes(), b0, b1); |
|
|
|
assertThat(families).contains("default".getBytes(), b0, b1); |
|
|
|
} finally { |
|
|
|
} finally { |
|
|
|
|
|
|
|
if (cf1 != null) { |
|
|
|
|
|
|
|
cf1.dispose(); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
if (cf2 != null) { |
|
|
|
|
|
|
|
cf2.dispose(); |
|
|
|
|
|
|
|
} |
|
|
|
if (db != null) { |
|
|
|
if (db != null) { |
|
|
|
db.close(); |
|
|
|
db.close(); |
|
|
|
} |
|
|
|
} |
|
|
@ -655,15 +721,20 @@ public class ColumnFamilyTest { |
|
|
|
public void testCFNameSimplifiedChinese() throws RocksDBException { |
|
|
|
public void testCFNameSimplifiedChinese() throws RocksDBException { |
|
|
|
RocksDB db = null; |
|
|
|
RocksDB db = null; |
|
|
|
Options options = null; |
|
|
|
Options options = null; |
|
|
|
|
|
|
|
ColumnFamilyHandle columnFamilyHandle = null; |
|
|
|
try { |
|
|
|
try { |
|
|
|
options = new Options().setCreateIfMissing(true); |
|
|
|
options = new Options().setCreateIfMissing(true); |
|
|
|
db = RocksDB.open(options, dbFolder.getRoot().getAbsolutePath()); |
|
|
|
db = RocksDB.open(options, dbFolder.getRoot().getAbsolutePath()); |
|
|
|
final String simplifiedChinese = "简体字"; |
|
|
|
final String simplifiedChinese = "简体字"; |
|
|
|
db.createColumnFamily(new ColumnFamilyDescriptor(simplifiedChinese.getBytes())); |
|
|
|
columnFamilyHandle = db.createColumnFamily( |
|
|
|
|
|
|
|
new ColumnFamilyDescriptor(simplifiedChinese.getBytes())); |
|
|
|
|
|
|
|
|
|
|
|
List<byte[]> families = RocksDB.listColumnFamilies(options, dbFolder.getRoot().getAbsolutePath()); |
|
|
|
List<byte[]> families = RocksDB.listColumnFamilies(options, dbFolder.getRoot().getAbsolutePath()); |
|
|
|
assertThat(families).contains("default".getBytes(), simplifiedChinese.getBytes()); |
|
|
|
assertThat(families).contains("default".getBytes(), simplifiedChinese.getBytes()); |
|
|
|
} finally { |
|
|
|
} finally { |
|
|
|
|
|
|
|
if (columnFamilyHandle != null) { |
|
|
|
|
|
|
|
columnFamilyHandle.dispose(); |
|
|
|
|
|
|
|
} |
|
|
|
if (db != null) { |
|
|
|
if (db != null) { |
|
|
|
db.close(); |
|
|
|
db.close(); |
|
|
|
} |
|
|
|
} |
|
|
|