2022-04-21 16:33:20 +02:00
|
|
|
import std/osproc
|
2022-11-01 18:58:41 -06:00
|
|
|
import std/os
|
2022-04-21 16:33:20 +02:00
|
|
|
import std/httpclient
|
2022-05-09 15:15:23 +02:00
|
|
|
import std/json
|
2022-11-01 18:58:41 -06:00
|
|
|
import std/strutils
|
|
|
|
|
2022-04-21 16:33:20 +02:00
|
|
|
import pkg/chronos
|
2022-05-18 14:31:45 +02:00
|
|
|
import ./ethertest
|
|
|
|
import ./contracts/time
|
2022-05-12 13:42:18 +02:00
|
|
|
import ./integration/nodes
|
2022-05-18 14:31:45 +02:00
|
|
|
import ./integration/tokens
|
2022-11-08 02:10:17 -05:00
|
|
|
import ./codex/helpers/eventually
|
2022-04-21 16:33:20 +02:00
|
|
|
|
2022-05-18 14:31:45 +02:00
|
|
|
ethersuite "Integration tests":
|
2022-04-21 16:33:20 +02:00
|
|
|
|
2022-11-08 02:10:17 -05:00
|
|
|
var node1, node2: NodeProcess
|
2022-05-09 16:51:08 +02:00
|
|
|
var baseurl1, baseurl2: string
|
2022-04-21 16:33:20 +02:00
|
|
|
var client: HttpClient
|
|
|
|
|
2022-11-01 18:58:41 -06:00
|
|
|
let dataDir1 = getTempDir() / "Codex1"
|
|
|
|
let dataDir2 = getTempDir() / "Codex2"
|
|
|
|
|
2022-04-21 16:33:20 +02:00
|
|
|
setup:
|
2022-05-18 14:31:45 +02:00
|
|
|
await provider.getSigner(accounts[0]).mint()
|
|
|
|
await provider.getSigner(accounts[1]).mint()
|
|
|
|
await provider.getSigner(accounts[1]).deposit()
|
2022-11-01 18:58:41 -06:00
|
|
|
|
|
|
|
baseurl1 = "http://localhost:8080/api/codex/v1"
|
|
|
|
baseurl2 = "http://localhost:8081/api/codex/v1"
|
|
|
|
client = newHttpClient()
|
|
|
|
|
|
|
|
node1 = startNode([
|
2022-05-18 14:31:45 +02:00
|
|
|
"--api-port=8080",
|
2022-11-01 18:58:41 -06:00
|
|
|
"--data-dir=" & dataDir1,
|
|
|
|
"--nat=127.0.0.1",
|
|
|
|
"--disc-ip=127.0.0.1",
|
|
|
|
"--disc-port=8090",
|
2022-11-14 17:42:57 -06:00
|
|
|
"--persistence",
|
|
|
|
"--eth-account=" & $accounts[0]
|
2022-11-01 18:58:41 -06:00
|
|
|
], debug = false)
|
|
|
|
|
2022-11-14 17:42:57 -06:00
|
|
|
let
|
|
|
|
bootstrap = strip(
|
|
|
|
$(parseJson(client.get(baseurl1 & "/debug/info").body)["spr"]),
|
|
|
|
chars = {'"'})
|
|
|
|
|
2022-11-01 18:58:41 -06:00
|
|
|
node2 = startNode([
|
2022-05-18 14:31:45 +02:00
|
|
|
"--api-port=8081",
|
2022-11-01 18:58:41 -06:00
|
|
|
"--data-dir=" & dataDir2,
|
|
|
|
"--nat=127.0.0.1",
|
|
|
|
"--disc-ip=127.0.0.1",
|
|
|
|
"--disc-port=8091",
|
2022-11-14 17:42:57 -06:00
|
|
|
"--bootstrap-node=" & bootstrap,
|
2022-08-09 06:29:06 +02:00
|
|
|
"--persistence",
|
2022-05-18 14:31:45 +02:00
|
|
|
"--eth-account=" & $accounts[1]
|
2022-11-01 18:58:41 -06:00
|
|
|
], debug = false)
|
2022-04-21 16:33:20 +02:00
|
|
|
|
|
|
|
teardown:
|
|
|
|
client.close()
|
|
|
|
node1.stop()
|
|
|
|
node2.stop()
|
|
|
|
|
2022-11-01 18:58:41 -06:00
|
|
|
dataDir1.removeDir()
|
|
|
|
dataDir2.removeDir()
|
|
|
|
|
2022-04-21 16:33:20 +02:00
|
|
|
test "nodes can print their peer information":
|
2022-11-14 17:42:57 -06:00
|
|
|
let info1 = client.get(baseurl1 & "/debug/info").body
|
|
|
|
let info2 = client.get(baseurl2 & "/debug/info").body
|
2022-04-21 16:33:20 +02:00
|
|
|
check info1 != info2
|
2022-04-26 08:49:27 +02:00
|
|
|
|
2022-11-14 17:42:57 -06:00
|
|
|
test "nodes should set chronicles log level":
|
|
|
|
client.headers = newHttpHeaders({ "Content-Type": "text/plain" })
|
|
|
|
let filter = "/debug/chronicles/loglevel?level=DEBUG;TRACE:codex"
|
|
|
|
check client.request(baseurl1 & filter, httpMethod = HttpPost, body = "").status == "200 OK"
|
|
|
|
|
2022-05-10 14:13:39 +02:00
|
|
|
test "node accepts file uploads":
|
|
|
|
let url = baseurl1 & "/upload"
|
|
|
|
let response = client.post(url, "some file contents")
|
|
|
|
check response.status == "200 OK"
|
|
|
|
|
2022-04-26 08:49:27 +02:00
|
|
|
test "node handles new storage availability":
|
2022-05-09 16:51:08 +02:00
|
|
|
let url = baseurl1 & "/sales/availability"
|
|
|
|
let json = %*{"size": "0x1", "duration": "0x2", "minPrice": "0x3"}
|
|
|
|
check client.post(url, $json).status == "200 OK"
|
|
|
|
|
|
|
|
test "node lists storage that is for sale":
|
|
|
|
let url = baseurl1 & "/sales/availability"
|
|
|
|
let json = %*{"size": "0x1", "duration": "0x2", "minPrice": "0x3"}
|
|
|
|
let availability = parseJson(client.post(url, $json).body)
|
|
|
|
let response = client.get(url)
|
2022-05-09 15:15:23 +02:00
|
|
|
check response.status == "200 OK"
|
2022-06-09 09:36:59 -06:00
|
|
|
check %*availability in parseJson(response.body)
|
2022-05-10 14:13:39 +02:00
|
|
|
|
|
|
|
test "node handles storage request":
|
|
|
|
let cid = client.post(baseurl1 & "/upload", "some file contents").body
|
|
|
|
let url = baseurl1 & "/storage/request/" & cid
|
2022-07-20 14:11:00 +02:00
|
|
|
let json = %*{"duration": "0x1", "reward": "0x2"}
|
2022-05-10 14:13:39 +02:00
|
|
|
let response = client.post(url, $json)
|
|
|
|
check response.status == "200 OK"
|
2022-05-11 10:51:59 +02:00
|
|
|
|
|
|
|
test "node retrieves purchase status":
|
|
|
|
let cid = client.post(baseurl1 & "/upload", "some file contents").body
|
2022-07-20 14:11:00 +02:00
|
|
|
let request = %*{"duration": "0x1", "reward": "0x2"}
|
2022-05-11 10:51:59 +02:00
|
|
|
let id = client.post(baseurl1 & "/storage/request/" & cid, $request).body
|
|
|
|
let response = client.get(baseurl1 & "/storage/purchases/" & id)
|
|
|
|
check response.status == "200 OK"
|
|
|
|
let json = parseJson(response.body)
|
|
|
|
check json["request"]["ask"]["duration"].getStr == "0x1"
|
2022-07-20 14:11:00 +02:00
|
|
|
check json["request"]["ask"]["reward"].getStr == "0x2"
|
2022-05-18 14:31:45 +02:00
|
|
|
|
2022-11-08 02:10:17 -05:00
|
|
|
test "node remembers purchase status after restart":
|
|
|
|
let cid = client.post(baseurl1 & "/upload", "some file contents").body
|
|
|
|
let request = %*{"duration": "0x1", "reward": "0x2"}
|
|
|
|
let id = client.post(baseurl1 & "/storage/request/" & cid, $request).body
|
|
|
|
|
|
|
|
proc getPurchase(id: string): JsonNode =
|
|
|
|
let response = client.get(baseurl1 & "/storage/purchases/" & id)
|
|
|
|
return parseJson(response.body).catch |? nil
|
|
|
|
|
|
|
|
check eventually getPurchase(id){"state"}.getStr == "submitted"
|
|
|
|
|
|
|
|
node1.restart()
|
|
|
|
|
|
|
|
client.close()
|
|
|
|
client = newHttpClient()
|
|
|
|
|
|
|
|
check eventually (not isNil getPurchase(id){"request"}{"ask"})
|
|
|
|
check getPurchase(id){"request"}{"ask"}{"duration"}.getStr == "0x1"
|
|
|
|
check getPurchase(id){"request"}{"ask"}{"reward"}.getStr == "0x2"
|
|
|
|
|
2022-05-18 14:31:45 +02:00
|
|
|
test "nodes negotiate contracts on the marketplace":
|
|
|
|
proc sell =
|
2022-10-06 23:01:25 +03:00
|
|
|
let json = %*{"size": "0xFFFFF", "duration": "0x200", "minPrice": "0x300"}
|
2022-05-18 14:31:45 +02:00
|
|
|
discard client.post(baseurl2 & "/sales/availability", $json)
|
|
|
|
|
|
|
|
proc available: JsonNode =
|
|
|
|
client.get(baseurl2 & "/sales/availability").body.parseJson
|
|
|
|
|
|
|
|
proc upload: string =
|
|
|
|
client.post(baseurl1 & "/upload", "some file contents").body
|
|
|
|
|
|
|
|
proc buy(cid: string): string =
|
2022-07-07 16:50:24 +02:00
|
|
|
let expiry = ((waitFor provider.currentTime()) + 30).toHex
|
2022-11-08 02:10:17 -05:00
|
|
|
let json = %*{"duration": "0x1", "reward": "0x400", "expiry": expiry}
|
2022-05-18 14:31:45 +02:00
|
|
|
client.post(baseurl1 & "/storage/request/" & cid, $json).body
|
|
|
|
|
2022-07-03 21:33:55 -05:00
|
|
|
proc finish(purchase: string): Future[JsonNode] {.async.} =
|
2022-05-18 14:31:45 +02:00
|
|
|
while true:
|
|
|
|
let response = client.get(baseurl1 & "/storage/purchases/" & purchase)
|
2022-07-03 21:33:55 -05:00
|
|
|
let json = parseJson(response.body)
|
2022-11-08 02:10:17 -05:00
|
|
|
if json["state"].getStr == "finished": return json
|
2022-07-03 21:33:55 -05:00
|
|
|
await sleepAsync(1.seconds)
|
2022-05-18 14:31:45 +02:00
|
|
|
|
|
|
|
sell()
|
2022-07-03 21:33:55 -05:00
|
|
|
let purchase = waitFor upload().buy().finish()
|
2022-05-18 14:31:45 +02:00
|
|
|
|
|
|
|
check purchase["error"].getStr == ""
|
|
|
|
check available().len == 0
|