All tests now use account names, and dont use accounts[0] (except ERC… (#1137)
* All tests now use account names, and dont use accounts[0] (except ERC721) * Added account names to some missing contracts.
This commit is contained in:
@ -8,7 +8,7 @@ require('chai')
|
||||
|
||||
const PullPaymentMock = artifacts.require('PullPaymentMock');
|
||||
|
||||
contract('PullPayment', function (accounts) {
|
||||
contract('PullPayment', function ([_, payer, payee1, payee2]) {
|
||||
const amount = web3.toWei(17.0, 'ether');
|
||||
|
||||
beforeEach(async function () {
|
||||
@ -21,44 +21,43 @@ contract('PullPayment', function (accounts) {
|
||||
|
||||
it('can record an async payment correctly', async function () {
|
||||
const AMOUNT = 100;
|
||||
await this.contract.callTransfer(accounts[0], AMOUNT);
|
||||
await this.contract.callTransfer(payee1, AMOUNT, { from: payer });
|
||||
|
||||
const paymentsToAccount0 = await this.contract.payments(accounts[0]);
|
||||
paymentsToAccount0.should.be.bignumber.equal(AMOUNT);
|
||||
const paymentsToPayee1 = await this.contract.payments(payee1);
|
||||
paymentsToPayee1.should.be.bignumber.equal(AMOUNT);
|
||||
});
|
||||
|
||||
it('can add multiple balances on one account', async function () {
|
||||
await this.contract.callTransfer(accounts[0], 200);
|
||||
await this.contract.callTransfer(accounts[0], 300);
|
||||
const paymentsToAccount0 = await this.contract.payments(accounts[0]);
|
||||
paymentsToAccount0.should.be.bignumber.equal(500);
|
||||
await this.contract.callTransfer(payee1, 200, { from: payer });
|
||||
await this.contract.callTransfer(payee1, 300, { from: payer });
|
||||
const paymentsToPayee1 = await this.contract.payments(payee1);
|
||||
paymentsToPayee1.should.be.bignumber.equal(500);
|
||||
});
|
||||
|
||||
it('can add balances on multiple accounts', async function () {
|
||||
await this.contract.callTransfer(accounts[0], 200);
|
||||
await this.contract.callTransfer(accounts[1], 300);
|
||||
await this.contract.callTransfer(payee1, 200, { from: payer });
|
||||
await this.contract.callTransfer(payee2, 300, { from: payer });
|
||||
|
||||
const paymentsToAccount0 = await this.contract.payments(accounts[0]);
|
||||
paymentsToAccount0.should.be.bignumber.equal(200);
|
||||
const paymentsToPayee1 = await this.contract.payments(payee1);
|
||||
paymentsToPayee1.should.be.bignumber.equal(200);
|
||||
|
||||
const paymentsToAccount1 = await this.contract.payments(accounts[1]);
|
||||
paymentsToAccount1.should.be.bignumber.equal(300);
|
||||
const paymentsToPayee2 = await this.contract.payments(payee2);
|
||||
paymentsToPayee2.should.be.bignumber.equal(300);
|
||||
});
|
||||
|
||||
it('can withdraw payment', async function () {
|
||||
const payee = accounts[1];
|
||||
const initialBalance = await ethGetBalance(payee);
|
||||
const initialBalance = await ethGetBalance(payee1);
|
||||
|
||||
await this.contract.callTransfer(payee, amount);
|
||||
await this.contract.callTransfer(payee1, amount, { from: payer });
|
||||
|
||||
const payment1 = await this.contract.payments(payee);
|
||||
const payment1 = await this.contract.payments(payee1);
|
||||
payment1.should.be.bignumber.equal(amount);
|
||||
|
||||
await this.contract.withdrawPayments({ from: payee });
|
||||
const payment2 = await this.contract.payments(payee);
|
||||
await this.contract.withdrawPayments({ from: payee1 });
|
||||
const payment2 = await this.contract.payments(payee1);
|
||||
payment2.should.be.bignumber.equal(0);
|
||||
|
||||
const balance = await ethGetBalance(payee);
|
||||
const balance = await ethGetBalance(payee1);
|
||||
Math.abs(balance - initialBalance - amount).should.be.lt(1e16);
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user