add dodo starter tests

This commit is contained in:
tracy
2022-03-20 22:21:35 +08:00
committed by owen05
parent 234d82aa94
commit e435578b3f
3 changed files with 477 additions and 56 deletions

View File

@@ -9,7 +9,7 @@
import { decimalStr, MAX_UINT256 } from '../utils/Converter';
import { logGas } from '../utils/Log';
import { DODOStarterContext,getDODOStarterContext } from '../utils/DODOStarterContext';
import { DODOStarterContext, DODOStarterContextInitConfig} from '../utils/DODOStarterContext';
import { assert } from 'chai';
import * as contracts from '../utils/Contracts';
import BigNumber from 'bignumber.js';
@@ -17,30 +17,32 @@ import { StringLiteralLike } from 'typescript';
const truffleAssert = require('truffle-assertions');
let maker: string;
let user: string;
async function init(ctx: NFTPoolContext): Promise<void> {
maker = ctx.SpareAccounts[0];
user = ctx.SpareAccounts[1];
let user1: string;
let user2: string;
let sellTokenAddress: string;
let fundTokenAddress: string;
let config: DODOStarterContextInitConfig = {
// time config
bidDuration: new BigNumber(86400),
calmDuration: new BigNumber(86400),
tokenVestingDuration: new BigNumber(86400),
fundVestingDuration: new BigNumber(86400),
lpVestingDuration: new BigNumber(86400),
// value config
lowerPrice: decimalStr("1"),
upperPrice: decimalStr("5"),
tokenCliffRate: decimalStr("1"),
fundCliffRate: decimalStr("1"),
lpCliffRate: decimalStr("1"),
initialLiquidity: decimalStr("1"),
}
async function createFairFunding(ctx: DODOStarterContext) {
// var tx = await logGas(ctx.DODONFTPoolProxy.methods.createNewNFTPoolV1(
// maker,
// ctx.DodoNft.options.address,
// 1,
// ['Filter01', 'FRAG', 'FRAG'],
// [decimalStr("10000000"), decimalStr("0.005")],
// [true, true, true],
// [0, 4, 5, 1],
// [decimalStr("1"), decimalStr("0.9"), decimalStr("1"), decimalStr("0.9"), decimalStr("2"), decimalStr("0.9")],
// [7]
// ), ctx.sendParam(maker), "createNewNFTPoolV1");
// var newFilterAdmin = tx.events['CreateNFTPool'].returnValues['newFilterAdmin']
// var filter = tx.events['CreateNFTPool'].returnValues['filter']
// return [newFilterAdmin, filter];
async function init(ctx: DODOStarterContext): Promise<void> {
maker = ctx.SpareAccounts[0];
user1 = ctx.SpareAccounts[1];
user2 = ctx.SpareAccounts[2];
sellTokenAddress = ctx.SellToken.options.address;
fundTokenAddress = ctx.FundToken.options.address;
}
describe("FairFunding", () => {
@@ -48,7 +50,8 @@ describe("FairFunding", () => {
let ctx: DODOStarterContext;
before(async () => {
ctx = await getDODOStarterContext();
ctx = new DODOStarterContext();
await ctx.init(config);
await init(ctx);
});
@@ -60,31 +63,188 @@ describe("FairFunding", () => {
await ctx.EVM.reset(snapshotId);
});
describe("FairFunding", () => {
it("Create_FairFunding", async () => {
// var tx = await logGas(ctx.DODONFTPoolProxy.methods.createNewNFTPoolV1(
// maker,
// ctx.DodoNft.options.address,
// 1,
// ['Filter01', 'FRAG', 'FRAG'],
// [decimalStr("10000000"), decimalStr("0.005")],
// [true, true, true],
// [0, 3, 2, 1],
// [decimalStr("1"), decimalStr("1.1"), decimalStr("1"), decimalStr("1.1"), decimalStr("2"), decimalStr("1.1")],
// [5]
// ), ctx.sendParam(maker), "createNewNFTPoolV1");
// var newFilterAdmin = tx.events['CreateNFTPool'].returnValues['newFilterAdmin']
// var filter = tx.events['CreateNFTPool'].returnValues['filter']
// console.log("newFilterAdmin:", newFilterAdmin)
// console.log("filterV1:", filter)
// assert.equal(
// tx.events['CreateNFTPool'].returnValues['filterAdminOwner'],
// maker
// )
describe("Basic Info", () => {
it("get the correct cooling duration", async () => {
assert.equal(await ctx.FairFunding.methods._COOLING_DURATION_().call(), 86400);
});
it("get the correct lower limit price", async () => {
assert.equal(await ctx.FairFunding.methods._LOWER_LIMIT_PRICE_().call(), decimalStr("1"));
});
it("get the correct upper limit price", async () => {
assert.equal(await ctx.FairFunding.methods._UPPER_LIMIT_PRICE_().call(), decimalStr("5"));
});
it("get the correct _IS_OVERCAP_STOP", async () => {
assert.equal(await ctx.FairFunding.methods._IS_OVERCAP_STOP().call(), true);
});
it("check if deposit is open", async () => {
assert.equal(await ctx.FairFunding.methods.isDepositOpen().call(), true)
await ctx.EVM.increaseTime(86400)
assert.equal(await ctx.FairFunding.methods.isDepositOpen().call(), false)
});
it("check if funding is end", async () => {
assert.equal(await ctx.FairFunding.methods.isFundingEnd().call(), false)
await ctx.EVM.increaseTime(86400 * 2 + 1)
assert.equal(await ctx.FairFunding.methods.isFundingEnd().call(), true)
});
it("check if is Settled",async () => {
assert.equal(await ctx.FairFunding.methods.isSettled().call(), false)
await ctx.EVM.increaseTime(86400 * 2 + 1)
await logGas(ctx.FairFunding.methods.settle(), ctx.sendParam(ctx.Deployer), "settle")
assert.equal(await ctx.FairFunding.methods.isSettled().call(), true)
})
});
describe("Deposit Funds", () => {
it("successfully deposit funds", async () => {
await ctx.FundToken.methods.mint(user1, decimalStr("10000")).send(ctx.sendParam(user1));
await ctx.FundToken.methods.transfer(ctx.FairFunding.options.address, 3).send(ctx.sendParam(user1));
var tx = await logGas(ctx.FairFunding.methods.depositFunds(user1), ctx.sendParam(user1), "depositFunds");
var account = tx.events['DepositFund'].returnValues['account'];
var fundAmount = tx.events['DepositFund'].returnValues['fundAmount'];
assert.equal(account, user1);
assert.equal(fundAmount, 3);
})
it("revert if the deposit is not open", async () => {
await ctx.FundToken.methods.mint(user1, decimalStr("10000")).send(ctx.sendParam(user1));
await ctx.FundToken.methods.transfer(ctx.FairFunding.options.address, 3).send(ctx.sendParam(user1));
await ctx.EVM.increaseTime(86400);
await truffleAssert.reverts(ctx.FairFunding.methods.depositFunds(user1).send(ctx.sendParam(user1)), "DEPOSIT_NOT_OPEN")
})
});
describe("Withdraw Funds", () => {
it("successfully withdraw funds", async () => {
await ctx.FundToken.methods.mint(user1, decimalStr("10000")).send(ctx.sendParam(user1));
await ctx.FundToken.methods.transfer(ctx.FairFunding.options.address, 3).send(ctx.sendParam(user1));
await logGas(ctx.FairFunding.methods.depositFunds(user1), ctx.sendParam(user1), "depositFunds");
var tx = await logGas(ctx.FairFunding.methods.withdrawFunds(user1, 3), ctx.sendParam(user1), "withdrawFunds");
var to = tx.events['WithdrawFund'].returnValues['to'];
var fundAmount = tx.events['WithdrawFund'].returnValues['fundAmount'];
assert.equal(to, user1);
assert.equal(fundAmount, 3);
})
it("revert if withdraw too much", async () => {
await ctx.FundToken.methods.mint(user1, decimalStr("10000")).send(ctx.sendParam(user1));
await ctx.FundToken.methods.transfer(ctx.FairFunding.options.address, 3).send(ctx.sendParam(user1));
await logGas(ctx.FairFunding.methods.depositFunds(user1), ctx.sendParam(user1), "depositFunds");
await truffleAssert.reverts(ctx.FairFunding.methods.withdrawFunds(user1, 4).send(ctx.sendParam(user1)), "WITHDRAW_TOO_MUCH")
})
});
describe("Claim Token", () => {
it("successfully claim token", async () => {
await ctx.FundToken.methods.mint(user1, decimalStr("10000")).send(ctx.sendParam(user1));
await ctx.FundToken.methods.transfer(ctx.FairFunding.options.address, 3).send(ctx.sendParam(user1));
await logGas(ctx.FairFunding.methods.depositFunds(user1), ctx.sendParam(user1), "depositFunds");
await ctx.EVM.increaseTime(86400 * 2 + 1)
await logGas(ctx.FairFunding.methods.settle(), ctx.sendParam(ctx.Deployer), "settle")
var tx = await logGas(ctx.FairFunding.methods.claimToken(user1), ctx.sendParam(user1), "claimToken");
var to = tx.events['ClaimToken'].returnValues['to'];
var tokenAmount = tx.events['ClaimToken'].returnValues['tokenAmount'];
assert.equal(to, user1);
assert.equal(tokenAmount, 3);
})
it("revert if not settled", async () => {
await ctx.FundToken.methods.mint(user1, decimalStr("10000")).send(ctx.sendParam(user1));
await ctx.FundToken.methods.transfer(ctx.FairFunding.options.address, 3).send(ctx.sendParam(user1));
await logGas(ctx.FairFunding.methods.depositFunds(user1), ctx.sendParam(user1), "depositFunds");
await truffleAssert.reverts(ctx.FairFunding.methods.claimToken(user1).send(ctx.sendParam(user1)), "NOT_SETTLED")
})
});
describe("Integration", () => {
it("case1: user1 deposit 8000, user2 deposit 8000", async () => {
await ctx.FundToken.methods.mint(user1, decimalStr("8000")).send(ctx.sendParam(user1));
await ctx.FundToken.methods.transfer(ctx.FairFunding.options.address, decimalStr("8000")).send(ctx.sendParam(user1));
await logGas(ctx.FairFunding.methods.depositFunds(user1), ctx.sendParam(user1), "depositFunds");
await ctx.FundToken.methods.mint(user2, decimalStr("8000")).send(ctx.sendParam(user2));
await ctx.FundToken.methods.transfer(ctx.FairFunding.options.address, decimalStr("8000")).send(ctx.sendParam(user2));
await logGas(ctx.FairFunding.methods.depositFunds(user2), ctx.sendParam(user2), "depositFunds");
await ctx.EVM.increaseTime(86400 * 2 + 1)
await logGas(ctx.FairFunding.methods.settle(), ctx.sendParam(ctx.Deployer), "settle")
var tx = await logGas(ctx.FairFunding.methods.claimToken(user1), ctx.sendParam(user1), "claimToken");
var to = tx.events['ClaimToken'].returnValues['to'];
var tokenAmount = tx.events['ClaimToken'].returnValues['tokenAmount'];
assert.equal(to, user1);
assert.equal(tokenAmount, decimalStr("5000"));
assert.equal(await ctx.SellToken.methods.balanceOf(user1).call(), decimalStr("5000"));
var tx = await logGas(ctx.FairFunding.methods.claimToken(user2), ctx.sendParam(user2), "claimToken");
var to = tx.events['ClaimToken'].returnValues['to'];
var tokenAmount = tx.events['ClaimToken'].returnValues['tokenAmount'];
assert.equal(to, user2);
assert.equal(tokenAmount, decimalStr("5000"));
assert.equal(await ctx.SellToken.methods.balanceOf(user2).call(), decimalStr("5000"));
})
it("case2: user1 deposit 2000, user2 deposit 8000", async () => {
await ctx.FundToken.methods.mint(user1, decimalStr("2000")).send(ctx.sendParam(user1));
await ctx.FundToken.methods.transfer(ctx.FairFunding.options.address, decimalStr("2000")).send(ctx.sendParam(user1));
await logGas(ctx.FairFunding.methods.depositFunds(user1), ctx.sendParam(user1), "depositFunds");
await ctx.FundToken.methods.mint(user2, decimalStr("8000")).send(ctx.sendParam(user2));
await ctx.FundToken.methods.transfer(ctx.FairFunding.options.address, decimalStr("8000")).send(ctx.sendParam(user2));
await logGas(ctx.FairFunding.methods.depositFunds(user2), ctx.sendParam(user2), "depositFunds");
await ctx.EVM.increaseTime(86400 * 2 + 1)
await logGas(ctx.FairFunding.methods.settle(), ctx.sendParam(ctx.Deployer), "settle")
var tx = await logGas(ctx.FairFunding.methods.claimToken(user1), ctx.sendParam(user1), "claimToken");
var to = tx.events['ClaimToken'].returnValues['to'];
var tokenAmount = tx.events['ClaimToken'].returnValues['tokenAmount'];
assert.equal(to, user1);
assert.equal(tokenAmount, decimalStr("2000"));
assert.equal(await ctx.SellToken.methods.balanceOf(user1).call(), decimalStr("2000"));
var tx = await logGas(ctx.FairFunding.methods.claimToken(user2), ctx.sendParam(user2), "claimToken");
var to = tx.events['ClaimToken'].returnValues['to'];
var tokenAmount = tx.events['ClaimToken'].returnValues['tokenAmount'];
assert.equal(to, user2);
assert.equal(tokenAmount, decimalStr("8000"));
assert.equal(await ctx.SellToken.methods.balanceOf(user2).call(), decimalStr("8000"));
})
it("case3: user1 deposit 20, user2 deposit 80", async () => {
await ctx.FundToken.methods.mint(user1, decimalStr("20")).send(ctx.sendParam(user1));
await ctx.FundToken.methods.transfer(ctx.FairFunding.options.address, decimalStr("20")).send(ctx.sendParam(user1));
await logGas(ctx.FairFunding.methods.depositFunds(user1), ctx.sendParam(user1), "depositFunds");
await ctx.FundToken.methods.mint(user2, decimalStr("80")).send(ctx.sendParam(user2));
await ctx.FundToken.methods.transfer(ctx.FairFunding.options.address, decimalStr("80")).send(ctx.sendParam(user2));
await logGas(ctx.FairFunding.methods.depositFunds(user2), ctx.sendParam(user2), "depositFunds");
await ctx.EVM.increaseTime(86400 * 2 + 1)
await logGas(ctx.FairFunding.methods.settle(), ctx.sendParam(ctx.Deployer), "settle")
var tx = await logGas(ctx.FairFunding.methods.claimToken(user1), ctx.sendParam(user1), "claimToken");
var to = tx.events['ClaimToken'].returnValues['to'];
var tokenAmount = tx.events['ClaimToken'].returnValues['tokenAmount'];
assert.equal(to, user1);
assert.equal(tokenAmount, decimalStr("20"));
assert.equal(await ctx.SellToken.methods.balanceOf(user1).call(), decimalStr("20"));
var tx = await logGas(ctx.FairFunding.methods.claimToken(user2), ctx.sendParam(user2), "claimToken");
var to = tx.events['ClaimToken'].returnValues['to'];
var tokenAmount = tx.events['ClaimToken'].returnValues['tokenAmount'];
assert.equal(to, user2);
assert.equal(tokenAmount, decimalStr("80"));
assert.equal(await ctx.SellToken.methods.balanceOf(user2).call(), decimalStr("80"));
})
});
});

View File

@@ -0,0 +1,158 @@
/*
Copyright 2021 DODO ZOO.
SPDX-License-Identifier: Apache-2.0
*/
// import * as assert from 'assert';
import { decimalStr, MAX_UINT256 } from '../utils/Converter';
import { logGas } from '../utils/Log';
import { DODOStarterContext, DODOStarterContextInitConfig} from '../utils/DODOStarterContext';
import { assert } from 'chai';
import * as contracts from '../utils/Contracts';
import BigNumber from 'bignumber.js';
import { StringLiteralLike } from 'typescript';
const truffleAssert = require('truffle-assertions');
let maker: string;
let user1: string;
let user2: string;
let sellTokenAddress: string;
let fundTokenAddress: string;
let config: DODOStarterContextInitConfig = {
// time config
bidDuration: new BigNumber(86400),
calmDuration: new BigNumber(86400),
tokenVestingDuration: new BigNumber(86400),
fundVestingDuration: new BigNumber(86400),
lpVestingDuration: new BigNumber(86400),
// value config
lowerPrice: decimalStr("1"),
upperPrice: decimalStr("5"),
tokenCliffRate: decimalStr("1"),
fundCliffRate: decimalStr("1"),
lpCliffRate: decimalStr("1"),
initialLiquidity: decimalStr("1"),
}
async function init(ctx: DODOStarterContext): Promise<void> {
maker = ctx.SpareAccounts[0];
user1 = ctx.SpareAccounts[1];
user2 = ctx.SpareAccounts[2];
sellTokenAddress = ctx.SellToken.options.address;
fundTokenAddress = ctx.FundToken.options.address;
}
describe("InstantFunding", () => {
let snapshotId: string;
let ctx: DODOStarterContext;
before(async () => {
ctx = new DODOStarterContext();
await ctx.init(config);
await init(ctx);
});
beforeEach(async () => {
snapshotId = await ctx.EVM.snapshot();
});
afterEach(async () => {
await ctx.EVM.reset(snapshotId);
});
describe("Basic Info", () => {
it("get the correct start price", async () => {
assert.equal(await ctx.InstantFunding.methods._START_PRICE_().call(), decimalStr("10"));
});
it("get the correct end price", async () => {
assert.equal(await ctx.InstantFunding.methods._END_PRICE_().call(), decimalStr("1"));
});
it("check if deposit is open", async () => {
assert.equal(await ctx.InstantFunding.methods.isDepositOpen().call(), true)
await ctx.EVM.increaseTime(86400 + 1)
assert.equal(await ctx.InstantFunding.methods.isDepositOpen().call(), false)
});
it("check if funding is end", async () => {
assert.equal(await ctx.InstantFunding.methods.isFundingEnd().call(), false)
await ctx.EVM.increaseTime(86400 + 1)
assert.equal(await ctx.InstantFunding.methods.isFundingEnd().call(), true)
});
});
describe("Deposit Funds", () => {
it("successfully deposit funds", async () => {
await ctx.FundToken.methods.mint(user1, decimalStr("10000")).send(ctx.sendParam(user1));
await ctx.FundToken.methods.transfer(ctx.InstantFunding.options.address, decimalStr("3")).send(ctx.sendParam(user1));
var tx = await logGas(ctx.InstantFunding.methods.depositFunds(user1), ctx.sendParam(user1), "depositFunds");
var account = tx.events['DepositFund'].returnValues['account'];
var fundAmount = tx.events['DepositFund'].returnValues['fundAmount'];
var allocationAmount = tx.events['DepositFund'].returnValues['allocationAmount'];
let currentPrice = await ctx.InstantFunding.methods.getCurrentPrice().call();
assert.equal(account, user1);
assert.equal(fundAmount, decimalStr("3"));
assert.equal(allocationAmount, decimalStr(new BigNumber(decimalStr("3")).div(currentPrice).toString()))
})
it("revert if the deposit is not open", async () => {
await ctx.FundToken.methods.mint(user1, decimalStr("10000")).send(ctx.sendParam(user1));
await ctx.FundToken.methods.transfer(ctx.InstantFunding.options.address, 3).send(ctx.sendParam(user1));
await ctx.EVM.increaseTime(86400);
await truffleAssert.reverts(ctx.InstantFunding.methods.depositFunds(user1).send(ctx.sendParam(user1)), "DEPOSIT_NOT_OPEN")
})
});
describe("Claim Token", () => {
it("successfully claim token", async () => {
await ctx.FundToken.methods.mint(user1, decimalStr("10000")).send(ctx.sendParam(user1));
await ctx.FundToken.methods.transfer(ctx.InstantFunding.options.address, decimalStr("3")).send(ctx.sendParam(user1));
await logGas(ctx.InstantFunding.methods.depositFunds(user1), ctx.sendParam(user1), "depositFunds");
let currentPrice = await ctx.InstantFunding.methods.getCurrentPrice().call();
await ctx.EVM.increaseTime(86400 * 2)
var tx = await logGas(ctx.InstantFunding.methods.claimToken(user1), ctx.sendParam(user1), "claimToken");
var to = tx.events['ClaimToken'].returnValues['to'];
var tokenAmount = tx.events['ClaimToken'].returnValues['tokenAmount'];
assert.equal(to, user1);
assert.equal(tokenAmount, decimalStr(new BigNumber(decimalStr("3")).div(currentPrice).toString()));
})
});
describe("Integration", () => {
it("user1 deposit 8000, user2 deposit 5000", async () => {
await ctx.FundToken.methods.mint(user1, decimalStr("8000")).send(ctx.sendParam(user1));
await ctx.FundToken.methods.transfer(ctx.InstantFunding.options.address, decimalStr("8000")).send(ctx.sendParam(user1));
await logGas(ctx.InstantFunding.methods.depositFunds(user1), ctx.sendParam(user1), "depositFunds");
let currentPrice1 = await ctx.InstantFunding.methods.getCurrentPrice().call();
await ctx.FundToken.methods.mint(user2, decimalStr("5000")).send(ctx.sendParam(user2));
await ctx.FundToken.methods.transfer(ctx.InstantFunding.options.address, decimalStr("5000")).send(ctx.sendParam(user2));
await logGas(ctx.InstantFunding.methods.depositFunds(user2), ctx.sendParam(user2), "depositFunds");
let currentPrice2 = await ctx.InstantFunding.methods.getCurrentPrice().call();
await ctx.EVM.increaseTime(86400 * 2)
var tx = await logGas(ctx.InstantFunding.methods.claimToken(user1), ctx.sendParam(user1), "claimToken");
var to = tx.events['ClaimToken'].returnValues['to'];
var tokenAmount = tx.events['ClaimToken'].returnValues['tokenAmount'];
let expectTokenAmount1 = decimalStr(new BigNumber(decimalStr("8000")).div(currentPrice1).toString())
assert.equal(to, user1);
assert.equal(tokenAmount, expectTokenAmount1);
assert.equal(await ctx.SellToken.methods.balanceOf(user1).call(), expectTokenAmount1);
var tx = await logGas(ctx.InstantFunding.methods.claimToken(user2), ctx.sendParam(user2), "claimToken");
var to = tx.events['ClaimToken'].returnValues['to'];
var tokenAmount = tx.events['ClaimToken'].returnValues['tokenAmount'];
let expectTokenAmount2 = decimalStr(new BigNumber(decimalStr("5000")).div(currentPrice1).toString())
assert.equal(to, user2);
assert.equal(tokenAmount, expectTokenAmount2);
assert.equal(await ctx.SellToken.methods.balanceOf(user2).call(), expectTokenAmount2);
})
});
});

View File

@@ -19,6 +19,21 @@ BigNumber.config({
DECIMAL_PLACES: 80,
});
export interface DODOStarterContextInitConfig {
// time config
bidDuration: BigNumber;
calmDuration: BigNumber;
tokenVestingDuration: BigNumber;
fundVestingDuration: BigNumber;
lpVestingDuration: BigNumber;
// value config
lowerPrice: string;
upperPrice: string;
tokenCliffRate: string;
fundCliffRate: string;
lpCliffRate: string;
initialLiquidity: string;
}
export class DODOStarterContext {
EVM: EVM;
@@ -26,6 +41,8 @@ export class DODOStarterContext {
//contract
DODOStarterFactory: Contract;
FairFunding: Contract;
InstantFunding: Contract;
//account
Deployer: string;
@@ -36,8 +53,7 @@ export class DODOStarterContext {
SellToken: Contract;
FundToken: Contract;
async init() {
async init(config: DODOStarterContextInitConfig) {
this.EVM = new EVM();
this.Web3 = getDefaultWeb3();
@@ -77,6 +93,99 @@ export class DODOStarterContext {
)
await this.DODOStarterFactory.methods.initOwner(this.Deployer).send(this.sendParam(this.Deployer));
await this.SellToken.methods.mint(this.Deployer, decimalStr("10000")).send(this.sendParam(this.Deployer));
await this.SellToken.methods.approve(this.DODOStarterFactory.options.address, decimalStr("10000")).send(this.sendParam(this.Deployer));
let starttime = (await this.Web3.eth.getBlock(await this.Web3.eth.getBlockNumber())).timestamp;
await this.DODOStarterFactory.methods.createFairFund(
[
this.Deployer,
this.SellToken.options.address,
this.FundToken.options.address,
"0x0000000000000000000000000000000000000000",
"0x0000000000000000000000000000000000000000",
],
[
starttime,
config.bidDuration,
config.calmDuration,
new BigNumber(starttime).plus(config.bidDuration).plus(config.calmDuration).plus(1),
config.tokenVestingDuration,
new BigNumber(starttime).plus(config.bidDuration).plus(config.calmDuration).plus(1),
config.fundVestingDuration,
new BigNumber(starttime).plus(config.bidDuration).plus(config.calmDuration).plus(1),
config.lpVestingDuration,
],
[
config.lowerPrice,
config.upperPrice,
config.tokenCliffRate,
config.fundCliffRate,
config.lpCliffRate,
config.initialLiquidity,
],
decimalStr("10000"),
true,
).send(this.sendParam(this.Deployer, "0.2"))
let fairPools = await this.DODOStarterFactory.methods.getFairFundPools(
this.SellToken.options.address,
this.FundToken.options.address
).call();
console.log(`fair fund pools: ${JSON.stringify(fairPools)}`)
let fairPool = fairPools.slice(-1)[0];
this.FairFunding = await contracts.getContractWithAddress(contracts.FAIR_FUNDING, fairPool);
console.log('start createing instant fund......')
await this.SellToken.methods.mint(this.Deployer, decimalStr("10000")).send(this.sendParam(this.Deployer));
await this.SellToken.methods.approve(this.DODOStarterFactory.options.address, decimalStr("10000")).send(this.sendParam(this.Deployer));
let starttime2 = (await this.Web3.eth.getBlock(await this.Web3.eth.getBlockNumber())).timestamp;
await this.DODOStarterFactory.methods.createInstantFund(
[
this.Deployer,
this.SellToken.options.address,
this.FundToken.options.address,
"0x0000000000000000000000000000000000000000",
"0x0000000000000000000000000000000000000000",
],
[
starttime2,
config.bidDuration,
new BigNumber(starttime2).plus(config.bidDuration).plus(config.calmDuration).plus(1),
config.tokenVestingDuration,
new BigNumber(starttime2).plus(config.bidDuration).plus(config.calmDuration).plus(1),
config.fundVestingDuration,
new BigNumber(starttime2).plus(config.bidDuration).plus(config.calmDuration).plus(1),
config.lpVestingDuration,
],
[
decimalStr("10"),
decimalStr("1"),
config.tokenCliffRate,
config.fundCliffRate,
config.lpCliffRate,
config.initialLiquidity,
],
decimalStr("10000"),
).send(this.sendParam(this.Deployer))
console.log(`finish creating instant pools`)
let instantPools = await this.DODOStarterFactory.methods.getInstantFundPools(
this.SellToken.options.address,
this.FundToken.options.address
).call();
console.log(`instant fund pools: ${JSON.stringify(instantPools)}`)
let instantPool = instantPools.slice(-1)[0];
this.InstantFunding = await contracts.getContractWithAddress(contracts.INSTANT_FUNDING, instantPool);
console.log(log.blueText("[Init DODOStarter context]"));
}
@@ -99,10 +208,4 @@ export class DODOStarterContext {
.approve(target, MAX_UINT256)
.send(this.sendParam(account));
}
}
export async function getDODOStarterContext(): Promise<DODOStarterContext> {
var context = new DODOStarterContext();
await context.init();
return context;
}