mirror of
https://github.com/codex-storage/nim-codex.git
synced 2025-01-10 13:05:48 +00:00
d3dbbc75fa
* don't force logging syncs * Add failing test * wip discovery engine * re-add chronicles sinks * wip * move network related stuff to own folder * move peer related stuff to own folder * extract discovery into it's own engine * update imports * move pending blocks into engine module * add top level exports * update imports * update import paths * update imports * support for inflight request filtering and tests * use `remove` instead of `del` * fix sorting in `selectCheapest` * re-org test file structure * fix to use discovery engine * file re-org * fix compilation * fixup discovery to use async handlers * more re-org * rework with support for discovery engine * add logging * use defaults * wip: reworking with discoveryengine * wip: more test fixes * more logging * use ordered table * use `bt` for blocktype Block * fix tests * make tests work with discovery engine * expose all node components * fix to work with discovery engine * wip * propagate cancellation in listBlocks * start/stop disc engine in blockexc engine * remove disc engine start/stop * wire up discovery engine * misc comments and imports * pass discovery to dagger node * set sleep timers * unused imports * misc * don't spawn a task, await it * don't await handlers * trace logging * reduce default sleep time Co-authored-by: Tanguy <tanguy@status.im>
73 lines
1.8 KiB
Nim
73 lines
1.8 KiB
Nim
import std/os
|
|
|
|
import pkg/questionable
|
|
import pkg/questionable/results
|
|
|
|
import pkg/chronos
|
|
import pkg/asynctest
|
|
import pkg/libp2p
|
|
import pkg/stew/byteutils
|
|
|
|
import pkg/dagger/stores/cachestore
|
|
import pkg/dagger/chunker
|
|
import pkg/dagger/stores
|
|
import pkg/dagger/blocktype as bt
|
|
|
|
import ../helpers
|
|
|
|
suite "FS Store":
|
|
let
|
|
(path, _, _) = instantiationInfo(-2, fullPaths = true) # get this file's name
|
|
|
|
var
|
|
store: FSStore
|
|
repoDir: string
|
|
newBlock = bt.Block.new("New Block".toBytes()).tryGet()
|
|
|
|
setup:
|
|
repoDir = path.parentDir / "repo"
|
|
createDir(repoDir)
|
|
store = FSStore.new(repoDir)
|
|
|
|
teardown:
|
|
removeDir(repoDir)
|
|
|
|
test "putBlock":
|
|
check await store.putBlock(newBlock)
|
|
check fileExists(store.blockPath(newBlock.cid))
|
|
check newBlock.cid in store
|
|
|
|
test "getBlock":
|
|
createDir(store.blockPath(newBlock.cid).parentDir)
|
|
writeFile(store.blockPath(newBlock.cid), newBlock.data)
|
|
let blk = await store.getBlock(newBlock.cid)
|
|
check blk.option == newBlock.some
|
|
|
|
test "fail getBlock":
|
|
let blk = await store.getBlock(newBlock.cid)
|
|
check blk.isErr
|
|
|
|
test "hasBlock":
|
|
createDir(store.blockPath(newBlock.cid).parentDir)
|
|
writeFile(store.blockPath(newBlock.cid), newBlock.data)
|
|
|
|
check store.hasBlock(newBlock.cid)
|
|
|
|
test "listBlocks":
|
|
createDir(store.blockPath(newBlock.cid).parentDir)
|
|
writeFile(store.blockPath(newBlock.cid), newBlock.data)
|
|
|
|
await store.listBlocks(
|
|
proc(cid: Cid) {.gcsafe, async.} =
|
|
check cid == newBlock.cid)
|
|
|
|
test "fail hasBlock":
|
|
check not store.hasBlock(newBlock.cid)
|
|
|
|
test "delBlock":
|
|
createDir(store.blockPath(newBlock.cid).parentDir)
|
|
writeFile(store.blockPath(newBlock.cid), newBlock.data)
|
|
|
|
check await store.delBlock(newBlock.cid)
|
|
check not fileExists(store.blockPath(newBlock.cid))
|