fix mysteryBoxV1

This commit is contained in:
owen05
2021-04-16 13:36:09 +08:00
parent 930698f676
commit 81765596c0
4 changed files with 129 additions and 25 deletions

View File

@@ -63,21 +63,21 @@ module.exports = {
//================== NFT ====================
ConstFeeRateModel: "0xBDAcEcF886a4F0C509260d9678D5673C3E8fa4b7",
FeeDistributor: "0xdE39C2901e72A883f7446951fB533219F3622b87",
Fragment: "0x40F3bBe2f8C5F2E5f4adFf7d51f652F2B9F77315",
NFTCollateralVault: "0xFDf7604649dfBb733e784afAEdC19892706cc683",
FeeDistributor: "0xC7da6C32E301C042C2237ca04aa4BB6D2e5C86B1",
Fragment: "0xc83c4aFdF216C7D0E15D50B9e1658298320A9551",
NFTCollateralVault: "0x7e83d9d94837eE82F0cc18a691da6f42F03F1d86",
DODONFTRouteHelper: "0xAE683548702be6d651e179e5F9313272bb18596A",
InitializableERC721: "0x7563414479593394460d1bbaFE2Fc3E29D804007",
InitializableERC1155: "0xb971B0df71fB1778351F25a0e3bfe0C3eF06E1d1",
NFTTokenFactory: "0x38c109aF4f3454172BA4eecf5676aA213b589e75",
InitializableERC721: "0x62dC4615AC755959a82b6D22FA5652A037284c0b",
InitializableERC1155: "0xfa391c0Ed6898e0C6186605d69e877f1317Bb506",
NFTTokenFactory: "0xdeBB45aCffF3b5e610C1EdF45DFaaea0030EAdaF",
DODONFTRegistry: "0xF405372b7808363DCfbb5Eb81204889B7a69Aa3e",
DODONFTProxy: "0x0727dEd495E35f4bA4F5D64794145152301Db23f",
DODONFTProxy: "0x8812E32b31530d21D1fE70A45bBa66bbEB3641C5",
//================= MysteryBox =================
MysteryBoxV1: "0x87457A7FDFE0a4A57aABB369A21690bF67b8dDbD",
MysteryBoxV1: "",
RandomGenerator: "0x53F54E4760FA5f839e5624782D032495613DF218",
RandomPool: [
"0xa2e0ef85618732d80e5ef362773da1c92e8b1c57",

View File

@@ -28,7 +28,6 @@ contract MysteryBoxV1 is ERC721URIStorage, InitializableOwnable {
uint256 public _TICKET_UNIT_ = 1; // ticket consumed in a single lottery
uint256[] public _TOKEN_IDS_;
uint256 public _ID_POINT_;
address public _RANDOM_GENERATOR_;
@@ -92,6 +91,11 @@ contract MysteryBoxV1 is ERC721URIStorage, InitializableOwnable {
_TOTAL_TICKETS_ = _TOTAL_TICKETS_.sub(ticketNum);
}
// ================= View ===================
function getTickets(address account) view external returns(uint256) {
return _USER_TICKETS_[account];
}
// =============== Internal ================
function _redeemSinglePrize(address to) internal {
@@ -103,7 +107,7 @@ contract MysteryBoxV1 is ERC721URIStorage, InitializableOwnable {
_TOKEN_IDS_[random] = _TOKEN_IDS_[range - 1];
}
_TOKEN_IDS_.pop();
safeTransferFrom(address(this), to, prizeId, "");
_safeTransfer(address(this), to, prizeId, "");
emit RedeemPrize(to, prizeId);
}
@@ -143,13 +147,12 @@ contract MysteryBoxV1 is ERC721URIStorage, InitializableOwnable {
emit Withdraw(msg.sender, amount);
}
function batchMint(string[] calldata urls) external onlyOwner {
for(uint256 i = 0; i < urls.length; i++) {
_mint(address(this), _ID_POINT_);
_TOKEN_IDS_.push(_ID_POINT_);
_setTokenURI(_ID_POINT_, urls[i]);
_ID_POINT_++;
function batchMint(uint256[] calldata ids, string[] calldata urls) external onlyOwner {
for(uint256 i = 0; i < ids.length; i++) {
_mint(address(this), ids[i]);
_TOKEN_IDS_.push(ids[i]);
_setTokenURI(ids[i], urls[i]);
}
emit BatchMint(urls.length);
emit BatchMint(ids.length);
}
}

View File

@@ -182,3 +182,19 @@ Deploy type: MysteryBoxV1
RandomGeneratorAddress: 0x7e21BFAcDB5062C071Fad17451E85f070DDa5d8F
MysteryBoxV1Address: 0x215BD4d983c571a840b89028CC005B6FF0734EbE
Init MysteryBoxV1 Tx: 0x15439f29a1c7b446f2d0dcda7f21dcfdd2ce3c197e8c0a5d1338621ecdb9ddab
====================================================
network type: kovan
Deploy time: 2021/4/16 下午12:14:20
Deploy type: NFT
multiSigAddress: 0x7e83d9d94837eE82F0cc18a691da6f42F03F1d86
ERC721Address: 0x62dC4615AC755959a82b6D22FA5652A037284c0b
ERC1155Address: 0xfa391c0Ed6898e0C6186605d69e877f1317Bb506
NFTTokenFactoryAddress: 0xdeBB45aCffF3b5e610C1EdF45DFaaea0030EAdaF
NFTCollateralVaultAddress: 0xC08D918400859272442CC71fc8cC3b1a69835B4a
FragmentAddress: 0xc83c4aFdF216C7D0E15D50B9e1658298320A9551
FeeDistributorAddress: 0xC7da6C32E301C042C2237ca04aa4BB6D2e5C86B1
DODONFTProxyAddress: 0x8812E32b31530d21D1fE70A45bBa66bbEB3641C5
Init DODONFTProxyAddress Tx: 0x96a1a4b9f8cdf4f6c56a2aa8298f2def0f7b87c493f172268fdd59c8aa617bc6
DODOApproveProxy unlockAddProxy tx: 0x8ef2e4693a45af5fd1fcdf9f5d8e544331148ddcf1551250244599430a0524a0
DODOApproveProxy addDODOProxy tx: 0x275aa8ec28849aa7e0b2c9b18eb3877797d027713be5f92764da8cf55f6d5eca
Add AdminList on DODONFTRegistry Tx: 0x4cc991762645beb448c3315369452d4af2e02b507b97d3638ba876d30b46d2f4

View File

@@ -4,12 +4,13 @@
SPDX-License-Identifier: Apache-2.0
*/
import { decimalStr, mweiStr, fromWei } from '../utils/Converter';
import { decimalStr, fromWei } from '../utils/Converter';
import { logGas } from '../utils/Log';
import { DVMContext, getDVMContext } from '../utils/DVMContext';
import { assert } from 'chai';
import * as contracts from '../utils/Contracts';
import { Contract } from 'web3-eth-contract';
const truffleAssert = require('truffle-assertions');
let owner: string;
let user1: string;
@@ -63,10 +64,11 @@ async function init(ctx: DVMContext): Promise<void> {
).send(ctx.sendParam(owner));
}
async function getTokenIdAndUrlByUser(user: string) {
async function getTokenIdAndUrlByUser(user: string, logInfo?: string) {
var tokenIds = []
var urls = []
var balance = await MysteryBoxV1.methods.balanceOf(user).call();
console.log(logInfo);
for (var i = 0; i < balance; i++) {
var curTokenId = await MysteryBoxV1.methods.tokenOfOwnerByIndex(user, i).call()
tokenIds.push(curTokenId);
@@ -77,6 +79,28 @@ async function getTokenIdAndUrlByUser(user: string) {
return [tokenIds, urls];
}
async function getTicketsInfo(user: string): Promise<[string, string]> {
var totalTickets = await MysteryBoxV1.methods._TOTAL_TICKETS_().call();
var userTickets = await MysteryBoxV1.methods.getTickets(user).call();
console.log("User Tickets:" + userTickets + " totalTickets:" + totalTickets);
return [totalTickets, userTickets];
}
async function getGlobalState(): Promise<[string, string]> {
var curSelling = await MysteryBoxV1.methods._CUR_SELLING_TICKETS_().call();
var curPrice = await MysteryBoxV1.methods._CUR_PRCIE_().call();
console.log("CurSellingTickets:" + curSelling + " CurPrice:" + fromWei(curPrice, 'ether'));
return [curSelling, curPrice];
}
async function batchMint(ctx: DVMContext) {
var ids = []
for (var i = 0; i < urls.length; i++) {
ids.push(i);
}
await logGas(await MysteryBoxV1.methods.batchMint(ids, urls), ctx.sendParam(owner), "batchMint-10");
}
describe("DODOMysteryBox", () => {
let snapshotId: string;
@@ -102,30 +126,91 @@ describe("DODOMysteryBox", () => {
});
describe("DODO MysteryBoxV1", () => {
it.only("batchMint", async () => {
await logGas(await MysteryBoxV1.methods.batchMint(urls), ctx.sendParam(owner), "batchMint-10");
it("batchMint", async () => {
var ids = []
for (var i = 0; i < urls.length; i++) {
ids.push(i);
}
await logGas(await MysteryBoxV1.methods.batchMint(ids, urls), ctx.sendParam(owner), "batchMint-10");
let [tokenIds,]: any = await getTokenIdAndUrlByUser(MysteryBoxV1.options.address);
assert(10, tokenIds.length);
});
it("buyTicket", async () => {
await MysteryBoxV1.methods.updateSellingInfo(100, decimalStr("0.5")).send(ctx.sendParam(owner));
await MysteryBoxV1.methods.updateSellingInfo(100, decimalStr("0.01")).send(ctx.sendParam(owner));
await truffleAssert.reverts(
MysteryBoxV1.methods.buyTicket().send(ctx.sendParam(user1, "0.001")),
"BNB_NOT_ENOUGH"
)
await logGas(await MysteryBoxV1.methods.buyTicket(), ctx.sendParam(user1, "0.5"), "buyTickets");
await logGas(await MysteryBoxV1.methods.buyTicket(), ctx.sendParam(user2, "0.4"), "buyTickets");
await truffleAssert.reverts(
MysteryBoxV1.methods.buyTicket().send(ctx.sendParam(user1, "0.2")),
"TICKETS_NOT_ENOUGH"
)
let [, userTickets] = await getTicketsInfo(user1)
assert(userTickets, "50")
let [curSelling0] = await getGlobalState()
assert(curSelling0, "10")
//两阶段卖币
await MysteryBoxV1.methods.updateSellingInfo(200, decimalStr("0.02")).send(ctx.sendParam(owner));
await logGas(await MysteryBoxV1.methods.buyTicket(), ctx.sendParam(user1, "1"), "buyTickets");
[, userTickets] = await getTicketsInfo(user1)
assert(userTickets, "100")
let [curSelling1] = await getGlobalState();
assert(curSelling1, "150")
//withdraw
var b_ETH = await ctx.Web3.eth.getBalance(owner);
var tx = await MysteryBoxV1.methods.withdraw().send(ctx.sendParam(owner))
var a_ETH = await ctx.Web3.eth.getBalance(owner);
console.log("b_ETH:" + fromWei(b_ETH, 'ether') + " a_ETH:" + fromWei(a_ETH, 'ether'));
assert.equal(
tx.events['Withdraw'].returnValues['amount'],
decimalStr("1.9")
);
});
it("redeemPrize", async () => {
//redeem
await batchMint(ctx);
//列表查询
await MysteryBoxV1.methods.updateSellingInfo(100, decimalStr("0.1")).send(ctx.sendParam(owner));
await logGas(await MysteryBoxV1.methods.buyTicket(), ctx.sendParam(user1, "0.5"), "buyTickets");
await getTicketsInfo(user1)
await getGlobalState()
await getTokenIdAndUrlByUser(user1, "redeemPrize前")
await getTokenIdAndUrlByUser(MysteryBoxV1.options.address, "盲盒合约redeemPrize前")
await logGas(await MysteryBoxV1.methods.redeemPrize(3), ctx.sendParam(user1), "redeemPrice");
await getTicketsInfo(user1)
await getGlobalState()
await getTokenIdAndUrlByUser(user1, "第一次redeemPrize后")
await logGas(await MysteryBoxV1.methods.redeemPrize(2), ctx.sendParam(user1), "redeemPrice");
let [, userTickets] = await getTicketsInfo(user1)
assert(userTickets, "0");
await getGlobalState()
await getTokenIdAndUrlByUser(user1, "第二次redeemPrize后")
let [tokenIds,] = await getTokenIdAndUrlByUser(MysteryBoxV1.options.address, "盲盒合约redeemPrize后")
assert(tokenIds, "5");
});
it("transferNFT", async () => {
await batchMint(ctx);
await MysteryBoxV1.methods.updateSellingInfo(100, decimalStr("0.1")).send(ctx.sendParam(owner));
await logGas(await MysteryBoxV1.methods.buyTicket(), ctx.sendParam(user1, "0.5"), "buyTickets");
await logGas(await MysteryBoxV1.methods.redeemPrize(1), ctx.sendParam(user1), "redeemPrice");
let [tokenId0,] = await getTokenIdAndUrlByUser(user1, "user1 转前")
assert(tokenId0.length == 1)
await getTokenIdAndUrlByUser(user2, "user2 转前")
await logGas(await MysteryBoxV1.methods.safeTransferFrom(user1, user2, tokenId0[0]), ctx.sendParam(user1), "transferNFT");
await getTokenIdAndUrlByUser(user1, "user1 转后")
let [tokenId1,] = await getTokenIdAndUrlByUser(user2, "user2 转后")
assert(tokenId1.length == 1)
});
});
});