Commit Graph

8 Commits

Author SHA1 Message Date
Bulat-Ziganshin 2c7de91278 Get rid of copyAllScalarFields() 2022-10-13 05:09:19 +03:00
Bulat-Ziganshin e5e70a7dd2 Changed addProtection to protect 2022-10-08 16:37:25 +03:00
Bulat-Ziganshin 5ebfe676a6 More detailed comment in erasure.decode() 2022-10-08 16:37:25 +03:00
Bulat-Ziganshin 546ec70589 Manifest: renamed operations to addProtection/removeProtection 2022-10-08 16:37:25 +03:00
Bulat-Ziganshin 105d02993b Used copyAllScalarFields when building unprotected Manifest from a protected one 2022-10-08 16:37:24 +03:00
Bulat-Ziganshin 2dc5b18da2 Manifest: added copyAllScalarFields
And used it when building a protected Manifest from unprotected one
2022-10-08 16:37:24 +03:00
Bulat-Ziganshin f24ded0f76
Download files without padding (#218)
The initial goal of this patch was to allow to download of a file via REST API in exactly the same size as it was uploaded, which required adding fields Chunker.offset and Manifest.originalBytes to keep that size. On top of that, we added more integrity checks to operations on Manifest, and reorganized TestNode.nim to test the actual interaction between node.store and node.retrieve operations.

Note that the wire format of Manifest was changed, so we need to recreate all BlockStores.

* Download without padding
* Fixed chunker tests
* Chunker: get rid of RabinChunker
* Verify offset in the chunker tests
* Use manifest.originalBytesPadded in StoreStream.size
* StoreStream: replace emptyBlock with zeroMem
* Manifest.bytes: compute how many bytes corresponding StoreStream(Manifest, pad) will return
* Manifest: verify originalBytes and originalLen on new/encode/decode
Also set originalBytes in each Manifest creation/update scenario
* Manifest: comments, split code into sections
* Reordered parameters to deal with int64 size in 32-bit builds
* TestNode.nim: combine Store and Retrieve tests
1. Instead of copy-pasting code from node.nim, new test calls node.store() and node.retrieve() in order to check that they can correctly store and then retrieve data
2. New test compares only file contents, manifest contents considered an implementation detail
3. New test chunks at odd chunkSize=BlockSize/1.618 in order to ensure that data retrieved correctly even when buffer sizes mismatch
* TestNode.nim: code refactoring
* Manifest.add: one more test
* Manifest.verify: return Result instead of raising Defect
* Node.store: added blockSize parameter
2022-08-24 15:15:59 +03:00
Michael Bradley 209343087c
Change every dagger to codex (#102) 2022-05-19 13:56:03 -06:00