2022-01-10 15:32:56 +00:00
|
|
|
import std/os
|
2022-07-28 00:39:17 +00:00
|
|
|
import std/options
|
2022-01-10 15:32:56 +00:00
|
|
|
|
|
|
|
import pkg/questionable
|
|
|
|
import pkg/questionable/results
|
|
|
|
|
|
|
|
import pkg/chronos
|
|
|
|
import pkg/asynctest
|
|
|
|
import pkg/libp2p
|
|
|
|
import pkg/stew/byteutils
|
|
|
|
|
2022-05-19 19:56:03 +00:00
|
|
|
import pkg/codex/stores/cachestore
|
|
|
|
import pkg/codex/chunker
|
|
|
|
import pkg/codex/stores
|
|
|
|
import pkg/codex/blocktype as bt
|
2022-01-10 15:32:56 +00:00
|
|
|
|
|
|
|
import ../helpers
|
|
|
|
|
|
|
|
suite "FS Store":
|
|
|
|
let
|
|
|
|
(path, _, _) = instantiationInfo(-2, fullPaths = true) # get this file's name
|
|
|
|
|
|
|
|
var
|
|
|
|
store: FSStore
|
|
|
|
repoDir: string
|
2022-05-19 02:29:15 +00:00
|
|
|
newBlock = bt.Block.new("New Block".toBytes()).tryGet()
|
2022-01-10 15:32:56 +00:00
|
|
|
|
|
|
|
setup:
|
|
|
|
repoDir = path.parentDir / "repo"
|
|
|
|
createDir(repoDir)
|
|
|
|
store = FSStore.new(repoDir)
|
|
|
|
|
|
|
|
teardown:
|
|
|
|
removeDir(repoDir)
|
|
|
|
|
|
|
|
test "putBlock":
|
2022-07-28 00:39:17 +00:00
|
|
|
(await store.putBlock(newBlock)).tryGet()
|
|
|
|
check:
|
|
|
|
fileExists(store.blockPath(newBlock.cid))
|
|
|
|
(await store.hasBlock(newBlock.cid)).tryGet()
|
|
|
|
await newBlock.cid in store
|
2022-01-10 15:32:56 +00:00
|
|
|
|
|
|
|
test "getBlock":
|
|
|
|
createDir(store.blockPath(newBlock.cid).parentDir)
|
|
|
|
writeFile(store.blockPath(newBlock.cid), newBlock.data)
|
|
|
|
let blk = await store.getBlock(newBlock.cid)
|
2022-07-28 00:39:17 +00:00
|
|
|
check blk.tryGet().get() == newBlock
|
2022-01-10 15:32:56 +00:00
|
|
|
|
|
|
|
test "fail getBlock":
|
|
|
|
let blk = await store.getBlock(newBlock.cid)
|
2022-07-28 00:39:17 +00:00
|
|
|
check blk.tryGet().isNone
|
2022-01-10 15:32:56 +00:00
|
|
|
|
|
|
|
test "hasBlock":
|
|
|
|
createDir(store.blockPath(newBlock.cid).parentDir)
|
|
|
|
writeFile(store.blockPath(newBlock.cid), newBlock.data)
|
|
|
|
|
2022-07-28 00:39:17 +00:00
|
|
|
check:
|
|
|
|
(await store.hasBlock(newBlock.cid)).tryGet()
|
|
|
|
await newBlock.cid in store
|
|
|
|
|
|
|
|
test "fail hasBlock":
|
|
|
|
check:
|
|
|
|
not (await store.hasBlock(newBlock.cid)).tryGet()
|
|
|
|
not (await newBlock.cid in store)
|
2022-01-10 15:32:56 +00:00
|
|
|
|
2022-05-12 20:02:30 +00:00
|
|
|
test "listBlocks":
|
2022-04-13 16:32:35 +00:00
|
|
|
createDir(store.blockPath(newBlock.cid).parentDir)
|
|
|
|
writeFile(store.blockPath(newBlock.cid), newBlock.data)
|
|
|
|
|
2022-07-28 00:39:17 +00:00
|
|
|
(await store.listBlocks(
|
2022-05-12 20:02:30 +00:00
|
|
|
proc(cid: Cid) {.gcsafe, async.} =
|
2022-07-28 00:39:17 +00:00
|
|
|
check cid == newBlock.cid
|
|
|
|
)).tryGet()
|
2022-01-10 15:32:56 +00:00
|
|
|
|
|
|
|
test "delBlock":
|
|
|
|
createDir(store.blockPath(newBlock.cid).parentDir)
|
|
|
|
writeFile(store.blockPath(newBlock.cid), newBlock.data)
|
|
|
|
|
2022-06-28 16:10:05 +00:00
|
|
|
(await store.delBlock(newBlock.cid)).tryGet()
|
2022-01-10 15:32:56 +00:00
|
|
|
check not fileExists(store.blockPath(newBlock.cid))
|