dvm proxy test ing
This commit is contained in:
@@ -7,7 +7,7 @@
|
||||
|
||||
// import * as assert from 'assert';
|
||||
import BigNumber from "bignumber.js";
|
||||
import { decimalStr, mweiStr} from '../utils/Converter';
|
||||
import { decimalStr, mweiStr } from '../utils/Converter';
|
||||
import { logGas } from '../utils/Log';
|
||||
import { ProxyContext, getProxyContext } from '../utils/ProxyContext';
|
||||
import { assert } from 'chai';
|
||||
@@ -30,12 +30,11 @@ async function init(ctx: ProxyContext): Promise<void> {
|
||||
project = ctx.SpareAccounts[1];
|
||||
trader = ctx.SpareAccounts[2];
|
||||
|
||||
await ctx.mintTestToken(lp, ctx.DODO, decimalStr("100000"));
|
||||
await ctx.mintTestToken(project, ctx.DODO, decimalStr("100000"));
|
||||
await ctx.mintTestToken(trader, ctx.DODO, decimalStr("100000"));
|
||||
await ctx.mintTestToken(lp, ctx.DODO, decimalStr("1000000"));
|
||||
await ctx.mintTestToken(project, ctx.DODO, decimalStr("1000000"));
|
||||
|
||||
await ctx.mintTestToken(lp, ctx.USDT, mweiStr("100000"));
|
||||
await ctx.mintTestToken(project, ctx.USDT, mweiStr("100000"));
|
||||
await ctx.mintTestToken(lp, ctx.USDT, mweiStr("1000000"));
|
||||
await ctx.mintTestToken(project, ctx.USDT, mweiStr("1000000"));
|
||||
|
||||
// await ctx.WETH.methods.deposit().send(ctx.sendParam(lp, '80'));
|
||||
// await ctx.WETH.methods.deposit().send(ctx.sendParam(project, '80'));
|
||||
@@ -46,7 +45,7 @@ async function init(ctx: ProxyContext): Promise<void> {
|
||||
}
|
||||
|
||||
|
||||
async function initCreateDPP(ctx: ProxyContext, token0: string, token1:string, token0Amount: string, token1Amount: string, ethValue:string): Promise<string> {
|
||||
async function initCreateDPP(ctx: ProxyContext, token0: string, token1:string, token0Amount: string, token1Amount: string, ethValue:string,i:string): Promise<string> {
|
||||
let PROXY = ctx.DODOProxy;
|
||||
await PROXY.methods.createDODOPrivatePool(
|
||||
token0,
|
||||
@@ -55,7 +54,7 @@ async function initCreateDPP(ctx: ProxyContext, token0: string, token1:string, t
|
||||
token1Amount,
|
||||
config.lpFeeRate,
|
||||
config.mtFeeRate,
|
||||
config.i,
|
||||
i,
|
||||
config.k,
|
||||
Math.floor(new Date().getTime()/1000 + 60 * 10)
|
||||
).send(ctx.sendParam(project,ethValue));
|
||||
@@ -76,9 +75,9 @@ describe("DODOProxyV2.0", () => {
|
||||
before(async () => {
|
||||
ctx = await getProxyContext();
|
||||
await init(ctx);
|
||||
dpp_DODO_USDT = await initCreateDPP(ctx,ctx.DODO.options.address,ctx.USDT.options.address,decimalStr("10000"),mweiStr("10000"), "0");
|
||||
dpp_DODO_USDT = await initCreateDPP(ctx,ctx.DODO.options.address,ctx.USDT.options.address,decimalStr("100000"),mweiStr("30000"), "0",mweiStr("0.3"));
|
||||
DPP_DODO_USDT = contracts.getContractWithAddress(contracts.DPP_NAME,dpp_DODO_USDT);
|
||||
dpp_WETH_USDT = await initCreateDPP(ctx,'0x000000000000000000000000000000000000000E',ctx.USDT.options.address,decimalStr("5"),mweiStr("10000"),"5");
|
||||
dpp_WETH_USDT = await initCreateDPP(ctx,'0x000000000000000000000000000000000000000E',ctx.USDT.options.address,decimalStr("5"),mweiStr("30000"),"5",mweiStr("600"));
|
||||
DPP_WETH_USDT = contracts.getContractWithAddress(contracts.DPP_NAME,dpp_WETH_USDT);
|
||||
console.log("dpp_DODO_USDT:",dpp_DODO_USDT);
|
||||
console.log("dpp_WETH_USDT:",dpp_WETH_USDT);
|
||||
@@ -110,17 +109,17 @@ describe("DODOProxyV2.0", () => {
|
||||
Math.floor(new Date().getTime()/1000 + 60 * 10)
|
||||
),ctx.sendParam(project),"createDPP");
|
||||
var addrs = await ctx.DPPFactory.methods.getPrivatePool(baseToken,quoteToken).call();
|
||||
var dppInfo = await ctx.DPPFactory.methods._DPP_INFO_(addrs[0]).call();
|
||||
var dppInfo = await ctx.DPPFactory.methods._DPP_INFO_(addrs[1]).call();
|
||||
assert.equal(
|
||||
dppInfo[0],
|
||||
project
|
||||
);
|
||||
assert.equal(
|
||||
await ctx.DODO.methods.balanceOf(addrs[0]).call(),
|
||||
await ctx.DODO.methods.balanceOf(addrs[1]).call(),
|
||||
baseAmount
|
||||
);
|
||||
assert.equal(
|
||||
await ctx.USDT.methods.balanceOf(addrs[0]).call(),
|
||||
await ctx.USDT.methods.balanceOf(addrs[1]).call(),
|
||||
quoteAmount
|
||||
);
|
||||
});
|
||||
@@ -143,17 +142,17 @@ describe("DODOProxyV2.0", () => {
|
||||
Math.floor(new Date().getTime()/1000 + 60 * 10)
|
||||
),ctx.sendParam(project, "5"),"createDPP - Wrap ETH");
|
||||
var addrs = await ctx.DPPFactory.methods.getPrivatePool(ctx.WETH.options.address,quoteToken).call();
|
||||
var dppInfo = await ctx.DPPFactory.methods._DPP_INFO_(addrs[0]).call();
|
||||
var dppInfo = await ctx.DPPFactory.methods._DPP_INFO_(addrs[1]).call();
|
||||
assert.equal(
|
||||
dppInfo[0],
|
||||
project
|
||||
);
|
||||
assert.equal(
|
||||
await ctx.WETH.methods.balanceOf(addrs[0]).call(),
|
||||
await ctx.WETH.methods.balanceOf(addrs[1]).call(),
|
||||
baseAmount
|
||||
);
|
||||
assert.equal(
|
||||
await ctx.USDT.methods.balanceOf(addrs[0]).call(),
|
||||
await ctx.USDT.methods.balanceOf(addrs[1]).call(),
|
||||
quoteAmount
|
||||
);
|
||||
});
|
||||
@@ -161,13 +160,13 @@ describe("DODOProxyV2.0", () => {
|
||||
it("resetDPP", async () => {
|
||||
var beforeState = await DPP_DODO_USDT.methods.getPMMState().call();
|
||||
assert.equal(beforeState.K,config.k);
|
||||
assert.equal(beforeState.B0,decimalStr("10000"));
|
||||
assert.equal(beforeState.Q0,mweiStr("10000"));
|
||||
assert.equal(beforeState.B0,decimalStr("100000"));
|
||||
assert.equal(beforeState.Q0,mweiStr("30000"));
|
||||
await logGas(await ctx.DODOProxy.methods.resetDODOPrivatePool(
|
||||
dpp_DODO_USDT,
|
||||
config.lpFeeRate,
|
||||
config.mtFeeRate,
|
||||
config.i,
|
||||
mweiStr("0.3"),
|
||||
decimalStr("0.2"),
|
||||
decimalStr("1000"),
|
||||
mweiStr("1000"),
|
||||
@@ -177,21 +176,22 @@ describe("DODOProxyV2.0", () => {
|
||||
),ctx.sendParam(project),"resetDPP");
|
||||
var afterState = await DPP_DODO_USDT.methods.getPMMState().call();
|
||||
assert.equal(afterState.K,decimalStr("0.2"));
|
||||
assert.equal(afterState.B0,decimalStr("11000"));
|
||||
assert.equal(afterState.Q0,mweiStr("11000"));
|
||||
assert.equal(afterState.B0,decimalStr("101000"));
|
||||
assert.equal(afterState.Q0,mweiStr("31000"));
|
||||
});
|
||||
|
||||
|
||||
it("resetDPP - OutETH", async () => {
|
||||
var beforeState = await DPP_WETH_USDT.methods.getPMMState().call();
|
||||
assert.equal(beforeState.K,config.k);
|
||||
assert.equal(beforeState.B0,decimalStr("5"));
|
||||
assert.equal(beforeState.Q0,mweiStr("10000"));
|
||||
assert.equal(beforeState.Q0,mweiStr("30000"));
|
||||
var b_ETH = await ctx.Web3.eth.getBalance(project);
|
||||
var tx = await logGas(await ctx.DODOProxy.methods.resetDODOPrivatePoolETH(
|
||||
dpp_WETH_USDT,
|
||||
config.lpFeeRate,
|
||||
config.mtFeeRate,
|
||||
config.i,
|
||||
mweiStr("600"),
|
||||
decimalStr("0.2"),
|
||||
decimalStr("0"),
|
||||
mweiStr("1000"),
|
||||
@@ -199,16 +199,172 @@ describe("DODOProxyV2.0", () => {
|
||||
mweiStr("0"),
|
||||
3,
|
||||
Math.floor(new Date().getTime()/1000 + 60 * 10)
|
||||
),ctx.sendParam(project),"resetDPP-ETH");
|
||||
),ctx.sendParam(project),"resetDPP-OutETH");
|
||||
var afterState = await DPP_WETH_USDT.methods.getPMMState().call();
|
||||
assert.equal(afterState.K,decimalStr("0.2"));
|
||||
assert.equal(afterState.B0,decimalStr("4"));
|
||||
assert.equal(afterState.Q0,mweiStr("11000"));
|
||||
assert.equal(afterState.Q0,mweiStr("31000"));
|
||||
var a_ETH = await ctx.Web3.eth.getBalance(project);
|
||||
console.log("b_ETH:",b_ETH);
|
||||
console.log("a_ETH:",a_ETH);
|
||||
assert.equal(new BigNumber(a_ETH).isGreaterThan(new BigNumber(b_ETH)),true);
|
||||
assert.equal(new BigNumber(b_ETH).isGreaterThan(new BigNumber(a_ETH).minus(decimalStr("1"))),true);
|
||||
});
|
||||
|
||||
|
||||
it("resetDPP - InETH", async () => {
|
||||
var beforeState = await DPP_WETH_USDT.methods.getPMMState().call();
|
||||
assert.equal(beforeState.K,config.k);
|
||||
assert.equal(beforeState.B0,decimalStr("5"));
|
||||
assert.equal(beforeState.Q0,mweiStr("30000"));
|
||||
var b_ETH = await ctx.Web3.eth.getBalance(project);
|
||||
var tx = await logGas(await ctx.DODOProxy.methods.resetDODOPrivatePoolETH(
|
||||
dpp_WETH_USDT,
|
||||
config.lpFeeRate,
|
||||
config.mtFeeRate,
|
||||
mweiStr("600"),
|
||||
decimalStr("0.2"),
|
||||
decimalStr("1"),
|
||||
mweiStr("1000"),
|
||||
decimalStr("0"),
|
||||
mweiStr("0"),
|
||||
1,
|
||||
Math.floor(new Date().getTime()/1000 + 60 * 10)
|
||||
),ctx.sendParam(project,"1"),"resetDPP-InETH");
|
||||
var afterState = await DPP_WETH_USDT.methods.getPMMState().call();
|
||||
assert.equal(afterState.K,decimalStr("0.2"));
|
||||
assert.equal(afterState.B0,decimalStr("6"));
|
||||
assert.equal(afterState.Q0,mweiStr("31000"));
|
||||
var a_ETH = await ctx.Web3.eth.getBalance(project);
|
||||
console.log("b_ETH:",b_ETH);
|
||||
console.log("a_ETH:",a_ETH);
|
||||
assert.equal(new BigNumber(b_ETH).isGreaterThan(new BigNumber(a_ETH).plus(decimalStr("1"))),true);
|
||||
});
|
||||
|
||||
it("swap - one hop", async () => {
|
||||
await ctx.mintTestToken(trader, ctx.DODO, decimalStr("1000"));
|
||||
var b_DOOD = await ctx.DODO.methods.balanceOf(trader).call();
|
||||
var b_USDT = await ctx.USDT.methods.balanceOf(trader).call();
|
||||
var dodoPairs = [
|
||||
dpp_DODO_USDT
|
||||
]
|
||||
var directions = [
|
||||
0
|
||||
]
|
||||
var tx = await logGas(await ctx.DODOProxy.methods.dodoSwapTokenToToken(
|
||||
trader,
|
||||
ctx.DODO.options.address,
|
||||
ctx.USDT.options.address,
|
||||
decimalStr("500"),
|
||||
1,
|
||||
dodoPairs,
|
||||
directions,
|
||||
Math.floor(new Date().getTime()/1000 + 60 * 10)
|
||||
),ctx.sendParam(trader),"swap - one hop");
|
||||
var a_DOOD = await ctx.DODO.methods.balanceOf(trader).call();
|
||||
var a_USDT = await ctx.USDT.methods.balanceOf(trader).call();
|
||||
console.log("b_DOOD:" + b_DOOD + " a_DODO:" + a_DOOD);
|
||||
console.log("b_USDT:" + b_USDT + " a_USDT:" + a_USDT);
|
||||
assert.equal(a_DOOD,decimalStr("500"));
|
||||
assert.equal(a_USDT,"149474924");
|
||||
});
|
||||
|
||||
|
||||
it("swap - two hop", async () => {
|
||||
await ctx.mintTestToken(trader, ctx.DODO, decimalStr("1000"));
|
||||
var b_DOOD = await ctx.DODO.methods.balanceOf(trader).call();
|
||||
var b_WETH = await ctx.WETH.methods.balanceOf(trader).call();
|
||||
var dodoPairs = [
|
||||
dpp_DODO_USDT,
|
||||
dpp_WETH_USDT
|
||||
]
|
||||
var directions = [
|
||||
0,
|
||||
1
|
||||
]
|
||||
var tx = await logGas(await ctx.DODOProxy.methods.dodoSwapTokenToToken(
|
||||
trader,
|
||||
ctx.DODO.options.address,
|
||||
ctx.WETH.options.address,
|
||||
decimalStr("500"),
|
||||
1,
|
||||
dodoPairs,
|
||||
directions,
|
||||
Math.floor(new Date().getTime()/1000 + 60 * 10)
|
||||
),ctx.sendParam(trader),"swap - two hop");
|
||||
var a_DOOD = await ctx.DODO.methods.balanceOf(trader).call();
|
||||
var a_WETH = await ctx.WETH.methods.balanceOf(trader).call();
|
||||
console.log("b_DOOD:" + b_DOOD + " a_DODO:" + a_DOOD);
|
||||
console.log("b_WETH:" + b_WETH + " a_WETH:" + a_WETH);
|
||||
assert.equal(a_DOOD,decimalStr("500"));
|
||||
assert.equal(a_WETH,"247088894507188480");
|
||||
});
|
||||
|
||||
it("swap - two hop - inETH", async () => {
|
||||
var b_DOOD = await ctx.DODO.methods.balanceOf(trader).call();
|
||||
var b_WETH = await ctx.WETH.methods.balanceOf(trader).call();
|
||||
var b_ETH = await ctx.Web3.eth.getBalance(trader);
|
||||
var dodoPairs = [
|
||||
dpp_WETH_USDT,
|
||||
dpp_DODO_USDT
|
||||
]
|
||||
var directions = [
|
||||
0,
|
||||
1
|
||||
]
|
||||
var tx = await logGas(await ctx.DODOProxy.methods.dodoSwapETHToToken(
|
||||
trader,
|
||||
ctx.DODO.options.address,
|
||||
decimalStr("1"),
|
||||
1,
|
||||
dodoPairs,
|
||||
directions,
|
||||
Math.floor(new Date().getTime()/1000 + 60 * 10)
|
||||
),ctx.sendParam(trader,"1"),"swap - two hop - inETH");
|
||||
var a_DOOD = await ctx.DODO.methods.balanceOf(trader).call();
|
||||
var a_WETH = await ctx.WETH.methods.balanceOf(trader).call();
|
||||
var a_ETH = await ctx.Web3.eth.getBalance(trader);
|
||||
console.log("b_DOOD:" + b_DOOD + " a_DODO:" + a_DOOD);
|
||||
console.log("b_WETH:" + b_WETH + " a_WETH:" + a_WETH);
|
||||
console.log("b_ETH:" + b_ETH + " a_ETH:" + a_ETH);
|
||||
assert.equal(a_DOOD,"1979965731049456633086");
|
||||
});
|
||||
|
||||
|
||||
it("swap - two hop - outETH", async () => {
|
||||
await ctx.mintTestToken(trader, ctx.DODO, decimalStr("100000"));
|
||||
var b_DOOD = await ctx.DODO.methods.balanceOf(trader).call();
|
||||
var b_WETH = await ctx.WETH.methods.balanceOf(trader).call();
|
||||
var b_ETH = await ctx.Web3.eth.getBalance(trader);
|
||||
var dodoPairs = [
|
||||
dpp_DODO_USDT,
|
||||
dpp_WETH_USDT
|
||||
]
|
||||
var directions = [
|
||||
0,
|
||||
1
|
||||
]
|
||||
var tx = await logGas(await ctx.DODOProxy.methods.dodoSwapTokenToETH(
|
||||
trader,
|
||||
ctx.DODO.options.address,
|
||||
decimalStr("10000"),
|
||||
1,
|
||||
dodoPairs,
|
||||
directions,
|
||||
Math.floor(new Date().getTime()/1000 + 60 * 10)
|
||||
),ctx.sendParam(trader),"swap - two hop - outETH");
|
||||
var a_DOOD = await ctx.DODO.methods.balanceOf(trader).call();
|
||||
var a_WETH = await ctx.WETH.methods.balanceOf(trader).call();
|
||||
var a_ETH = await ctx.Web3.eth.getBalance(trader);
|
||||
console.log("b_DOOD:" + b_DOOD + " a_DODO:" + a_DOOD);
|
||||
console.log("b_WETH:" + b_WETH + " a_WETH:" + a_WETH);
|
||||
console.log("b_ETH:" + b_ETH + " a_ETH:" + a_ETH);
|
||||
assert.equal(a_DOOD,decimalStr("90000"));
|
||||
assert.equal(
|
||||
tx.events['OrderHistory'].returnValues['returnAmount'],
|
||||
"3760778358599649282"
|
||||
)
|
||||
});
|
||||
|
||||
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user