dagger-contracts/test/examples.js

60 lines
1.2 KiB
JavaScript
Raw Normal View History

const { ethers } = require("hardhat")
const { hours } = require("./time")
2023-01-17 10:07:12 +00:00
const { hexlify, randomBytes } = ethers.utils
const exampleConfiguration = () => ({
collateral: {
repairRewardPercentage: 10,
maxNumberOfSlashes: 5,
slashCriterion: 3,
slashPercentage: 10,
},
proofs: {
period: 10,
timeout: 5,
downtime: 64,
zkeyHash: "",
downtimeProduct: 67,
},
})
const exampleRequest = async () => {
return {
client: hexlify(randomBytes(20)),
ask: {
slots: 4,
slotSize: 1 * 1024 * 1024 * 1024, // 1 Gigabyte
duration: hours(10),
proofProbability: 4, // require a proof roughly once every 4 periods
reward: 84,
maxSlotLoss: 2,
2023-03-08 11:02:34 +00:00
collateral: 200,
},
content: {
cid: "zb2rhheVmk3bLks5MgzTqyznLu1zqGH5jrfTA1eAZXrjx7Vob",
2024-01-10 14:12:18 +00:00
merkleRoot: Array.from(randomBytes(32)),
},
expiry: hours(1),
nonce: hexlify(randomBytes(32)),
}
}
2022-02-15 16:01:54 +00:00
2024-01-18 12:50:54 +00:00
const exampleProof = () => ({
a: { x: 1, y: 2 },
2024-01-25 12:13:32 +00:00
b: { x: [3, 4], y: [5, 6] },
c: { x: 7, y: 8 },
2024-01-18 12:50:54 +00:00
})
const invalidProof = () => ({
a: { x: 0, y: 0 },
b: { x: [0, 0], y: [0, 0] },
c: { x: 0, y: 0 },
})
module.exports = {
exampleConfiguration,
exampleRequest,
exampleProof,
invalidProof,
}