2022-01-10 09:32:56 -06:00
|
|
|
import std/sequtils
|
|
|
|
|
|
|
|
import pkg/chronos
|
|
|
|
import pkg/questionable/results
|
|
|
|
import pkg/asynctest
|
|
|
|
import pkg/stew/byteutils
|
|
|
|
|
2022-05-19 14:56:03 -05:00
|
|
|
import pkg/codex/chunker
|
|
|
|
import pkg/codex/blocktype as bt
|
|
|
|
import pkg/codex/manifest
|
2022-01-10 09:32:56 -06:00
|
|
|
|
|
|
|
import ./helpers
|
|
|
|
|
2023-06-22 12:01:21 -06:00
|
|
|
checksuite "Manifest":
|
2022-01-10 09:32:56 -06:00
|
|
|
test "Should produce valid tree hash checksum":
|
2022-03-17 07:56:46 -06:00
|
|
|
var manifest = Manifest.new(
|
2022-01-10 09:32:56 -06:00
|
|
|
blocks = @[
|
2022-03-18 13:50:53 -06:00
|
|
|
Block.new("Block 1".toBytes).tryGet().cid,
|
|
|
|
Block.new("Block 2".toBytes).tryGet().cid,
|
|
|
|
Block.new("Block 3".toBytes).tryGet().cid,
|
|
|
|
Block.new("Block 4".toBytes).tryGet().cid,
|
|
|
|
Block.new("Block 5".toBytes).tryGet().cid,
|
|
|
|
Block.new("Block 6".toBytes).tryGet().cid,
|
|
|
|
Block.new("Block 7".toBytes).tryGet().cid,
|
2022-03-17 07:56:46 -06:00
|
|
|
]).tryGet()
|
2022-01-10 09:32:56 -06:00
|
|
|
|
|
|
|
let
|
2022-04-04 18:46:13 -06:00
|
|
|
encoded = @[byte 18, 32, 227, 176, 196, 66, 152,
|
2022-01-10 21:04:00 -06:00
|
|
|
252, 28, 20, 154, 251, 244, 200, 153,
|
|
|
|
111, 185, 36, 39, 174, 65, 228, 100,
|
|
|
|
155, 147, 76, 164, 149, 153, 27, 120,
|
|
|
|
82, 184, 85]
|
2022-01-10 09:32:56 -06:00
|
|
|
|
|
|
|
var mh: MultiHash
|
2022-04-04 18:46:13 -06:00
|
|
|
check MultiHash.decode(encoded, mh).tryGet() > 0
|
2022-01-10 09:32:56 -06:00
|
|
|
|
2022-04-04 18:46:13 -06:00
|
|
|
let encodedCid = Cid.init(manifest.version, manifest.codec, mh).tryGet()
|
|
|
|
check:
|
|
|
|
encodedCid == manifest.cid.tryGet()
|
2022-01-10 09:32:56 -06:00
|
|
|
|
|
|
|
test "Should encode/decode to/from manifest":
|
|
|
|
let
|
2022-01-10 20:25:13 -06:00
|
|
|
blocks = (0..<1000).mapIt(
|
2022-03-18 13:50:53 -06:00
|
|
|
Block.new(("Block " & $it).toBytes).tryGet().cid
|
2022-01-10 20:25:13 -06:00
|
|
|
)
|
2022-01-10 09:32:56 -06:00
|
|
|
|
|
|
|
var
|
2022-04-04 18:46:13 -06:00
|
|
|
manifest = Manifest.new(blocks).tryGet()
|
2022-01-10 09:32:56 -06:00
|
|
|
|
|
|
|
let
|
2022-04-04 18:46:13 -06:00
|
|
|
e = manifest.encode().tryGet()
|
|
|
|
decoded = Manifest.decode(e).tryGet()
|
2022-01-10 09:32:56 -06:00
|
|
|
|
2022-04-04 18:46:13 -06:00
|
|
|
check:
|
|
|
|
decoded.blocks == blocks
|
|
|
|
decoded.protected == false
|
|
|
|
|
|
|
|
test "Should produce a protected manifest":
|
|
|
|
let
|
|
|
|
blocks = (0..<333).mapIt(
|
|
|
|
Block.new(("Block " & $it).toBytes).tryGet().cid
|
|
|
|
)
|
|
|
|
manifest = Manifest.new(blocks).tryGet()
|
2023-07-19 16:06:59 +02:00
|
|
|
|
|
|
|
var
|
2022-04-04 18:46:13 -06:00
|
|
|
protected = Manifest.new(manifest, 2, 2).tryGet()
|
|
|
|
|
|
|
|
check:
|
|
|
|
protected.originalCid == manifest.cid.tryGet()
|
|
|
|
protected.blocks[0..<333] == manifest.blocks
|
|
|
|
protected.protected == true
|
|
|
|
protected.originalLen == manifest.len
|
|
|
|
|
|
|
|
# fill up with empty Cid's
|
|
|
|
for i in protected.rounded..<protected.len:
|
2023-07-19 16:06:59 +02:00
|
|
|
protected[i] = EmptyCid[manifest.version]
|
2022-04-04 18:46:13 -06:00
|
|
|
.catch
|
|
|
|
.get()[manifest.hcodec]
|
|
|
|
.catch
|
|
|
|
.get()
|
|
|
|
|
|
|
|
var
|
|
|
|
encoded = protected.encode().tryGet()
|
|
|
|
decoded = Manifest.decode(encoded).tryGet()
|
|
|
|
|
|
|
|
check:
|
|
|
|
decoded.protected == true
|
|
|
|
decoded.originalLen == manifest.len
|
|
|
|
|
2023-03-10 08:02:54 +01:00
|
|
|
decoded.ecK == protected.ecK
|
|
|
|
decoded.ecM == protected.ecM
|
2022-04-04 18:46:13 -06:00
|
|
|
|
|
|
|
decoded.originalCid == protected.originalCid
|
|
|
|
decoded.originalCid == manifest.cid.tryGet()
|
|
|
|
|
|
|
|
decoded.blocks == protected.blocks
|
|
|
|
decoded.blocks[0..<333] == manifest.blocks
|