2024-10-17 18:54:28 +02:00
|
|
|
import pkg/codex/rest/json
|
2024-05-23 17:29:30 +02:00
|
|
|
import ./twonodes
|
2024-10-25 14:43:19 +01:00
|
|
|
import json
|
|
|
|
from pkg/libp2p import Cid, `$`
|
2024-05-23 17:29:30 +02:00
|
|
|
|
|
|
|
twonodessuite "Uploads and downloads", debug1 = false, debug2 = false:
|
|
|
|
|
|
|
|
test "node allows local file downloads":
|
|
|
|
let content1 = "some file contents"
|
|
|
|
let content2 = "some other contents"
|
|
|
|
|
|
|
|
let cid1 = client1.upload(content1).get
|
|
|
|
let cid2 = client2.upload(content2).get
|
|
|
|
|
|
|
|
let resp1 = client1.download(cid1, local = true).get
|
|
|
|
let resp2 = client2.download(cid2, local = true).get
|
|
|
|
|
|
|
|
check:
|
|
|
|
content1 == resp1
|
|
|
|
content2 == resp2
|
|
|
|
|
|
|
|
test "node allows remote file downloads":
|
|
|
|
let content1 = "some file contents"
|
|
|
|
let content2 = "some other contents"
|
|
|
|
|
|
|
|
let cid1 = client1.upload(content1).get
|
|
|
|
let cid2 = client2.upload(content2).get
|
|
|
|
|
|
|
|
let resp2 = client1.download(cid2, local = false).get
|
|
|
|
let resp1 = client2.download(cid1, local = false).get
|
|
|
|
|
|
|
|
check:
|
|
|
|
content1 == resp1
|
|
|
|
content2 == resp2
|
|
|
|
|
|
|
|
test "node fails retrieving non-existing local file":
|
|
|
|
let content1 = "some file contents"
|
|
|
|
let cid1 = client1.upload(content1).get # upload to first node
|
|
|
|
let resp2 = client2.download(cid1, local = true) # try retrieving from second node
|
|
|
|
|
|
|
|
check:
|
|
|
|
resp2.error.msg == "404 Not Found"
|
2024-10-17 18:54:28 +02:00
|
|
|
|
2024-10-25 14:43:19 +01:00
|
|
|
proc checkRestContent(cid: Cid, content: ?!string) =
|
2024-10-17 18:54:28 +02:00
|
|
|
let c = content.tryGet()
|
2024-10-25 14:43:19 +01:00
|
|
|
|
2024-10-17 18:54:28 +02:00
|
|
|
# tried to JSON (very easy) and checking the resulting object (would be much nicer)
|
|
|
|
# spent an hour to try and make it work.
|
2024-10-25 14:43:19 +01:00
|
|
|
let jsonData = parseJson(c)
|
|
|
|
|
|
|
|
check jsonData.hasKey("cid") == true
|
|
|
|
|
|
|
|
check jsonData["cid"].getStr() == $cid
|
|
|
|
check jsonData.hasKey("manifest") == true
|
|
|
|
|
|
|
|
let manifest = jsonData["manifest"]
|
|
|
|
|
|
|
|
check manifest.hasKey("treeCid") == true
|
|
|
|
check manifest["treeCid"].getStr() == "zDzSvJTezk7bJNQqFq8k1iHXY84psNuUfZVusA5bBQQUSuyzDSVL"
|
|
|
|
check manifest.hasKey("datasetSize") == true
|
|
|
|
check manifest["datasetSize"].getInt() == 18
|
|
|
|
check manifest.hasKey("blockSize") == true
|
|
|
|
check manifest["blockSize"].getInt() == 65536
|
|
|
|
check manifest.hasKey("protected") == true
|
|
|
|
check manifest["protected"].getBool() == false
|
2024-10-17 18:54:28 +02:00
|
|
|
|
|
|
|
test "node allows downloading only manifest":
|
|
|
|
let content1 = "some file contents"
|
|
|
|
let cid1 = client1.upload(content1).get
|
2024-10-25 14:43:19 +01:00
|
|
|
|
|
|
|
let resp2 = client1.downloadManifestOnly(cid1)
|
|
|
|
checkRestContent(cid1, resp2)
|
2024-10-17 18:54:28 +02:00
|
|
|
|
|
|
|
test "node allows downloading content without stream":
|
|
|
|
let content1 = "some file contents"
|
|
|
|
let cid1 = client1.upload(content1).get
|
2024-10-25 14:43:19 +01:00
|
|
|
|
2024-10-17 18:54:28 +02:00
|
|
|
let resp1 = client2.downloadNoStream(cid1)
|
2024-10-25 14:43:19 +01:00
|
|
|
checkRestContent(cid1, resp1)
|
2024-10-17 18:54:28 +02:00
|
|
|
let resp2 = client2.download(cid1, local = true).get
|
|
|
|
check:
|
|
|
|
content1 == resp2
|