mirror of
https://github.com/status-im/nim-dagger.git
synced 2025-01-12 15:44:18 +00:00
[marketplace] support latest contracts changes (#327)
* [marketplace] support removal of Storage contract * [marketplace] change submod dep dagger-contracts to codex-contracts-eth
This commit is contained in:
parent
b1cf8e5239
commit
df729be261
2
.github/workflows/ci.yml
vendored
2
.github/workflows/ci.yml
vendored
@ -46,7 +46,7 @@ jobs:
|
||||
run: make -j${ncpu} test
|
||||
|
||||
- name: Start Ethereum node with Codex contracts
|
||||
working-directory: vendor/dagger-contracts
|
||||
working-directory: vendor/codex-contracts-eth
|
||||
run: |
|
||||
if [[ '${{ matrix.os }}' == 'windows' ]]; then
|
||||
export PATH="${PATH}:/c/program files/nodejs"
|
||||
|
7
.gitmodules
vendored
7
.gitmodules
vendored
@ -133,10 +133,6 @@
|
||||
url = https://github.com/status-im/nim-websock.git
|
||||
ignore = untracked
|
||||
branch = master
|
||||
[submodule "vendor/dagger-contracts"]
|
||||
path = vendor/dagger-contracts
|
||||
url = https://github.com/status-im/dagger-contracts
|
||||
ignore = dirty
|
||||
[submodule "vendor/nim-contract-abi"]
|
||||
path = vendor/nim-contract-abi
|
||||
url = https://github.com/status-im/nim-contract-abi
|
||||
@ -182,3 +178,6 @@
|
||||
[submodule "vendor/nim-eth"]
|
||||
path = vendor/nim-eth
|
||||
url = https://github.com/status-im/nim-eth
|
||||
[submodule "vendor/codex-contracts-eth"]
|
||||
path = vendor/codex-contracts-eth
|
||||
url = https://github.com/status-im/codex-contracts-eth
|
||||
|
@ -132,7 +132,7 @@ $ nvm install --lts
|
||||
|
||||
In that same terminal run
|
||||
```text
|
||||
$ cd repos/nim-codex/vendor/dagger-contracts && npm install && npm start
|
||||
$ cd repos/nim-codex/vendor/codex-contracts-eth && npm install && npm start
|
||||
```
|
||||
|
||||
Those commands install and launch a [Hardhat](https://hardhat.org/) environment with nim-codex's Ethereum contracts.
|
||||
|
@ -1,12 +1,12 @@
|
||||
import contracts/requests
|
||||
import contracts/storage
|
||||
import contracts/marketplace
|
||||
import contracts/deployment
|
||||
import contracts/market
|
||||
import contracts/proofs
|
||||
import contracts/interactions
|
||||
|
||||
export requests
|
||||
export storage
|
||||
export marketplace
|
||||
export deployment
|
||||
export market
|
||||
export proofs
|
||||
|
@ -20,7 +20,7 @@ import ethers
|
||||
|
||||
let address = # fill in address where the contract was deployed
|
||||
let provider = JsonRpcProvider.new("ws://localhost:8545")
|
||||
let storage = Storage.new(address, provider)
|
||||
let marketplace = Marketplace.new(address, provider)
|
||||
```
|
||||
|
||||
Setup client and host so that they can sign transactions; here we use the first
|
||||
@ -39,7 +39,7 @@ Hosts need to put up collateral before participating in storage contracts.
|
||||
|
||||
A host can learn about the amount of collateral that is required:
|
||||
```nim
|
||||
let collateralAmount = await storage.collateralAmount()
|
||||
let collateral = await marketplace.collateral()
|
||||
```
|
||||
|
||||
The host then needs to prepare a payment to the smart contract by calling the
|
||||
@ -50,7 +50,7 @@ After preparing the payment, the host can deposit collateral:
|
||||
```nim
|
||||
await storage
|
||||
.connect(host)
|
||||
.deposit(collateralAmount)
|
||||
.deposit(collateral)
|
||||
```
|
||||
|
||||
When a host is not participating in storage offers or contracts, it can withdraw
|
||||
@ -176,6 +176,6 @@ await storage
|
||||
.markProofAsMissing(id, period)
|
||||
```
|
||||
|
||||
[1]: https://github.com/status-im/dagger-contracts/
|
||||
[1]: https://github.com/status-im/codex-contracts-eth/
|
||||
[2]: https://ethereum.org/en/developers/docs/standards/tokens/erc-20/
|
||||
[3]: https://github.com/status-im/codex-research/blob/main/design/storage-proof-timing.md
|
||||
|
@ -6,7 +6,7 @@ import pkg/questionable
|
||||
type Deployment* = object
|
||||
json: JsonNode
|
||||
|
||||
const defaultFile = "vendor" / "dagger-contracts" / "deployment-localhost.json"
|
||||
const defaultFile = "vendor" / "codex-contracts-eth" / "deployment-localhost.json"
|
||||
|
||||
## Reads deployment information from a json file. It expects a file that has
|
||||
## been exported with Hardhat deploy.
|
||||
|
@ -4,7 +4,7 @@ import ../purchasing
|
||||
import ../sales
|
||||
import ../proving
|
||||
import ./deployment
|
||||
import ./storage
|
||||
import ./marketplace
|
||||
import ./market
|
||||
import ./proofs
|
||||
import ./clock
|
||||
@ -25,11 +25,11 @@ proc new*(_: type ContractInteractions,
|
||||
signer: Signer,
|
||||
deployment: Deployment): ?ContractInteractions =
|
||||
|
||||
without address =? deployment.address(Storage):
|
||||
error "Unable to determine address of the Storage smart contract"
|
||||
without address =? deployment.address(Marketplace):
|
||||
error "Unable to determine address of the Marketplace smart contract"
|
||||
return none ContractInteractions
|
||||
|
||||
let contract = Storage.new(address, signer)
|
||||
let contract = Marketplace.new(address, signer)
|
||||
let market = OnChainMarket.new(contract)
|
||||
let proofs = OnChainProofs.new(contract)
|
||||
let clock = OnChainClock.new(signer.provider)
|
||||
|
@ -4,22 +4,22 @@ import pkg/ethers/testing
|
||||
import pkg/upraises
|
||||
import pkg/questionable
|
||||
import ../market
|
||||
import ./storage
|
||||
import ./marketplace
|
||||
|
||||
export market
|
||||
|
||||
type
|
||||
OnChainMarket* = ref object of Market
|
||||
contract: Storage
|
||||
contract: Marketplace
|
||||
signer: Signer
|
||||
MarketSubscription = market.Subscription
|
||||
EventSubscription = ethers.Subscription
|
||||
OnChainMarketSubscription = ref object of MarketSubscription
|
||||
eventSubscription: EventSubscription
|
||||
|
||||
func new*(_: type OnChainMarket, contract: Storage): OnChainMarket =
|
||||
func new*(_: type OnChainMarket, contract: Marketplace): OnChainMarket =
|
||||
without signer =? contract.signer:
|
||||
raiseAssert("Storage contract should have a signer")
|
||||
raiseAssert("Marketplace contract should have a signer")
|
||||
OnChainMarket(
|
||||
contract: contract,
|
||||
signer: signer,
|
||||
|
62
codex/contracts/marketplace.nim
Normal file
62
codex/contracts/marketplace.nim
Normal file
@ -0,0 +1,62 @@
|
||||
import pkg/ethers
|
||||
import pkg/json_rpc/rpcclient
|
||||
import pkg/stint
|
||||
import pkg/chronos
|
||||
import ../clock
|
||||
import ./requests
|
||||
|
||||
export stint
|
||||
export ethers
|
||||
|
||||
type
|
||||
Marketplace* = ref object of Contract
|
||||
StorageRequested* = object of Event
|
||||
requestId*: RequestId
|
||||
ask*: StorageAsk
|
||||
SlotFilled* = object of Event
|
||||
requestId* {.indexed.}: RequestId
|
||||
slotIndex* {.indexed.}: UInt256
|
||||
slotId*: SlotId
|
||||
RequestFulfilled* = object of Event
|
||||
requestId* {.indexed.}: RequestId
|
||||
RequestCancelled* = object of Event
|
||||
requestId* {.indexed.}: RequestId
|
||||
RequestFailed* = object of Event
|
||||
requestId* {.indexed.}: RequestId
|
||||
ProofSubmitted* = object of Event
|
||||
id*: SlotId
|
||||
proof*: seq[byte]
|
||||
|
||||
|
||||
proc collateral*(marketplace: Marketplace): UInt256 {.contract, view.}
|
||||
proc slashMisses*(marketplace: Marketplace): UInt256 {.contract, view.}
|
||||
proc slashPercentage*(marketplace: Marketplace): UInt256 {.contract, view.}
|
||||
proc minCollateralThreshold*(marketplace: Marketplace): UInt256 {.contract, view.}
|
||||
|
||||
proc deposit*(marketplace: Marketplace, amount: UInt256) {.contract.}
|
||||
proc withdraw*(marketplace: Marketplace) {.contract.}
|
||||
proc balanceOf*(marketplace: Marketplace, account: Address): UInt256 {.contract, view.}
|
||||
|
||||
proc requestStorage*(marketplace: Marketplace, request: StorageRequest) {.contract.}
|
||||
proc fillSlot*(marketplace: Marketplace, requestId: RequestId, slotIndex: UInt256, proof: seq[byte]) {.contract.}
|
||||
proc withdrawFunds*(marketplace: Marketplace, requestId: RequestId) {.contract.}
|
||||
proc freeSlot*(marketplace: Marketplace, id: SlotId) {.contract.}
|
||||
proc getRequest*(marketplace: Marketplace, id: RequestId): StorageRequest {.contract, view.}
|
||||
proc getHost*(marketplace: Marketplace, id: SlotId): Address {.contract, view.}
|
||||
|
||||
proc myRequests*(marketplace: Marketplace): seq[RequestId] {.contract, view.}
|
||||
proc state*(marketplace: Marketplace, requestId: RequestId): RequestState {.contract, view.}
|
||||
proc requestEnd*(marketplace: Marketplace, requestId: RequestId): SecondsSince1970 {.contract, view.}
|
||||
|
||||
proc proofPeriod*(marketplace: Marketplace): UInt256 {.contract, view.}
|
||||
proc proofTimeout*(marketplace: Marketplace): UInt256 {.contract, view.}
|
||||
|
||||
proc proofEnd*(marketplace: Marketplace, id: SlotId): UInt256 {.contract, view.}
|
||||
proc missingProofs*(marketplace: Marketplace, id: SlotId): UInt256 {.contract, view.}
|
||||
proc isProofRequired*(marketplace: Marketplace, id: SlotId): bool {.contract, view.}
|
||||
proc willProofBeRequired*(marketplace: Marketplace, id: SlotId): bool {.contract, view.}
|
||||
proc getChallenge*(marketplace: Marketplace, id: SlotId): array[32, byte] {.contract, view.}
|
||||
proc getPointer*(marketplace: Marketplace, id: SlotId): uint8 {.contract, view.}
|
||||
|
||||
proc submitProof*(marketplace: Marketplace, id: SlotId, proof: seq[byte]) {.contract.}
|
||||
proc markProofAsMissing*(marketplace: Marketplace, id: SlotId, period: UInt256) {.contract.}
|
@ -2,13 +2,13 @@ import std/strutils
|
||||
import pkg/ethers
|
||||
import pkg/ethers/testing
|
||||
import ../storageproofs/timing/proofs
|
||||
import ./storage
|
||||
import ./marketplace
|
||||
|
||||
export proofs
|
||||
|
||||
type
|
||||
OnChainProofs* = ref object of Proofs
|
||||
storage: Storage
|
||||
marketplace: Marketplace
|
||||
pollInterval*: Duration
|
||||
ProofsSubscription = proofs.Subscription
|
||||
EventSubscription = ethers.Subscription
|
||||
@ -17,17 +17,17 @@ type
|
||||
|
||||
const DefaultPollInterval = 3.seconds
|
||||
|
||||
proc new*(_: type OnChainProofs, storage: Storage): OnChainProofs =
|
||||
OnChainProofs(storage: storage, pollInterval: DefaultPollInterval)
|
||||
proc new*(_: type OnChainProofs, marketplace: Marketplace): OnChainProofs =
|
||||
OnChainProofs(marketplace: marketplace, pollInterval: DefaultPollInterval)
|
||||
|
||||
method periodicity*(proofs: OnChainProofs): Future[Periodicity] {.async.} =
|
||||
let period = await proofs.storage.proofPeriod()
|
||||
let period = await proofs.marketplace.proofPeriod()
|
||||
return Periodicity(seconds: period)
|
||||
|
||||
method isProofRequired*(proofs: OnChainProofs,
|
||||
id: SlotId): Future[bool] {.async.} =
|
||||
try:
|
||||
return await proofs.storage.isProofRequired(id)
|
||||
return await proofs.marketplace.isProofRequired(id)
|
||||
except ProviderError as e:
|
||||
if e.revertReason.contains("Slot empty"):
|
||||
return false
|
||||
@ -36,7 +36,7 @@ method isProofRequired*(proofs: OnChainProofs,
|
||||
method willProofBeRequired*(proofs: OnChainProofs,
|
||||
id: SlotId): Future[bool] {.async.} =
|
||||
try:
|
||||
return await proofs.storage.willProofBeRequired(id)
|
||||
return await proofs.marketplace.willProofBeRequired(id)
|
||||
except ProviderError as e:
|
||||
if e.revertReason.contains("Slot empty"):
|
||||
return false
|
||||
@ -45,7 +45,7 @@ method willProofBeRequired*(proofs: OnChainProofs,
|
||||
method getProofEnd*(proofs: OnChainProofs,
|
||||
id: SlotId): Future[UInt256] {.async.} =
|
||||
try:
|
||||
return await proofs.storage.proofEnd(id)
|
||||
return await proofs.marketplace.proofEnd(id)
|
||||
except ProviderError as e:
|
||||
if e.revertReason.contains("Slot empty"):
|
||||
return 0.u256
|
||||
@ -54,14 +54,14 @@ method getProofEnd*(proofs: OnChainProofs,
|
||||
method submitProof*(proofs: OnChainProofs,
|
||||
id: SlotId,
|
||||
proof: seq[byte]) {.async.} =
|
||||
await proofs.storage.submitProof(id, proof)
|
||||
await proofs.marketplace.submitProof(id, proof)
|
||||
|
||||
method subscribeProofSubmission*(proofs: OnChainProofs,
|
||||
callback: OnProofSubmitted):
|
||||
Future[ProofsSubscription] {.async.} =
|
||||
proc onEvent(event: ProofSubmitted) {.upraises: [].} =
|
||||
callback(event.id, event.proof)
|
||||
let subscription = await proofs.storage.subscribe(ProofSubmitted, onEvent)
|
||||
let subscription = await proofs.marketplace.subscribe(ProofSubmitted, onEvent)
|
||||
return OnChainProofsSubscription(eventSubscription: subscription)
|
||||
|
||||
method unsubscribe*(subscription: OnChainProofsSubscription) {.async, upraises:[].} =
|
||||
|
@ -1,62 +0,0 @@
|
||||
import pkg/ethers
|
||||
import pkg/json_rpc/rpcclient
|
||||
import pkg/stint
|
||||
import pkg/chronos
|
||||
import ../clock
|
||||
import ./requests
|
||||
|
||||
export stint
|
||||
export ethers
|
||||
|
||||
type
|
||||
Storage* = ref object of Contract
|
||||
StorageRequested* = object of Event
|
||||
requestId*: RequestId
|
||||
ask*: StorageAsk
|
||||
SlotFilled* = object of Event
|
||||
requestId* {.indexed.}: RequestId
|
||||
slotIndex* {.indexed.}: UInt256
|
||||
slotId*: SlotId
|
||||
RequestFulfilled* = object of Event
|
||||
requestId* {.indexed.}: RequestId
|
||||
RequestCancelled* = object of Event
|
||||
requestId* {.indexed.}: RequestId
|
||||
RequestFailed* = object of Event
|
||||
requestId* {.indexed.}: RequestId
|
||||
ProofSubmitted* = object of Event
|
||||
id*: SlotId
|
||||
proof*: seq[byte]
|
||||
|
||||
|
||||
proc collateralAmount*(storage: Storage): UInt256 {.contract, view.}
|
||||
proc slashMisses*(storage: Storage): UInt256 {.contract, view.}
|
||||
proc slashPercentage*(storage: Storage): UInt256 {.contract, view.}
|
||||
proc minCollateralThreshold*(storage: Storage): UInt256 {.contract, view.}
|
||||
|
||||
proc deposit*(storage: Storage, amount: UInt256) {.contract.}
|
||||
proc withdraw*(storage: Storage) {.contract.}
|
||||
proc balanceOf*(storage: Storage, account: Address): UInt256 {.contract, view.}
|
||||
|
||||
proc requestStorage*(storage: Storage, request: StorageRequest) {.contract.}
|
||||
proc fillSlot*(storage: Storage, requestId: RequestId, slotIndex: UInt256, proof: seq[byte]) {.contract.}
|
||||
proc withdrawFunds*(storage: Storage, requestId: RequestId) {.contract.}
|
||||
proc payoutSlot*(storage: Storage, requestId: RequestId, slotIndex: UInt256) {.contract.}
|
||||
proc getRequest*(storage: Storage, id: RequestId): StorageRequest {.contract, view.}
|
||||
proc getHost*(storage: Storage, id: SlotId): Address {.contract, view.}
|
||||
|
||||
proc myRequests*(storage: Storage): seq[RequestId] {.contract, view.}
|
||||
proc state*(storage: Storage, requestId: RequestId): RequestState {.contract, view.}
|
||||
proc requestEnd*(storage: Storage, requestId: RequestId): SecondsSince1970 {.contract, view.}
|
||||
|
||||
proc proofPeriod*(storage: Storage): UInt256 {.contract, view.}
|
||||
proc proofTimeout*(storage: Storage): UInt256 {.contract, view.}
|
||||
|
||||
proc proofEnd*(storage: Storage, id: SlotId): UInt256 {.contract, view.}
|
||||
proc missingProofs*(storage: Storage, id: SlotId): UInt256 {.contract, view.}
|
||||
proc isProofRequired*(storage: Storage, id: SlotId): bool {.contract, view.}
|
||||
proc willProofBeRequired*(storage: Storage, id: SlotId): bool {.contract, view.}
|
||||
proc getChallenge*(storage: Storage, id: SlotId): array[32, byte] {.contract, view.}
|
||||
proc getPointer*(storage: Storage, id: SlotId): uint8 {.contract, view.}
|
||||
|
||||
proc submitProof*(storage: Storage, id: SlotId, proof: seq[byte]) {.contract.}
|
||||
proc markProofAsMissing*(storage: Storage, id: SlotId, period: UInt256) {.contract.}
|
@ -6,27 +6,27 @@ import ../ethertest
|
||||
|
||||
ethersuite "Collateral":
|
||||
|
||||
let collateralAmount = 100.u256
|
||||
let collateral = 100.u256
|
||||
|
||||
var storage: Storage
|
||||
var marketplace: Marketplace
|
||||
var token: TestToken
|
||||
|
||||
setup:
|
||||
let deployment = deployment()
|
||||
storage = Storage.new(!deployment.address(Storage), provider.getSigner())
|
||||
marketplace = Marketplace.new(!deployment.address(Marketplace), provider.getSigner())
|
||||
token = TestToken.new(!deployment.address(TestToken), provider.getSigner())
|
||||
await token.mint(accounts[0], 1000.u256)
|
||||
|
||||
test "increases collateral":
|
||||
await token.approve(storage.address, collateralAmount)
|
||||
await storage.deposit(collateralAmount)
|
||||
let collateral = await storage.balanceOf(accounts[0])
|
||||
check collateral == collateralAmount
|
||||
await token.approve(marketplace.address, collateral)
|
||||
await marketplace.deposit(collateral)
|
||||
let balance = await marketplace.balanceOf(accounts[0])
|
||||
check balance == collateral
|
||||
|
||||
test "withdraws collateral":
|
||||
await token.approve(storage.address, collateralAmount)
|
||||
await storage.deposit(collateralAmount)
|
||||
await token.approve(marketplace.address, collateral)
|
||||
await marketplace.deposit(collateral)
|
||||
let balanceBefore = await token.balanceOf(accounts[0])
|
||||
await storage.withdraw()
|
||||
await marketplace.withdraw()
|
||||
let balanceAfter = await token.balanceOf(accounts[0])
|
||||
check (balanceAfter - balanceBefore) == collateralAmount
|
||||
check (balanceAfter - balanceBefore) == collateral
|
||||
|
@ -8,19 +8,19 @@ import ../ethertest
|
||||
import ./examples
|
||||
import ./time
|
||||
|
||||
ethersuite "Storage contracts":
|
||||
ethersuite "Marketplace contracts":
|
||||
let proof = exampleProof()
|
||||
|
||||
var client, host: Signer
|
||||
var storage: Storage
|
||||
var marketplace: Marketplace
|
||||
var token: TestToken
|
||||
var collateralAmount: UInt256
|
||||
var collateral: UInt256
|
||||
var periodicity: Periodicity
|
||||
var request: StorageRequest
|
||||
var slotId: SlotId
|
||||
|
||||
proc switchAccount(account: Signer) =
|
||||
storage = storage.connect(account)
|
||||
marketplace = marketplace.connect(account)
|
||||
token = token.connect(account)
|
||||
|
||||
setup:
|
||||
@ -28,44 +28,44 @@ ethersuite "Storage contracts":
|
||||
host = provider.getSigner(accounts[1])
|
||||
|
||||
let deployment = deployment()
|
||||
storage = Storage.new(!deployment.address(Storage), provider.getSigner())
|
||||
marketplace = Marketplace.new(!deployment.address(Marketplace), provider.getSigner())
|
||||
token = TestToken.new(!deployment.address(TestToken), provider.getSigner())
|
||||
|
||||
await token.mint(await client.getAddress(), 1_000_000_000.u256)
|
||||
await token.mint(await host.getAddress(), 1000_000_000.u256)
|
||||
|
||||
collateralAmount = await storage.collateralAmount()
|
||||
periodicity = Periodicity(seconds: await storage.proofPeriod())
|
||||
collateral = await marketplace.collateral()
|
||||
periodicity = Periodicity(seconds: await marketplace.proofPeriod())
|
||||
|
||||
request = StorageRequest.example
|
||||
request.client = await client.getAddress()
|
||||
|
||||
switchAccount(client)
|
||||
await token.approve(storage.address, request.price)
|
||||
await storage.requestStorage(request)
|
||||
await token.approve(marketplace.address, request.price)
|
||||
await marketplace.requestStorage(request)
|
||||
switchAccount(host)
|
||||
await token.approve(storage.address, collateralAmount)
|
||||
await storage.deposit(collateralAmount)
|
||||
await storage.fillSlot(request.id, 0.u256, proof)
|
||||
await token.approve(marketplace.address, collateral)
|
||||
await marketplace.deposit(collateral)
|
||||
await marketplace.fillSlot(request.id, 0.u256, proof)
|
||||
slotId = request.slotId(0.u256)
|
||||
|
||||
proc waitUntilProofRequired(slotId: SlotId) {.async.} =
|
||||
let currentPeriod = periodicity.periodOf(await provider.currentTime())
|
||||
await provider.advanceTimeTo(periodicity.periodEnd(currentPeriod))
|
||||
while not (
|
||||
(await storage.isProofRequired(slotId)) and
|
||||
(await storage.getPointer(slotId)) < 250
|
||||
(await marketplace.isProofRequired(slotId)) and
|
||||
(await marketplace.getPointer(slotId)) < 250
|
||||
):
|
||||
await provider.advanceTime(periodicity.seconds)
|
||||
|
||||
proc startContract() {.async.} =
|
||||
for slotIndex in 1..<request.ask.slots:
|
||||
await storage.fillSlot(request.id, slotIndex.u256, proof)
|
||||
await marketplace.fillSlot(request.id, slotIndex.u256, proof)
|
||||
|
||||
test "accept storage proofs":
|
||||
test "accept marketplace proofs":
|
||||
switchAccount(host)
|
||||
await waitUntilProofRequired(slotId)
|
||||
await storage.submitProof(slotId, proof)
|
||||
await marketplace.submitProof(slotId, proof)
|
||||
|
||||
test "can mark missing proofs":
|
||||
switchAccount(host)
|
||||
@ -73,20 +73,24 @@ ethersuite "Storage contracts":
|
||||
let missingPeriod = periodicity.periodOf(await provider.currentTime())
|
||||
await provider.advanceTime(periodicity.seconds)
|
||||
switchAccount(client)
|
||||
await storage.markProofAsMissing(slotId, missingPeriod)
|
||||
await marketplace.markProofAsMissing(slotId, missingPeriod)
|
||||
|
||||
test "can be paid out at the end":
|
||||
switchAccount(host)
|
||||
let address = await host.getAddress()
|
||||
await startContract()
|
||||
let requestEnd = await storage.requestEnd(request.id)
|
||||
let requestEnd = await marketplace.requestEnd(request.id)
|
||||
await provider.advanceTimeTo(requestEnd.u256)
|
||||
await storage.payoutSlot(request.id, 0.u256)
|
||||
let startBalance = await token.balanceOf(address)
|
||||
await marketplace.freeSlot(slotId)
|
||||
let endBalance = await token.balanceOf(address)
|
||||
check endBalance == (startBalance + request.ask.duration * request.ask.reward)
|
||||
|
||||
test "cannot mark proofs missing for cancelled request":
|
||||
await provider.advanceTimeTo(request.expiry + 1)
|
||||
switchAccount(client)
|
||||
let missingPeriod = periodicity.periodOf(await provider.currentTime())
|
||||
await provider.advanceTime(periodicity.seconds)
|
||||
check await storage
|
||||
check await marketplace
|
||||
.markProofAsMissing(slotId, missingPeriod)
|
||||
.reverts("Slot not accepting proofs")
|
||||
|
@ -3,7 +3,7 @@ import codex/contracts
|
||||
import ../ethertest
|
||||
import ./examples
|
||||
|
||||
ethersuite "Storage Contract Interactions":
|
||||
ethersuite "Marketplace Contract Interactions":
|
||||
|
||||
let account = Address.example
|
||||
|
||||
@ -20,7 +20,7 @@ ethersuite "Storage Contract Interactions":
|
||||
test "can be instantiated with a provider url":
|
||||
let url = "http://localhost:8545"
|
||||
let account = Address.example
|
||||
let deployment = "vendor" / "dagger-contracts" / "deployment-localhost.json"
|
||||
let deployment = "vendor" / "codex-contracts-eth" / "deployment-localhost.json"
|
||||
check ContractInteractions.new(url, account).isSome
|
||||
check ContractInteractions.new(url, account, deployment).isSome
|
||||
|
||||
|
@ -12,7 +12,7 @@ ethersuite "On-Chain Market":
|
||||
let proof = exampleProof()
|
||||
|
||||
var market: OnChainMarket
|
||||
var storage: Storage
|
||||
var marketplace: Marketplace
|
||||
var token: TestToken
|
||||
var request: StorageRequest
|
||||
var slotIndex: UInt256
|
||||
@ -20,16 +20,16 @@ ethersuite "On-Chain Market":
|
||||
|
||||
setup:
|
||||
let deployment = deployment()
|
||||
storage = Storage.new(!deployment.address(Storage), provider.getSigner())
|
||||
marketplace = Marketplace.new(!deployment.address(Marketplace), provider.getSigner())
|
||||
token = TestToken.new(!deployment.address(TestToken), provider.getSigner())
|
||||
await token.mint(accounts[0], 1_000_000_000.u256)
|
||||
|
||||
let collateral = await storage.collateralAmount()
|
||||
await token.approve(storage.address, collateral)
|
||||
await storage.deposit(collateral)
|
||||
let collateral = await marketplace.collateral()
|
||||
await token.approve(marketplace.address, collateral)
|
||||
await marketplace.deposit(collateral)
|
||||
|
||||
market = OnChainMarket.new(storage)
|
||||
periodicity = Periodicity(seconds: await storage.proofPeriod())
|
||||
market = OnChainMarket.new(marketplace)
|
||||
periodicity = Periodicity(seconds: await marketplace.proofPeriod())
|
||||
|
||||
request = StorageRequest.example
|
||||
request.client = accounts[0]
|
||||
@ -40,32 +40,32 @@ ethersuite "On-Chain Market":
|
||||
let currentPeriod = periodicity.periodOf(await provider.currentTime())
|
||||
await provider.advanceTimeTo(periodicity.periodEnd(currentPeriod))
|
||||
while not (
|
||||
(await storage.isProofRequired(slotId)) and
|
||||
(await storage.getPointer(slotId)) < 250
|
||||
(await marketplace.isProofRequired(slotId)) and
|
||||
(await marketplace.getPointer(slotId)) < 250
|
||||
):
|
||||
await provider.advanceTime(periodicity.seconds)
|
||||
|
||||
test "fails to instantiate when contract does not have a signer":
|
||||
let storageWithoutSigner = storage.connect(provider)
|
||||
let storageWithoutSigner = marketplace.connect(provider)
|
||||
expect AssertionError:
|
||||
discard OnChainMarket.new(storageWithoutSigner)
|
||||
|
||||
test "knows signer address":
|
||||
check (await market.getSigner()) == (await provider.getSigner().getAddress())
|
||||
|
||||
test "supports storage requests":
|
||||
await token.approve(storage.address, request.price)
|
||||
test "supports marketplace requests":
|
||||
await token.approve(marketplace.address, request.price)
|
||||
await market.requestStorage(request)
|
||||
|
||||
test "can retrieve previously submitted requests":
|
||||
check (await market.getRequest(request.id)) == none StorageRequest
|
||||
await token.approve(storage.address, request.price)
|
||||
await token.approve(marketplace.address, request.price)
|
||||
await market.requestStorage(request)
|
||||
let r = await market.getRequest(request.id)
|
||||
check (r) == some request
|
||||
|
||||
test "supports withdrawing of funds":
|
||||
await token.approve(storage.address, request.price)
|
||||
await token.approve(marketplace.address, request.price)
|
||||
await market.requestStorage(request)
|
||||
await provider.advanceTimeTo(request.expiry)
|
||||
await market.withdrawFunds(request.id)
|
||||
@ -77,26 +77,26 @@ ethersuite "On-Chain Market":
|
||||
receivedIds.add(id)
|
||||
receivedAsks.add(ask)
|
||||
let subscription = await market.subscribeRequests(onRequest)
|
||||
await token.approve(storage.address, request.price)
|
||||
await token.approve(marketplace.address, request.price)
|
||||
await market.requestStorage(request)
|
||||
check receivedIds == @[request.id]
|
||||
check receivedAsks == @[request.ask]
|
||||
await subscription.unsubscribe()
|
||||
|
||||
test "supports filling of slots":
|
||||
await token.approve(storage.address, request.price)
|
||||
await token.approve(marketplace.address, request.price)
|
||||
await market.requestStorage(request)
|
||||
await market.fillSlot(request.id, slotIndex, proof)
|
||||
|
||||
test "can retrieve host that filled slot":
|
||||
await token.approve(storage.address, request.price)
|
||||
await token.approve(marketplace.address, request.price)
|
||||
await market.requestStorage(request)
|
||||
check (await market.getHost(request.id, slotIndex)) == none Address
|
||||
await market.fillSlot(request.id, slotIndex, proof)
|
||||
check (await market.getHost(request.id, slotIndex)) == some accounts[0]
|
||||
|
||||
test "support slot filled subscriptions":
|
||||
await token.approve(storage.address, request.price)
|
||||
await token.approve(marketplace.address, request.price)
|
||||
await market.requestStorage(request)
|
||||
var receivedIds: seq[RequestId]
|
||||
var receivedSlotIndices: seq[UInt256]
|
||||
@ -111,7 +111,7 @@ ethersuite "On-Chain Market":
|
||||
|
||||
test "subscribes only to a certain slot":
|
||||
var otherSlot = slotIndex - 1
|
||||
await token.approve(storage.address, request.price)
|
||||
await token.approve(marketplace.address, request.price)
|
||||
await market.requestStorage(request)
|
||||
var receivedSlotIndices: seq[UInt256]
|
||||
proc onSlotFilled(requestId: RequestId, slotIndex: UInt256) =
|
||||
@ -124,7 +124,7 @@ ethersuite "On-Chain Market":
|
||||
await subscription.unsubscribe()
|
||||
|
||||
test "support fulfillment subscriptions":
|
||||
await token.approve(storage.address, request.price)
|
||||
await token.approve(marketplace.address, request.price)
|
||||
await market.requestStorage(request)
|
||||
var receivedIds: seq[RequestId]
|
||||
proc onFulfillment(id: RequestId) =
|
||||
@ -139,9 +139,9 @@ ethersuite "On-Chain Market":
|
||||
var otherRequest = StorageRequest.example
|
||||
otherRequest.client = accounts[0]
|
||||
|
||||
await token.approve(storage.address, request.price)
|
||||
await token.approve(marketplace.address, request.price)
|
||||
await market.requestStorage(request)
|
||||
await token.approve(storage.address, otherRequest.price)
|
||||
await token.approve(marketplace.address, otherRequest.price)
|
||||
await market.requestStorage(otherRequest)
|
||||
|
||||
var receivedIds: seq[RequestId]
|
||||
@ -160,7 +160,7 @@ ethersuite "On-Chain Market":
|
||||
await subscription.unsubscribe()
|
||||
|
||||
test "support request cancelled subscriptions":
|
||||
await token.approve(storage.address, request.price)
|
||||
await token.approve(marketplace.address, request.price)
|
||||
await market.requestStorage(request)
|
||||
|
||||
var receivedIds: seq[RequestId]
|
||||
@ -174,7 +174,7 @@ ethersuite "On-Chain Market":
|
||||
await subscription.unsubscribe()
|
||||
|
||||
test "support request failed subscriptions":
|
||||
await token.approve(storage.address, request.price)
|
||||
await token.approve(marketplace.address, request.price)
|
||||
await market.requestStorage(request)
|
||||
|
||||
var receivedIds: seq[RequestId]
|
||||
@ -191,7 +191,7 @@ ethersuite "On-Chain Market":
|
||||
await waitUntilProofRequired(slotId)
|
||||
let missingPeriod = periodicity.periodOf(await provider.currentTime())
|
||||
await provider.advanceTime(periodicity.seconds)
|
||||
await storage.markProofAsMissing(slotId, missingPeriod)
|
||||
await marketplace.markProofAsMissing(slotId, missingPeriod)
|
||||
except ProviderError as e:
|
||||
if e.revertReason == "Slot empty":
|
||||
break
|
||||
@ -201,9 +201,9 @@ ethersuite "On-Chain Market":
|
||||
test "subscribes only to a certain request cancellation":
|
||||
var otherRequest = request
|
||||
otherRequest.nonce = Nonce.example
|
||||
await token.approve(storage.address, request.price)
|
||||
await token.approve(marketplace.address, request.price)
|
||||
await market.requestStorage(request)
|
||||
await token.approve(storage.address, otherRequest.price)
|
||||
await token.approve(marketplace.address, otherRequest.price)
|
||||
await market.requestStorage(otherRequest)
|
||||
|
||||
var receivedIds: seq[RequestId]
|
||||
@ -222,16 +222,16 @@ ethersuite "On-Chain Market":
|
||||
check isNone await market.getRequest(request.id)
|
||||
|
||||
test "can retrieve active requests":
|
||||
await token.approve(storage.address, request.price)
|
||||
await token.approve(marketplace.address, request.price)
|
||||
await market.requestStorage(request)
|
||||
var request2 = StorageRequest.example
|
||||
request2.client = accounts[0]
|
||||
await token.approve(storage.address, request2.price)
|
||||
await token.approve(marketplace.address, request2.price)
|
||||
await market.requestStorage(request2)
|
||||
check (await market.myRequests()) == @[request.id, request2.id]
|
||||
|
||||
test "can retrieve request state":
|
||||
await token.approve(storage.address, request.price)
|
||||
await token.approve(marketplace.address, request.price)
|
||||
await market.requestStorage(request)
|
||||
for slotIndex in 0..<request.ask.slots:
|
||||
await market.fillSlot(request.id, slotIndex.u256, proof)
|
||||
|
@ -9,16 +9,16 @@ ethersuite "On-Chain Proofs":
|
||||
let proof = exampleProof()
|
||||
|
||||
var proofs: OnChainProofs
|
||||
var storage: Storage
|
||||
var marketplace: Marketplace
|
||||
|
||||
setup:
|
||||
let deployment = deployment()
|
||||
storage = Storage.new(!deployment.address(Storage), provider.getSigner())
|
||||
proofs = OnChainProofs.new(storage)
|
||||
marketplace = Marketplace.new(!deployment.address(Marketplace), provider.getSigner())
|
||||
proofs = OnChainProofs.new(marketplace)
|
||||
|
||||
test "can retrieve proof periodicity":
|
||||
let periodicity = await proofs.periodicity()
|
||||
let periodLength = await storage.proofPeriod()
|
||||
let periodLength = await marketplace.proofPeriod()
|
||||
check periodicity.seconds == periodLength
|
||||
|
||||
test "supports checking whether proof is required now":
|
||||
|
@ -3,13 +3,13 @@ import codex/contracts/testtoken
|
||||
|
||||
proc mint*(signer: Signer, amount = 1_000_000.u256) {.async.} =
|
||||
## Mints a considerable amount of tokens and approves them for transfer to
|
||||
## the Storage contract.
|
||||
## the Marketplace contract.
|
||||
let token = TestToken.new(!deployment().address(TestToken), signer)
|
||||
let storage = Storage.new(!deployment().address(Storage), signer)
|
||||
let marketplace = Marketplace.new(!deployment().address(Marketplace), signer)
|
||||
await token.mint(await signer.getAddress(), amount)
|
||||
await token.approve(storage.address, amount)
|
||||
await token.approve(marketplace.address, amount)
|
||||
|
||||
proc deposit*(signer: Signer) {.async.} =
|
||||
## Deposits sufficient collateral into the Storage contract.
|
||||
let storage = Storage.new(!deployment().address(Storage), signer)
|
||||
await storage.deposit(await storage.collateralAmount())
|
||||
## Deposits sufficient collateral into the Marketplace contract.
|
||||
let marketplace = Marketplace.new(!deployment().address(Marketplace), signer)
|
||||
await marketplace.deposit(await marketplace.collateral())
|
||||
|
1
vendor/codex-contracts-eth
vendored
Submodule
1
vendor/codex-contracts-eth
vendored
Submodule
@ -0,0 +1 @@
|
||||
Subproject commit ce335d0568b4d056def6570f7d5d5c0d6a840083
|
1
vendor/dagger-contracts
vendored
1
vendor/dagger-contracts
vendored
@ -1 +0,0 @@
|
||||
Subproject commit 61b8f5fc352838866b0fe27b936323de45bf269c
|
Loading…
x
Reference in New Issue
Block a user