2021-10-21 12:06:30 +00:00
|
|
|
const { expect } = require("chai")
|
|
|
|
const { ethers } = require("hardhat")
|
|
|
|
|
|
|
|
describe("Stakes", function () {
|
|
|
|
|
|
|
|
var stakes
|
|
|
|
var token
|
|
|
|
var host
|
|
|
|
|
|
|
|
beforeEach(async function() {
|
|
|
|
[host] = await ethers.getSigners()
|
|
|
|
const Stakes = await ethers.getContractFactory("TestStakes")
|
|
|
|
const TestToken = await ethers.getContractFactory("TestToken")
|
|
|
|
token = await TestToken.deploy()
|
|
|
|
stakes = await Stakes.deploy(token.address)
|
|
|
|
})
|
|
|
|
|
|
|
|
it("has zero stakes initially", async function () {
|
|
|
|
const address = await host.getAddress()
|
|
|
|
const stake = await stakes.stake(address)
|
|
|
|
expect(stake).to.equal(0)
|
|
|
|
})
|
|
|
|
|
|
|
|
it("increases stakes by transferring tokens", async function () {
|
|
|
|
await token.approve(stakes.address, 20)
|
2021-11-01 14:17:19 +00:00
|
|
|
await stakes.increaseStake(20)
|
2021-10-21 12:06:30 +00:00
|
|
|
let stake = await stakes.stake(host.address)
|
|
|
|
expect(stake).to.equal(20)
|
|
|
|
})
|
|
|
|
|
|
|
|
it("does not increase stake when token transfer fails", async function () {
|
|
|
|
await expect(
|
2021-11-01 14:17:19 +00:00
|
|
|
stakes.increaseStake(20)
|
2021-10-21 12:06:30 +00:00
|
|
|
).to.be.revertedWith("ERC20: transfer amount exceeds allowance")
|
|
|
|
})
|
|
|
|
|
|
|
|
it("allows withdrawal of stake", async function () {
|
|
|
|
await token.approve(stakes.address, 20)
|
2021-11-01 14:17:19 +00:00
|
|
|
await stakes.increaseStake(20)
|
2021-10-21 12:06:30 +00:00
|
|
|
let balanceBefore = await token.balanceOf(host.address)
|
2021-11-01 14:17:19 +00:00
|
|
|
await stakes.withdrawStake()
|
2021-10-21 12:06:30 +00:00
|
|
|
let balanceAfter = await token.balanceOf(host.address)
|
|
|
|
expect(balanceAfter - balanceBefore).to.equal(20)
|
|
|
|
})
|
|
|
|
|
|
|
|
it("locks stake", async function () {
|
|
|
|
await token.approve(stakes.address, 20)
|
2021-11-01 14:17:19 +00:00
|
|
|
await stakes.increaseStake(20)
|
|
|
|
await stakes.lockStake(host.address)
|
|
|
|
await expect(stakes.withdrawStake()).to.be.revertedWith("Stake locked")
|
|
|
|
await stakes.unlockStake(host.address)
|
|
|
|
await expect(stakes.withdrawStake()).not.to.be.reverted
|
2021-10-21 12:06:30 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
it("fails to unlock when already unlocked", async function () {
|
|
|
|
await expect(
|
2021-11-01 14:17:19 +00:00
|
|
|
stakes.unlockStake(host.address)
|
2021-10-21 12:06:30 +00:00
|
|
|
).to.be.revertedWith("Stake already unlocked")
|
|
|
|
})
|
|
|
|
|
|
|
|
it("requires an equal amount of locks and unlocks", async function () {
|
|
|
|
await token.approve(stakes.address, 20)
|
2021-11-01 14:17:19 +00:00
|
|
|
await stakes.increaseStake(20)
|
|
|
|
await stakes.lockStake(host.address)
|
|
|
|
await stakes.lockStake(host.address)
|
|
|
|
await stakes.unlockStake(host.address)
|
|
|
|
await expect(stakes.withdrawStake()).to.be.revertedWith("Stake locked")
|
|
|
|
await stakes.unlockStake(host.address)
|
|
|
|
await expect(stakes.withdrawStake()).not.to.be.reverted
|
2021-10-21 12:06:30 +00:00
|
|
|
})
|
|
|
|
})
|