UNPKG

arc_dx

Version:

A platform for building DAOs

291 lines (268 loc) 14 kB
const helpers = require('./helpers'); const DaoCreator = artifacts.require("./DaoCreator.sol"); const ControllerCreator = artifacts.require("./ControllerCreator.sol"); const constants = require('./constants'); const StandardTokenMock = artifacts.require('./test/StandardTokenMock.sol'); var LockingToken4Reputation = artifacts.require("./LockingToken4Reputation.sol"); const setup = async function (accounts, _repAllocation = 100, _lockingStartTime = 0, _lockingEndTime = 3000, _redeemEnableTime = 3000, _maxLockingPeriod = 6000, _initialize = true) { var testSetup = new helpers.TestSetup(); testSetup.lockingToken = await StandardTokenMock.new(accounts[0], web3.utils.toWei('100', "ether")); var controllerCreator = await ControllerCreator.new({gas: constants.ARC_GAS_LIMIT}); testSetup.daoCreator = await DaoCreator.new(controllerCreator.address,{gas:constants.ARC_GAS_LIMIT}); testSetup.org = await helpers.setupOrganization(testSetup.daoCreator,accounts[0],1000,1000); testSetup.lockingEndTime = (await web3.eth.getBlock("latest")).timestamp + _lockingEndTime; testSetup.lockingStartTime = (await web3.eth.getBlock("latest")).timestamp + _lockingStartTime; testSetup.redeemEnableTime = (await web3.eth.getBlock("latest")).timestamp + _redeemEnableTime; testSetup.lockingToken4Reputation = await LockingToken4Reputation.new(); if (_initialize === true) { await testSetup.lockingToken4Reputation.initialize(testSetup.org.avatar.address, _repAllocation, testSetup.lockingStartTime, testSetup.lockingEndTime, testSetup.redeemEnableTime, _maxLockingPeriod, testSetup.lockingToken.address); } var permissions = "0x00000000"; await testSetup.daoCreator.setSchemes(testSetup.org.avatar.address,[testSetup.lockingToken4Reputation.address],[helpers.NULL_HASH],[permissions]); await testSetup.lockingToken.approve(testSetup.lockingToken4Reputation.address,web3.utils.toWei('100', "ether")); return testSetup; }; contract('LockingToken4Reputation', accounts => { it("initialize", async () => { let testSetup = await setup(accounts); assert.equal(await testSetup.lockingToken4Reputation.reputationReward(),100); assert.equal(await testSetup.lockingToken4Reputation.maxLockingPeriod(),6000); assert.equal(await testSetup.lockingToken4Reputation.lockingEndTime(),testSetup.lockingEndTime); assert.equal(await testSetup.lockingToken4Reputation.redeemEnableTime(),testSetup.redeemEnableTime); assert.equal(await testSetup.lockingToken4Reputation.token(),testSetup.lockingToken.address); }); it("lock", async () => { let testSetup = await setup(accounts); var tx = await testSetup.lockingToken4Reputation.lock(web3.utils.toWei('1', "ether"),100); var lockingId = await helpers.getValueFromLogs(tx, '_lockingId',1); assert.equal(tx.logs.length,1); assert.equal(tx.logs[0].event,"Lock"); assert.equal(tx.logs[0].args._lockingId,lockingId); assert.equal(tx.logs[0].args._amount,web3.utils.toWei('1', "ether")); assert.equal(tx.logs[0].args._period,100); assert.equal(tx.logs[0].args._locker,accounts[0]); }); it("cannot lock without initialize", async () => { let testSetup = await setup(accounts,100,0,3000,3000,6000,false); try { await testSetup.lockingToken4Reputation.lock(web3.utils.toWei('1', "ether"),100); assert(false, "cannot lock without initialize"); } catch(error) { helpers.assertVMException(error); } }); it("lock with value == 0 should revert", async () => { let testSetup = await setup(accounts); try { await testSetup.lockingToken4Reputation.lock(web3.utils.toWei('0', "ether"),100); assert(false, "lock with value == 0 should revert"); } catch(error) { helpers.assertVMException(error); } }); it("lock after _lockingEndTime should revert", async () => { let testSetup = await setup(accounts); await helpers.increaseTime(3001); try { await testSetup.lockingToken4Reputation.lock(web3.utils.toWei('1', "ether"),100); assert(false, "lock after _lockingEndTime should revert"); } catch(error) { helpers.assertVMException(error); } }); it("lock before start should revert", async () => { let testSetup = await setup(accounts,100,100); try { await testSetup.lockingToken4Reputation.lock(web3.utils.toWei('1', "ether"),0); assert(false, "lock before start should revert"); } catch(error) { helpers.assertVMException(error); } }); it("lock with period == 0 should revert", async () => { let testSetup = await setup(accounts); try { await testSetup.lockingToken4Reputation.lock(web3.utils.toWei('1', "ether"),0); assert(false, "lock with period == 0 should revert"); } catch(error) { helpers.assertVMException(error); } }); it("lock over _maxLockingPeriod should revert", async () => { let testSetup = await setup(accounts); try { await testSetup.lockingToken4Reputation.lock(web3.utils.toWei('1', "ether"),6001); assert(false, "lock over _maxLockingPeriod should revert"); } catch(error) { helpers.assertVMException(error); } }); it("release", async () => { let testSetup = await setup(accounts); var tx = await testSetup.lockingToken4Reputation.lock(web3.utils.toWei('1', "ether"),100); var lockingId = await helpers.getValueFromLogs(tx, '_lockingId',1); await helpers.increaseTime(101); tx = await testSetup.lockingToken4Reputation.release(accounts[0],lockingId); assert.equal(tx.logs.length,1); assert.equal(tx.logs[0].event,"Release"); assert.equal(tx.logs[0].args._lockingId,lockingId); assert.equal(tx.logs[0].args._amount,web3.utils.toWei('1', "ether")); assert.equal(tx.logs[0].args._beneficiary,accounts[0]); }); it("release before locking period should revert", async () => { let testSetup = await setup(accounts); var tx = await testSetup.lockingToken4Reputation.lock(web3.utils.toWei('1', "ether"),100); var lockingId = await helpers.getValueFromLogs(tx, '_lockingId',1); try { await testSetup.lockingToken4Reputation.release(accounts[0],lockingId); assert(false, "release before locking period should revert"); } catch(error) { helpers.assertVMException(error); } }); it("release cannot release twice", async () => { let testSetup = await setup(accounts); var tx = await testSetup.lockingToken4Reputation.lock(web3.utils.toWei('1', "ether"),100); var lockingId = await helpers.getValueFromLogs(tx, '_lockingId',1); await helpers.increaseTime(101); await testSetup.lockingToken4Reputation.release(accounts[0],lockingId); try { await testSetup.lockingToken4Reputation.release(accounts[0],lockingId); assert(false, "release cannot release twice"); } catch(error) { helpers.assertVMException(error); } }); it("redeem", async () => { let testSetup = await setup(accounts); await testSetup.lockingToken4Reputation.lock(web3.utils.toWei('1', "ether"),100); await helpers.increaseTime(3001); var tx = await testSetup.lockingToken4Reputation.redeem(accounts[0]); assert.equal(tx.logs.length,1); assert.equal(tx.logs[0].event,"Redeem"); assert.equal(tx.logs[0].args._amount,100); assert.equal(tx.logs[0].args._beneficiary,accounts[0]); assert.equal(await testSetup.org.reputation.balanceOf(accounts[0]),1000+100); }); it("redeem score ", async () => { let testSetup = await setup(accounts); await testSetup.lockingToken4Reputation.lock(web3.utils.toWei('1', "ether"),100 ,{from:accounts[0]}); await testSetup.lockingToken.transfer(accounts[1],web3.utils.toWei('1', "ether")); await testSetup.lockingToken.approve(testSetup.lockingToken4Reputation.address,web3.utils.toWei('100', "ether"),{from:accounts[1]}); await testSetup.lockingToken4Reputation.lock(web3.utils.toWei('1', "ether"),300 ,{from:accounts[1]}); await helpers.increaseTime(3001); await testSetup.lockingToken4Reputation.redeem(accounts[0]); await testSetup.lockingToken4Reputation.redeem(accounts[1]); assert.equal(await testSetup.org.reputation.balanceOf(accounts[0]),1000+25); assert.equal(await testSetup.org.reputation.balanceOf(accounts[1]),75); }); it("redeem cannot redeem twice", async () => { let testSetup = await setup(accounts); await testSetup.lockingToken4Reputation.lock(web3.utils.toWei('1', "ether"),100); await helpers.increaseTime(3001); await testSetup.lockingToken4Reputation.redeem(accounts[0]); try { await testSetup.lockingToken4Reputation.redeem(accounts[0]); assert(false, "cannot redeem twice"); } catch(error) { helpers.assertVMException(error); } }); it("redeem before lockingEndTime should revert", async () => { let testSetup = await setup(accounts); await testSetup.lockingToken4Reputation.lock(web3.utils.toWei('1', "ether"),100); await helpers.increaseTime(50); try { await testSetup.lockingToken4Reputation.redeem(accounts[0]); assert(false, "redeem before lockingEndTime should revert"); } catch(error) { helpers.assertVMException(error); } }); it("redeem before redeemEnableTime should revert", async () => { let testSetup = await setup(accounts,100,0,3000,4000,6000,true); await testSetup.lockingToken4Reputation.lock(web3.utils.toWei('1', "ether"),100); await helpers.increaseTime(3500); try { await testSetup.lockingToken4Reputation.redeem(accounts[0]); assert(false, "redeem before lockingEndTime should revert"); } catch(error) { helpers.assertVMException(error); } await helpers.increaseTime(501); await testSetup.lockingToken4Reputation.redeem(accounts[0]); }); it("cannot initialize twice", async () => { let testSetup = await setup(accounts); try { await testSetup.lockingToken4Reputation.initialize(testSetup.org.avatar.address, 100, testSetup.lockingStartTime, testSetup.lockingEndTime, testSetup.redeemEnableTime, 6000, testSetup.lockingToken.address); assert(false, "cannot initialize twice"); } catch(error) { helpers.assertVMException(error); } }); it("initialize is onlyOwner", async () => { var lockingToken4Reputation = await LockingToken4Reputation.new(); try { await lockingToken4Reputation.initialize(accounts[1], 100, 0, 100, 100, 6000, accounts[1], {from:accounts[1]}); assert(false, "initialize is onlyOwner"); } catch(error) { helpers.assertVMException(error); } await lockingToken4Reputation.initialize(accounts[1], 100, 0, 100, 100, 6000, accounts[1], {from:accounts[0]}); }); it("redeemEnableTime >= lockingEndTime", async () => { var lockingToken4Reputation = await LockingToken4Reputation.new(); try { await lockingToken4Reputation.initialize(accounts[1], 100, 0, 100, 100-1, 6000, accounts[1]); assert(false, "redeemEnableTime >= lockingEndTime"); } catch(error) { helpers.assertVMException(error); } await lockingToken4Reputation.initialize(accounts[1], 100, 0, 100, 100, 6000, accounts[1]); }); });