mirror of
https://github.com/status-im/nim-rocksdb.git
synced 2025-02-18 09:57:04 +00:00
* Column families support (#34) * Update library to support column families. If not specified, uses the 'default' column family. * Added tests for column family changes. * Update library version and readme. * Updated the librocksdb c library to the latest stable version. * Started rewrite of library. * Commit library rewrite progress. * Completed initial rewrite and refactored tests. * Completed implementation of backup engine. * Added tests for new types. * Completed tests for existing features. * Remove features not supported by older versions of RocksDB to fix CI (temporary fix). * Remove flush before backup support from BackupEngine to fix CI. * Transactions support (#36) * Update library to support column families. If not specified, uses the 'default' column family. * Added tests for column family changes. * Update library version and readme. * Updated the librocksdb c library to the latest stable version. * Started rewrite of library. * Commit library rewrite progress. * Completed initial rewrite and refactored tests. * Completed implementation of backup engine. * Added tests for new types. * Completed tests for existing features. * Remove features not supported by older versions of RocksDB to fix CI (temporary fix). * Remove flush before backup support from BackupEngine to fix CI. * Implemented RocksDB iterator. * Implemented pairs iterator. * Completed implementation of WriteBatch with tests. * Fix example code. * Completed implementation of TransactionDb. * Support setting default column family. * Remove unneeded usage of var for ref type parameters. * Completed transactiondb tests. * Improve and refactor rocksdb test. * Added support for ingesting sst files using the SstFileWriter. (#37) * Create ColFamilyReadOnly and ColFamilyReadWrite types for using a specific column family. * Use inline pragma for small procs and add lock to RocksDbRef type close to prevent double free. * Added documentation for the public API. * Initial implementation of sst filewriter. * Added tests for sstfilewriter. * Documentation minor improvements.
68 lines
1.6 KiB
Nim
68 lines
1.6 KiB
Nim
# Nim-RocksDB
|
|
# Copyright 2024 Status Research & Development GmbH
|
|
# Licensed under either of
|
|
#
|
|
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)
|
|
# * GPL license, version 2.0, ([LICENSE-GPLv2](LICENSE-GPLv2) or https://www.gnu.org/licenses/old-licenses/gpl-2.0.en.html)
|
|
#
|
|
# at your option. This file may not be copied, modified, or distributed except according to those terms.
|
|
|
|
{.used.}
|
|
|
|
import
|
|
std/os,
|
|
tempfile,
|
|
unittest2,
|
|
../../rocksdb/lib/librocksdb,
|
|
../../rocksdb/columnfamily/cfhandle
|
|
|
|
suite "ColFamilyHandleRef Tests":
|
|
|
|
const TEST_CF_NAME = "test"
|
|
|
|
setup:
|
|
let
|
|
dbPath = mkdtemp() / "data"
|
|
dbOpts = rocksdb_options_create()
|
|
cfOpts = rocksdb_options_create()
|
|
|
|
var
|
|
errors: cstring
|
|
|
|
rocksdb_options_set_create_if_missing(dbOpts, 1);
|
|
|
|
let db = rocksdb_open(dbOpts, dbPath.cstring, cast[cstringArray](errors.addr))
|
|
doAssert errors.isNil()
|
|
doAssert not db.isNil()
|
|
|
|
let cfHandlePtr = rocksdb_create_column_family(
|
|
db,
|
|
cfOpts,
|
|
TEST_CF_NAME.cstring,
|
|
cast[cstringArray](errors.addr))
|
|
doAssert errors.isNil()
|
|
doAssert not cfHandlePtr.isNil()
|
|
|
|
teardown:
|
|
rocksdb_close(db)
|
|
removeDir($dbPath)
|
|
|
|
test "Test newColFamilyHandle":
|
|
var cfHandle = newColFamilyHandle(cfHandlePtr)
|
|
|
|
check:
|
|
not cfHandle.cPtr.isNil()
|
|
cfHandle.cPtr == cfHandlePtr
|
|
|
|
cfHandle.close()
|
|
|
|
test "Test close":
|
|
var cfHandle = newColFamilyHandle(cfHandlePtr)
|
|
|
|
check not cfHandle.isClosed()
|
|
cfHandle.close()
|
|
check cfHandle.isClosed()
|
|
cfHandle.close()
|
|
check cfHandle.isClosed()
|
|
|