From d73c76c8d4ed279d8734c833fa4f9045aa78133f Mon Sep 17 00:00:00 2001 From: Isaac Kang Date: Wed, 16 Oct 2019 22:56:55 -0400 Subject: [PATCH] fix test: previously the bootstrap ballot submission in TCR.sol is assigned to the owner of the contract (Registry.sol). this can be set to the `msg.sender` of the `start` transaction (via Registry.sol), allowing for the ballot to be claimed. --- .gitignore | 3 ++- contracts/Registry.sol | 2 +- contracts/TCR.sol | 4 ++-- test/tcr.js | 4 ++++ 4 files changed, 9 insertions(+), 4 deletions(-) diff --git a/.gitignore b/.gitignore index d163863..7c75002 100644 --- a/.gitignore +++ b/.gitignore @@ -1 +1,2 @@ -build/ \ No newline at end of file +build/ +output.json \ No newline at end of file diff --git a/contracts/Registry.sol b/contracts/Registry.sol index d4e12a1..a697800 100644 --- a/contracts/Registry.sol +++ b/contracts/Registry.sol @@ -118,7 +118,7 @@ contract Registry { require(didStart == false, "TCR already started"); require(didRagequit == true, "need to ragequit before starting TCR"); - tcrContract.start(_token); + tcrContract.start(_token, msg.sender); didStart = true; emit TCRStart(address(tcrContract), name, symbol, decimals, bootstrapList); diff --git a/contracts/TCR.sol b/contracts/TCR.sol index 314059f..954d44e 100644 --- a/contracts/TCR.sol +++ b/contracts/TCR.sol @@ -188,7 +188,7 @@ contract TCR { // Initialization // ------------------------------------------------------------------------- - function start(address _token) public onlyOwner returns(bool) { + function start(address _token, address _msgSender) public onlyOwner returns(bool) { require(startDate == 0, "TCR already started"); // launch TCR token @@ -236,7 +236,7 @@ contract TCR { tallyQueue.push(bootstrapTally); pollQueue.push(bootstrapPoll); - ballotQueue[0].votesByVoter[owner] = bootstrapSubmission; + ballotQueue[0].votesByVoter[_msgSender] = bootstrapSubmission; startDate = now; currentBallotIndex = 1; diff --git a/test/tcr.js b/test/tcr.js index 1f2f2ff..c4f2ea9 100644 --- a/test/tcr.js +++ b/test/tcr.js @@ -259,6 +259,10 @@ contract('TCR', ([creator, alice, bob]) => { }); it('process ballot', async () => { + await setupDaoMembership(); + const shares = '1'; + await initTcr(shares); + const votingDurationSecs = await tcr.votingDurationSecs(); await moveForwardSecs(votingDurationSecs.toNumber());