Merge branch 'feature/V2' of github.com:DODOEX/contractV2 into feature/V2
This commit is contained in:
@@ -8,7 +8,7 @@
|
||||
import * as assert from 'assert';
|
||||
import BigNumber from 'bignumber.js';
|
||||
import { DODOContext, getDODOContext } from '../utils-v1/Context-route';
|
||||
import { decimalStr,MAX_UINT256,fromWei,mweiStr} from '../utils-v1/Converter';
|
||||
import { decimalStr, MAX_UINT256, fromWei, mweiStr } from '../utils-v1/Converter';
|
||||
import { logGas } from '../utils-v1/Log';
|
||||
import { DODOHelper } from '../utils-v1/dodoHelper';
|
||||
|
||||
@@ -16,99 +16,104 @@ let lp: string;
|
||||
let trader: string;
|
||||
|
||||
async function initDODO_USDT(ctx: DODOContext): Promise<void> {
|
||||
await ctx.setOraclePrice(ctx.DODO_USDT_ORACLE,mweiStr("0.1"));
|
||||
await ctx.setOraclePrice(ctx.DODO_USDT_ORACLE, mweiStr("0.1"));
|
||||
lp = ctx.spareAccounts[0];
|
||||
trader = ctx.spareAccounts[1];
|
||||
|
||||
|
||||
let DODO = ctx.DODO;
|
||||
let USDT = ctx.USDT;
|
||||
let DODO_USDT = ctx.DODO_USDT;
|
||||
await ctx.approvePair(DODO,USDT,DODO_USDT.options.address,lp);
|
||||
await ctx.approvePair(DODO,USDT,DODO_USDT.options.address,trader);
|
||||
await ctx.approvePair(DODO, USDT, DODO_USDT.options.address, lp);
|
||||
await ctx.approvePair(DODO, USDT, DODO_USDT.options.address, trader);
|
||||
|
||||
await ctx.mintToken(DODO,USDT, lp, decimalStr("10000"), mweiStr("1000"));
|
||||
await ctx.mintToken(DODO,USDT,trader, decimalStr("100"), mweiStr("0"));
|
||||
await ctx.mintToken(DODO, USDT, lp, decimalStr("10000000"), mweiStr("1000000"));
|
||||
await ctx.mintToken(DODO, USDT, trader, decimalStr("1000"), mweiStr("0"));
|
||||
|
||||
await DODO_USDT.methods
|
||||
.depositBaseTo(lp, decimalStr("10000"))
|
||||
.depositBaseTo(lp, decimalStr("10000000"))
|
||||
.send(ctx.sendParam(lp));
|
||||
await DODO_USDT.methods
|
||||
.depositQuoteTo(lp, mweiStr("1000"))
|
||||
.depositQuoteTo(lp, mweiStr("1000000"))
|
||||
.send(ctx.sendParam(lp));
|
||||
}
|
||||
|
||||
async function initUSDT_USDC(ctx: DODOContext): Promise<void> {
|
||||
await ctx.setOraclePrice(ctx.USDT_USDC_ORACLE,decimalStr("1"));
|
||||
await ctx.setOraclePrice(ctx.USDT_USDC_ORACLE, decimalStr("1"));
|
||||
lp = ctx.spareAccounts[0];
|
||||
trader = ctx.spareAccounts[1];
|
||||
|
||||
|
||||
let USDT = ctx.USDT;
|
||||
let USDC = ctx.USDC;
|
||||
let USDT_USDC = ctx.USDT_USDC;
|
||||
|
||||
await ctx.approvePair(USDT,USDC,USDT_USDC.options.address,lp);
|
||||
await ctx.mintToken(USDT,USDC,lp, mweiStr("1000"), mweiStr("1000"));
|
||||
await ctx.approvePair(USDT, USDC, USDT_USDC.options.address, lp);
|
||||
await ctx.mintToken(USDT, USDC, lp, mweiStr("1000000"), mweiStr("1000000"));
|
||||
|
||||
await USDT_USDC.methods
|
||||
.depositBaseTo(lp, mweiStr("1000"))
|
||||
.depositBaseTo(lp, mweiStr("1000000"))
|
||||
.send(ctx.sendParam(lp));
|
||||
await USDT_USDC.methods
|
||||
.depositQuoteTo(lp, mweiStr("1000"))
|
||||
.depositQuoteTo(lp, mweiStr("1000000"))
|
||||
.send(ctx.sendParam(lp));
|
||||
}
|
||||
|
||||
|
||||
async function initWETH_USDC(ctx: DODOContext): Promise<void> {
|
||||
await ctx.setOraclePrice(ctx.WETH_USDC_ORACLE,mweiStr("450"));
|
||||
await ctx.setOraclePrice(ctx.WETH_USDC_ORACLE, mweiStr("450"));
|
||||
lp = ctx.spareAccounts[0];
|
||||
trader = ctx.spareAccounts[1];
|
||||
|
||||
|
||||
let WETH = ctx.WETH;
|
||||
let USDC = ctx.USDC;
|
||||
let WETH_USDC = ctx.WETH_USDC;
|
||||
|
||||
await ctx.approvePair(WETH,USDC,WETH_USDC.options.address,lp);
|
||||
await ctx.mintToken(WETH,USDC,lp, decimalStr("1000"), mweiStr("450000"));
|
||||
await ctx.approvePair(WETH, USDC, WETH_USDC.options.address, lp);
|
||||
await ctx.mintToken(null, USDC, lp, decimalStr("0"), mweiStr("36000"));
|
||||
await WETH.methods.deposit().send(ctx.sendParam(lp, '80'));
|
||||
|
||||
await WETH_USDC.methods
|
||||
.depositBaseTo(lp, decimalStr("1000"))
|
||||
.depositBaseTo(lp, decimalStr("80"))
|
||||
.send(ctx.sendParam(lp));
|
||||
await WETH_USDC.methods
|
||||
.depositQuoteTo(lp, mweiStr("450000"))
|
||||
.depositQuoteTo(lp, mweiStr("36000"))
|
||||
.send(ctx.sendParam(lp));
|
||||
}
|
||||
|
||||
//mock sdk logic
|
||||
async function calcRoute(ctx: DODOContext,fromTokenAmount:string,slippage:number,routes:any[],pairs:any[]) {
|
||||
async function calcRoute(ctx: DODOContext, fromTokenAmount: string, slippage: number, routes: any[], pairs: any[]) {
|
||||
let swapAmount = fromTokenAmount
|
||||
let directions:number[] = []
|
||||
let dodoPairs:string[] = []
|
||||
let directions: number[] = []
|
||||
let dodoPairs: string[] = []
|
||||
|
||||
|
||||
for (let i = 0; i < pairs.length; i++) {
|
||||
let curPair = pairs[i]
|
||||
dodoPairs.push(curPair.pair)
|
||||
let curContact = pairs[i].pairContract
|
||||
if (curPair.base === routes[i].address) {
|
||||
if (routes[i].address == '0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE') {
|
||||
directions[i] = 0;
|
||||
swapAmount = await curContact.methods.querySellBaseToken(swapAmount).call();
|
||||
console.log(i + "-swapAmount:",swapAmount);
|
||||
console.log(i + "-swapAmount:", swapAmount);
|
||||
} else if (curPair.base === routes[i].address) {
|
||||
directions[i] = 0;
|
||||
swapAmount = await curContact.methods.querySellBaseToken(swapAmount).call();
|
||||
console.log(i + "-swapAmount:", swapAmount);
|
||||
} else {
|
||||
directions[i] = 1;
|
||||
swapAmount = await ctx.DODOSellHelper.methods.querySellQuoteToken(curPair.pair,swapAmount).call();
|
||||
console.log(i + "-swapAmount:",swapAmount);
|
||||
swapAmount = await ctx.DODOSellHelper.methods.querySellQuoteToken(curPair.pair, swapAmount).call();
|
||||
console.log(i + "-swapAmount:", swapAmount);
|
||||
}
|
||||
}
|
||||
|
||||
let toAmount = new BigNumber(swapAmount).multipliedBy(1-slippage).toFixed(0, BigNumber.ROUND_DOWN)
|
||||
|
||||
console.log("minAmount:",toAmount);
|
||||
let toAmount = new BigNumber(swapAmount).multipliedBy(1 - slippage).toFixed(0, BigNumber.ROUND_DOWN)
|
||||
|
||||
console.log("minAmount:", toAmount);
|
||||
// console.log("dodoPairs",dodoPairs);
|
||||
// console.log("directions",directions);
|
||||
|
||||
return ctx.SmartSwap.methods.dodoSwap(
|
||||
routes[0].address,
|
||||
routes[routes.length-1].address,
|
||||
routes[routes.length - 1].address,
|
||||
fromTokenAmount,
|
||||
toAmount,
|
||||
dodoPairs,
|
||||
@@ -139,9 +144,9 @@ describe("Trader", () => {
|
||||
it("DODO to USDT directly swap", async () => {
|
||||
var b_DODO = await ctx.DODO.methods.balanceOf(trader).call()
|
||||
var b_USDT = await ctx.USDT.methods.balanceOf(trader).call()
|
||||
console.log("Before DODO:" + fromWei(b_DODO,'ether') + "; USDT:" + fromWei(b_USDT,'mwei'));
|
||||
console.log("Before DODO:" + fromWei(b_DODO, 'ether') + "; USDT:" + fromWei(b_USDT, 'mwei'));
|
||||
//approve DODO entry
|
||||
await ctx.DODO.methods.approve(ctx.SmartApprove.options.address,MAX_UINT256).send(ctx.sendParam(trader))
|
||||
await ctx.DODO.methods.approve(ctx.SmartApprove.options.address, MAX_UINT256).send(ctx.sendParam(trader))
|
||||
//set route path
|
||||
var routes = [{
|
||||
address: ctx.DODO.options.address,
|
||||
@@ -155,37 +160,35 @@ describe("Trader", () => {
|
||||
var pairs = [{
|
||||
pair: ctx.DODO_USDT.options.address,
|
||||
base: ctx.DODO.options.address,
|
||||
/*only for test*/
|
||||
pairContract: ctx.DODO_USDT
|
||||
/**************/
|
||||
}];
|
||||
|
||||
var tx = await logGas(await calcRoute(ctx,decimalStr('10'),0.1,routes,pairs), ctx.sendParam(trader), "directly swap")
|
||||
var tx = await logGas(await calcRoute(ctx, decimalStr('10'), 0.1, routes, pairs), ctx.sendParam(trader), "directly swap")
|
||||
// console.log(tx.events['OrderHistory']);
|
||||
var a_DODO = await ctx.DODO.methods.balanceOf(trader).call()
|
||||
var a_USDT = await ctx.USDT.methods.balanceOf(trader).call()
|
||||
console.log("After DODO:" + fromWei(a_DODO,'ether') + "; USDT:" + fromWei(a_USDT,'mwei'));
|
||||
console.log("After DODO:" + fromWei(a_DODO, 'ether') + "; USDT:" + fromWei(a_USDT, 'mwei'));
|
||||
console.log("===============================================")
|
||||
var c_DODO = await ctx.DODO.methods.balanceOf(ctx.SmartSwap.options.address).call()
|
||||
var c_USDT = await ctx.USDT.methods.balanceOf(ctx.SmartSwap.options.address).call()
|
||||
console.log("Contract DODO:" + fromWei(c_DODO,'ether') + "; USDT:" + fromWei(c_USDT,'mwei'));
|
||||
console.log("Contract DODO:" + fromWei(c_DODO, 'ether') + "; USDT:" + fromWei(c_USDT, 'mwei'));
|
||||
});
|
||||
|
||||
|
||||
it("DODO to USDC two hops swap", async () => {
|
||||
var b_DODO = await ctx.DODO.methods.balanceOf(trader).call()
|
||||
var b_USDC = await ctx.USDC.methods.balanceOf(trader).call()
|
||||
console.log("Before DODO:" + fromWei(b_DODO,'ether') + "; USDC:" + fromWei(b_USDC,'mwei'));
|
||||
console.log("Before DODO:" + fromWei(b_DODO, 'ether') + "; USDC:" + fromWei(b_USDC, 'mwei'));
|
||||
//approve DODO entry
|
||||
await ctx.DODO.methods.approve(ctx.SmartApprove.options.address,MAX_UINT256).send(ctx.sendParam(trader))
|
||||
await ctx.DODO.methods.approve(ctx.SmartApprove.options.address, MAX_UINT256).send(ctx.sendParam(trader))
|
||||
//set route path
|
||||
var routes = [{
|
||||
address: ctx.DODO.options.address,
|
||||
decimals: 18
|
||||
},{
|
||||
}, {
|
||||
address: ctx.USDT.options.address,
|
||||
decimals: 6
|
||||
},{
|
||||
}, {
|
||||
address: ctx.USDC.options.address,
|
||||
decimals: 6
|
||||
}];
|
||||
@@ -193,46 +196,42 @@ describe("Trader", () => {
|
||||
var pairs = [{
|
||||
pair: ctx.DODO_USDT.options.address,
|
||||
base: ctx.DODO.options.address,
|
||||
/*only for test*/
|
||||
pairContract: ctx.DODO_USDT
|
||||
/**************/
|
||||
},{
|
||||
}, {
|
||||
pair: ctx.USDT_USDC.options.address,
|
||||
base: ctx.USDT.options.address,
|
||||
/*only for test*/
|
||||
pairContract: ctx.USDT_USDC
|
||||
/**************/
|
||||
}];
|
||||
|
||||
var tx = await logGas(await calcRoute(ctx,decimalStr('10'),0.1,routes,pairs), ctx.sendParam(trader), "tow hops swap")
|
||||
var tx = await logGas(await calcRoute(ctx, decimalStr('10'), 0.1, routes, pairs), ctx.sendParam(trader), "tow hops swap")
|
||||
// console.log(tx.events['Swapped']);
|
||||
var a_DODO = await ctx.DODO.methods.balanceOf(trader).call()
|
||||
var a_USDC = await ctx.USDC.methods.balanceOf(trader).call()
|
||||
console.log("After DODO:" + fromWei(a_DODO,'ether') + "; USDC:" + fromWei(a_USDC,'mwei'));
|
||||
console.log("After DODO:" + fromWei(a_DODO, 'ether') + "; USDC:" + fromWei(a_USDC, 'mwei'));
|
||||
console.log("===============================================")
|
||||
var c_DODO = await ctx.DODO.methods.balanceOf(ctx.SmartSwap.options.address).call()
|
||||
var c_USDT = await ctx.USDT.methods.balanceOf(ctx.SmartSwap.options.address).call()
|
||||
var c_USDC = await ctx.USDC.methods.balanceOf(ctx.SmartSwap.options.address).call()
|
||||
console.log("Contract DODO:" + fromWei(c_DODO,'ether') + "; USDT:" + fromWei(c_USDT,'mwei') + "; USDC:" + fromWei(c_USDC,'mwei'));
|
||||
console.log("Contract DODO:" + fromWei(c_DODO, 'ether') + "; USDT:" + fromWei(c_USDT, 'mwei') + "; USDC:" + fromWei(c_USDC, 'mwei'));
|
||||
});
|
||||
|
||||
it("DODO to WETH three hops swap", async () => {
|
||||
var b_DODO = await ctx.DODO.methods.balanceOf(trader).call()
|
||||
var b_WETH = await ctx.WETH.methods.balanceOf(trader).call()
|
||||
console.log("Before DODO:" + fromWei(b_DODO,'ether') + "; WETH:" + fromWei(b_WETH,'ether'));
|
||||
console.log("Before DODO:" + fromWei(b_DODO, 'ether') + "; WETH:" + fromWei(b_WETH, 'ether'));
|
||||
//approve DODO entry
|
||||
await ctx.DODO.methods.approve(ctx.SmartApprove.options.address,MAX_UINT256).send(ctx.sendParam(trader))
|
||||
await ctx.DODO.methods.approve(ctx.SmartApprove.options.address, MAX_UINT256).send(ctx.sendParam(trader))
|
||||
//set route path
|
||||
var routes = [{
|
||||
address: ctx.DODO.options.address,
|
||||
decimals: 18
|
||||
},{
|
||||
}, {
|
||||
address: ctx.USDT.options.address,
|
||||
decimals: 6
|
||||
},{
|
||||
}, {
|
||||
address: ctx.USDC.options.address,
|
||||
decimals: 6
|
||||
},{
|
||||
}, {
|
||||
address: ctx.WETH.options.address,
|
||||
decimals: 18
|
||||
}];
|
||||
@@ -240,34 +239,168 @@ describe("Trader", () => {
|
||||
var pairs = [{
|
||||
pair: ctx.DODO_USDT.options.address,
|
||||
base: ctx.DODO.options.address,
|
||||
/*only for test*/
|
||||
pairContract: ctx.DODO_USDT
|
||||
/**************/
|
||||
},{
|
||||
}, {
|
||||
pair: ctx.USDT_USDC.options.address,
|
||||
base: ctx.USDT.options.address,
|
||||
/*only for test*/
|
||||
pairContract: ctx.USDT_USDC
|
||||
/**************/
|
||||
},{
|
||||
}, {
|
||||
pair: ctx.WETH_USDC.options.address,
|
||||
base: ctx.WETH.options.address,
|
||||
/*only for test*/
|
||||
pairContract: ctx.WETH_USDC
|
||||
/**************/
|
||||
}];
|
||||
|
||||
var tx = await logGas(await calcRoute(ctx,decimalStr('10'),0.1,routes,pairs), ctx.sendParam(trader), "three hops swap")
|
||||
var tx = await logGas(await calcRoute(ctx, decimalStr('10'), 0.1, routes, pairs), ctx.sendParam(trader), "three hops swap")
|
||||
console.log(tx.events['TestAmount']);
|
||||
var a_DODO = await ctx.DODO.methods.balanceOf(trader).call()
|
||||
var a_WETH = await ctx.WETH.methods.balanceOf(trader).call()
|
||||
console.log("After DODO:" + fromWei(a_DODO,'ether') + "; WETH:" + fromWei(a_WETH,'ether'));
|
||||
console.log("After DODO:" + fromWei(a_DODO, 'ether') + "; WETH:" + fromWei(a_WETH, 'ether'));
|
||||
console.log("===============================================")
|
||||
var c_DODO = await ctx.DODO.methods.balanceOf(ctx.SmartSwap.options.address).call()
|
||||
var c_USDT = await ctx.USDT.methods.balanceOf(ctx.SmartSwap.options.address).call()
|
||||
var c_USDC = await ctx.USDC.methods.balanceOf(ctx.SmartSwap.options.address).call()
|
||||
var c_WETH = await ctx.WETH.methods.balanceOf(ctx.SmartSwap.options.address).call()
|
||||
console.log("Contract DODO:" + fromWei(c_DODO,'ether') + "; USDT:" + fromWei(c_USDT,'mwei') + "; USDC:" + fromWei(c_USDC,'mwei') + "; WETH:" + fromWei(c_WETH,'ether'));
|
||||
console.log("Contract DODO:" + fromWei(c_DODO, 'ether') + "; USDT:" + fromWei(c_USDT, 'mwei') + "; USDC:" + fromWei(c_USDC, 'mwei') + "; WETH:" + fromWei(c_WETH, 'ether'));
|
||||
});
|
||||
|
||||
|
||||
it("ETH to USDT wrap eth and directly swap", async () => {
|
||||
var b_ETH = await ctx.Web3.eth.getBalance(trader)
|
||||
var b_WETH = await ctx.WETH.methods.balanceOf(trader).call()
|
||||
var b_USDC = await ctx.USDC.methods.balanceOf(trader).call()
|
||||
console.log("Before ETH:" + fromWei(b_ETH, 'ether') + "; WETH:" + fromWei(b_WETH, 'ether') + "; USDC:" + fromWei(b_USDC, 'mwei'));
|
||||
var b_w_eth = await ctx.Web3.eth.getBalance(ctx.WETH.options.address)
|
||||
console.log("weth contract Before:" + fromWei(b_w_eth, 'ether'))
|
||||
//set route path
|
||||
var routes = [{
|
||||
address: "0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE",
|
||||
decimals: 18
|
||||
}, {
|
||||
address: ctx.USDC.options.address,
|
||||
decimals: 6
|
||||
}];
|
||||
|
||||
var pairs = [{
|
||||
pair: ctx.WETH_USDC.options.address,
|
||||
base: ctx.WETH.options.address,
|
||||
pairContract: ctx.WETH_USDC
|
||||
}];
|
||||
|
||||
var tx = await logGas(await calcRoute(ctx, decimalStr('1'), 0.1, routes, pairs), ctx.sendParam(trader, '1'), "wrap eth and directly swap")
|
||||
var a_ETH = await ctx.Web3.eth.getBalance(trader)
|
||||
var a_WETH = await ctx.WETH.methods.balanceOf(trader).call()
|
||||
var a_USDC = await ctx.USDC.methods.balanceOf(trader).call()
|
||||
console.log("After ETH:" + fromWei(a_ETH, 'ether') + "; WETH:" + fromWei(a_WETH, 'ether') + "; USDC:" + fromWei(a_USDC, 'mwei'));
|
||||
console.log("===============================================")
|
||||
var c_ETH = await ctx.Web3.eth.getBalance(ctx.SmartSwap.options.address)
|
||||
var c_WETH = await ctx.WETH.methods.balanceOf(ctx.SmartSwap.options.address).call()
|
||||
var c_USDT = await ctx.USDT.methods.balanceOf(ctx.SmartSwap.options.address).call()
|
||||
var c_USDC = await ctx.USDC.methods.balanceOf(ctx.SmartSwap.options.address).call()
|
||||
console.log("Contract ETH:" + fromWei(c_ETH, 'ether') + "; WETH:" + fromWei(c_WETH, 'ether') + "; USDT:" + fromWei(c_USDT, 'mwei') + "; USDC:" + fromWei(c_USDC, 'mwei'));
|
||||
var a_w_eth = await ctx.Web3.eth.getBalance(ctx.WETH.options.address)
|
||||
console.log("weth contract After:" + fromWei(a_w_eth, 'ether'))
|
||||
});
|
||||
|
||||
|
||||
it("ETH to USDT wrap eth and two hops swap", async () => {
|
||||
var b_ETH = await ctx.Web3.eth.getBalance(trader)
|
||||
var b_WETH = await ctx.WETH.methods.balanceOf(trader).call()
|
||||
var b_USDT = await ctx.USDT.methods.balanceOf(trader).call()
|
||||
console.log("Before ETH:" + fromWei(b_ETH, 'ether') + "; WETH:" + fromWei(b_WETH, 'ether') + "; USDT:" + fromWei(b_USDT, 'mwei'));
|
||||
var b_w_eth = await ctx.Web3.eth.getBalance(ctx.WETH.options.address)
|
||||
console.log("weth contract Before:" + fromWei(b_w_eth, 'ether'))
|
||||
//set route path
|
||||
var routes = [{
|
||||
address: "0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE",
|
||||
decimals: 18
|
||||
}, {
|
||||
address: ctx.USDC.options.address,
|
||||
decimals: 6
|
||||
}, {
|
||||
address: ctx.USDT.options.address,
|
||||
decimals: 6
|
||||
}];
|
||||
|
||||
var pairs = [{
|
||||
pair: ctx.WETH_USDC.options.address,
|
||||
base: ctx.WETH.options.address,
|
||||
pairContract: ctx.WETH_USDC
|
||||
}, {
|
||||
pair: ctx.USDT_USDC.options.address,
|
||||
base: ctx.USDT.options.address,
|
||||
pairContract: ctx.USDT_USDC
|
||||
}];
|
||||
|
||||
var tx = await logGas(await calcRoute(ctx, decimalStr('1'), 0.1, routes, pairs), ctx.sendParam(trader, '1'), "wrap eth and tow hops swap")
|
||||
var a_ETH = await ctx.Web3.eth.getBalance(trader)
|
||||
var a_WETH = await ctx.WETH.methods.balanceOf(trader).call()
|
||||
var a_USDT = await ctx.USDT.methods.balanceOf(trader).call()
|
||||
console.log("After ETH:" + fromWei(a_ETH, 'ether') + "; WETH:" + fromWei(a_WETH, 'ether') + "; USDT:" + fromWei(a_USDT, 'mwei'));
|
||||
console.log("===============================================")
|
||||
var c_ETH = await ctx.Web3.eth.getBalance(ctx.SmartSwap.options.address)
|
||||
var c_WETH = await ctx.WETH.methods.balanceOf(ctx.SmartSwap.options.address).call()
|
||||
var c_USDT = await ctx.USDT.methods.balanceOf(ctx.SmartSwap.options.address).call()
|
||||
var c_USDC = await ctx.USDC.methods.balanceOf(ctx.SmartSwap.options.address).call()
|
||||
console.log("Contract ETH:" + fromWei(c_ETH, 'ether') + "; WETH:" + fromWei(c_WETH, 'ether') + "; USDT:" + fromWei(c_USDT, 'mwei') + "; USDC:" + fromWei(c_USDC, 'mwei'));
|
||||
var a_w_eth = await ctx.Web3.eth.getBalance(ctx.WETH.options.address)
|
||||
console.log("weth contract After:" + fromWei(a_w_eth, 'ether'))
|
||||
});
|
||||
|
||||
|
||||
it("DODO to ETH unwrap eth and three hops swap", async () => {
|
||||
var b_DODO = await ctx.DODO.methods.balanceOf(trader).call()
|
||||
var b_ETH = await ctx.Web3.eth.getBalance(trader)
|
||||
var b_WETH = await ctx.WETH.methods.balanceOf(trader).call()
|
||||
console.log("User Before ETH:" + fromWei(b_ETH, 'ether') + "; WETH:" + fromWei(b_WETH, 'ether') + "; DODO:" + fromWei(b_DODO, 'ether'));
|
||||
var b_w_eth = await ctx.Web3.eth.getBalance(ctx.WETH.options.address)
|
||||
console.log("weth contract Before:" + fromWei(b_w_eth, 'ether'))
|
||||
|
||||
//approve DODO entry
|
||||
await ctx.DODO.methods.approve(ctx.SmartApprove.options.address, MAX_UINT256).send(ctx.sendParam(trader))
|
||||
//set route path
|
||||
var routes = [{
|
||||
address: ctx.DODO.options.address,
|
||||
decimals: 18
|
||||
}, {
|
||||
address: ctx.USDT.options.address,
|
||||
decimals: 6
|
||||
}, {
|
||||
address: ctx.USDC.options.address,
|
||||
decimals: 6
|
||||
}, {
|
||||
address: "0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE",
|
||||
decimals: 18
|
||||
}];
|
||||
|
||||
var pairs = [{
|
||||
pair: ctx.DODO_USDT.options.address,
|
||||
base: ctx.DODO.options.address,
|
||||
pairContract: ctx.DODO_USDT
|
||||
}, {
|
||||
pair: ctx.USDT_USDC.options.address,
|
||||
base: ctx.USDT.options.address,
|
||||
pairContract: ctx.USDT_USDC
|
||||
}, {
|
||||
pair: ctx.WETH_USDC.options.address,
|
||||
base: ctx.WETH.options.address,
|
||||
pairContract: ctx.WETH_USDC
|
||||
}];
|
||||
|
||||
var tx = await logGas(await calcRoute(ctx, decimalStr('1000'), 0.1, routes, pairs), ctx.sendParam(trader), "unwrap eth and three hops swap")
|
||||
var a_ETH = await ctx.Web3.eth.getBalance(trader)
|
||||
var a_WETH = await ctx.WETH.methods.balanceOf(trader).call()
|
||||
var a_DODO = await ctx.DODO.methods.balanceOf(trader).call()
|
||||
console.log("After ETH:" + fromWei(a_ETH, 'ether') + "; WETH:" + fromWei(a_WETH, 'ether') + "; DODO:" + fromWei(a_DODO, 'ether'));
|
||||
console.log("===============================================")
|
||||
var c_ETH = await ctx.Web3.eth.getBalance(ctx.SmartSwap.options.address)
|
||||
var c_WETH = await ctx.WETH.methods.balanceOf(ctx.SmartSwap.options.address).call()
|
||||
var c_USDT = await ctx.USDT.methods.balanceOf(ctx.SmartSwap.options.address).call()
|
||||
var c_USDC = await ctx.USDC.methods.balanceOf(ctx.SmartSwap.options.address).call()
|
||||
var c_DODO = await ctx.DODO.methods.balanceOf(ctx.SmartSwap.options.address).call()
|
||||
console.log("Contract ETH:" + fromWei(c_ETH, 'ether') + "; WETH:" + fromWei(c_WETH, 'ether') + "; USDT:" + fromWei(c_USDT, 'mwei') + "; USDC:" + fromWei(c_USDC, 'mwei') + "; DODO:" + fromWei(c_DODO, "ether"));
|
||||
var w_eth = await ctx.Web3.eth.getBalance(ctx.WETH.options.address)
|
||||
console.log("weth contract After:" + fromWei(w_eth, 'ether'))
|
||||
});
|
||||
|
||||
});
|
||||
});
|
||||
|
||||
@@ -58,10 +58,10 @@ export class DODOContext {
|
||||
mtFeeRate: string;
|
||||
k: string;
|
||||
//token
|
||||
DODO:Contract;
|
||||
USDT:Contract;
|
||||
USDC:Contract;
|
||||
WETH:Contract;
|
||||
DODO: Contract;
|
||||
USDT: Contract;
|
||||
USDC: Contract;
|
||||
WETH: Contract;
|
||||
//pair
|
||||
DODO_USDT: Contract;
|
||||
USDT_USDC: Contract;
|
||||
@@ -74,7 +74,7 @@ export class DODOContext {
|
||||
SmartApprove: Contract;
|
||||
DODOSellHelper: Contract;
|
||||
|
||||
constructor() {}
|
||||
constructor() { }
|
||||
|
||||
async init(config: DODOContextInitConfig) {
|
||||
this.k = config.k;
|
||||
@@ -116,9 +116,10 @@ export class DODOContext {
|
||||
["USDC", 6]
|
||||
);
|
||||
this.WETH = await contracts.newContract(
|
||||
contracts.TEST_ERC20_CONTRACT_NAME,
|
||||
["WETH", 18]
|
||||
contracts.WETH_CONTRACT_NAME
|
||||
);
|
||||
|
||||
|
||||
//创建交易对
|
||||
//DODO-USDT
|
||||
this.DODO_USDT_ORACLE = await contracts.newContract(
|
||||
@@ -223,7 +224,7 @@ export class DODOContext {
|
||||
|
||||
this.SmartSwap = await contracts.newContract(
|
||||
contracts.SMART_SWAP,
|
||||
[this.SmartApprove.options.address,this.DODOSellHelper.options.address]
|
||||
[this.SmartApprove.options.address, this.DODOSellHelper.options.address, this.WETH.options.address]
|
||||
);
|
||||
|
||||
await this.SmartApprove.methods.setSmartSwap(this.SmartSwap.options.address).send(this.sendParam(this.Deployer));
|
||||
@@ -240,20 +241,21 @@ export class DODOContext {
|
||||
};
|
||||
}
|
||||
|
||||
async setOraclePrice(oracle:Contract,price: string) {
|
||||
async setOraclePrice(oracle: Contract, price: string) {
|
||||
await oracle.methods
|
||||
.setPrice(price)
|
||||
.send(this.sendParam(this.Deployer));
|
||||
}
|
||||
|
||||
async mintToken(tokenBase:Contract,tokenQuote:Contract,to: string, base: string, quote: string) {
|
||||
await tokenBase.methods.mint(to, base).send(this.sendParam(this.Deployer));
|
||||
await tokenQuote.methods
|
||||
.mint(to, quote)
|
||||
.send(this.sendParam(this.Deployer));
|
||||
async mintToken(tokenBase: Contract, tokenQuote: Contract, to: string, base: string, quote: string) {
|
||||
if (tokenBase != null)
|
||||
await tokenBase.methods.mint(to, base).send(this.sendParam(this.Deployer));
|
||||
if (tokenQuote != null)
|
||||
await tokenQuote.methods.mint(to, quote).send(this.sendParam(this.Deployer));
|
||||
}
|
||||
|
||||
async approvePair(tokenBase:Contract,tokenQuote:Contract, approveTarget:string,account: string) {
|
||||
|
||||
async approvePair(tokenBase: Contract, tokenQuote: Contract, approveTarget: string, account: string) {
|
||||
await tokenBase.methods
|
||||
.approve(approveTarget, MAX_UINT256)
|
||||
.send(this.sendParam(account));
|
||||
|
||||
@@ -17,7 +17,6 @@ const CloneFactory = require(`${jsonPath}CloneFactory.json`)
|
||||
const DODO = require(`${jsonPath}DODO.json`)
|
||||
const DODOZoo = require(`${jsonPath}DODOZoo.json`)
|
||||
const DODOEthProxy = require(`${jsonPath}DODOEthProxy.json`)
|
||||
const WETH = require(`${jsonPath}WETH9.json`)
|
||||
const TestERC20 = require(`${jsonPath}TestERC20.json`)
|
||||
const NaiveOracle = require(`${jsonPath}NaiveOracle.json`)
|
||||
const DODOLpToken = require(`${jsonPath}DODOLpToken.json`)
|
||||
@@ -31,6 +30,7 @@ const LockedTokenVault = require(`${jsonPath}LockedTokenVault.json`)
|
||||
const SmartSwap = require(`${jsonPath2}SmartSwap.json`)
|
||||
const SmartApprove = require(`${jsonPath2}SmartApprove.json`)
|
||||
const DODOSellHelper = require(`${jsonPath2}DODOSellHelper.json`)
|
||||
const WETH = require(`${jsonPath2}WETH9.json`)
|
||||
/******/
|
||||
|
||||
import { getDefaultWeb3 } from './EVM';
|
||||
|
||||
Reference in New Issue
Block a user