Skip to content

Commit

Permalink
feat(services/redb): add redb workflow
Browse files Browse the repository at this point in the history
Signed-off-by: owl <[email protected]>
  • Loading branch information
oowl committed Jun 25, 2023
1 parent b47309b commit 1a9ad44
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 13 deletions.
4 changes: 4 additions & 0 deletions .env.example
Original file line number Diff line number Diff line change
Expand Up @@ -114,3 +114,7 @@ OPENDAL_WASABI_BUCKET=<bucket>
OPENDAL_WASABI_ENDPOINT=<endpoint>
OPENDAL_WASABI_ACCESS_KEY_ID=<ak>
OPENDAL_WASABI_SECRET_ACCESS_KEY=<sk>
# redb
OPENDAL_REDB_TEST=false
OPENDAL_REDB_DATADIR=/path/to/database
OPENDAL_REDB_TABLE=redb-table
6 changes: 6 additions & 0 deletions .github/workflows/service_test_redb.yml
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,12 @@ jobs:
- uses: actions/checkout@v3
- name: Setup Rust toolchain
uses: ./.github/actions/setup
- name: Prepare for tests
shell: bash
working-directory: core
run: mkdir -p $OPENDAL_REDB_DATADIR
env:
OPENDAL_REDB_DATADIR: /tmp/opendal/redb/
- name: Test
shell: bash
working-directory: core
Expand Down
28 changes: 15 additions & 13 deletions core/src/services/redb/backend.rs
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,7 @@ impl Builder for RedbBuilder {
let mut builder = RedbBuilder::default();

map.get("datadir").map(|v| builder.datadir(v));
map.get("table").map(|v| builder.table(v));
map.get("root").map(|v| builder.root(v));

builder
Expand Down Expand Up @@ -146,8 +147,9 @@ impl kv::Adapter for Adapter {
return Err(Error::new(ErrorKind::Unexpected, "error from redb").set_source(e));
}
};

let table_define: redb::TableDefinition<&str, &[u8]> = redb::TableDefinition::new(&self.table);

let table_define: redb::TableDefinition<&str, &[u8]> =
redb::TableDefinition::new(&self.table);

let table = match read_txn.open_table(table_define) {
Ok(table) => table,
Expand Down Expand Up @@ -176,7 +178,8 @@ impl kv::Adapter for Adapter {
}
};

let table_define: redb::TableDefinition<&str, &[u8]> = redb::TableDefinition::new(&self.table);
let table_define: redb::TableDefinition<&str, &[u8]> =
redb::TableDefinition::new(&self.table);

{
let mut table = match write_txn.open_table(table_define) {
Expand All @@ -185,17 +188,16 @@ impl kv::Adapter for Adapter {
return Err(Error::new(ErrorKind::Unexpected, "error from redb").set_source(e));
}
};

if let Err(e) = table.insert(path, value) {
return Err(Error::new(ErrorKind::Unexpected, "error from redb").set_source(e));
};
}

let result = match write_txn.commit() {
match write_txn.commit() {
Ok(()) => Ok(()),
Err(e) => Err(Error::new(ErrorKind::Unexpected, "error from redb").set_source(e)),
};
result
}
}

async fn delete(&self, path: &str) -> Result<()> {
Expand All @@ -210,7 +212,8 @@ impl kv::Adapter for Adapter {
}
};

let table_define: redb::TableDefinition<&str, &[u8]> = redb::TableDefinition::new(&self.table);
let table_define: redb::TableDefinition<&str, &[u8]> =
redb::TableDefinition::new(&self.table);

{
let mut table = match write_txn.open_table(table_define) {
Expand All @@ -219,16 +222,15 @@ impl kv::Adapter for Adapter {
return Err(Error::new(ErrorKind::Unexpected, "error from redb").set_source(e));
}
};

if let Err(e) = table.remove(path) {
return Err(Error::new(ErrorKind::Unexpected, "error from redb").set_source(e));
};
}

let result = match write_txn.commit() {
match write_txn.commit() {
Ok(()) => Ok(()),
Err(e) => Err(Error::new(ErrorKind::Unexpected, "error from redb").set_source(e)),
};
result
}
}
}
}

0 comments on commit 1a9ad44

Please sign in to comment.