|
@@ -1,71 +1,62 @@
|
|
|
-var PullPaymentMock = artifacts.require('PullPaymentMock');
|
|
|
+const BigNumber = web3.BigNumber;
|
|
|
+
|
|
|
+require('chai')
|
|
|
+ .use(require('chai-bignumber')(BigNumber))
|
|
|
+ .should();
|
|
|
+
|
|
|
+const PullPaymentMock = artifacts.require('PullPaymentMock');
|
|
|
|
|
|
contract('PullPayment', function (accounts) {
|
|
|
- let ppce;
|
|
|
- let amount = 17 * 1e18;
|
|
|
+ const amount = web3.toWei(17.0, 'ether');
|
|
|
|
|
|
beforeEach(async function () {
|
|
|
- ppce = await PullPaymentMock.new({ value: amount });
|
|
|
+ this.contract = await PullPaymentMock.new({ value: amount });
|
|
|
});
|
|
|
|
|
|
it('can\'t call asyncSend externally', async function () {
|
|
|
- assert.isUndefined(ppce.asyncSend);
|
|
|
+ assert.isUndefined(this.contract.asyncSend);
|
|
|
});
|
|
|
|
|
|
it('can record an async payment correctly', async function () {
|
|
|
- let AMOUNT = 100;
|
|
|
- await ppce.callSend(accounts[0], AMOUNT);
|
|
|
- let paymentsToAccount0 = await ppce.payments(accounts[0]);
|
|
|
- let totalPayments = await ppce.totalPayments();
|
|
|
+ const AMOUNT = 100;
|
|
|
+ await this.contract.callTransfer(accounts[0], AMOUNT);
|
|
|
|
|
|
- assert.equal(totalPayments, AMOUNT);
|
|
|
- assert.equal(paymentsToAccount0, AMOUNT);
|
|
|
+ const paymentsToAccount0 = await this.contract.payments(accounts[0]);
|
|
|
+ paymentsToAccount0.should.be.bignumber.equal(AMOUNT);
|
|
|
});
|
|
|
|
|
|
it('can add multiple balances on one account', async function () {
|
|
|
- await ppce.callSend(accounts[0], 200);
|
|
|
- await ppce.callSend(accounts[0], 300);
|
|
|
- let paymentsToAccount0 = await ppce.payments(accounts[0]);
|
|
|
- let totalPayments = await ppce.totalPayments();
|
|
|
-
|
|
|
- assert.equal(totalPayments, 500);
|
|
|
- assert.equal(paymentsToAccount0, 500);
|
|
|
+ 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);
|
|
|
});
|
|
|
|
|
|
it('can add balances on multiple accounts', async function () {
|
|
|
- await ppce.callSend(accounts[0], 200);
|
|
|
- await ppce.callSend(accounts[1], 300);
|
|
|
+ await this.contract.callTransfer(accounts[0], 200);
|
|
|
+ await this.contract.callTransfer(accounts[1], 300);
|
|
|
|
|
|
- let paymentsToAccount0 = await ppce.payments(accounts[0]);
|
|
|
- assert.equal(paymentsToAccount0, 200);
|
|
|
+ const paymentsToAccount0 = await this.contract.payments(accounts[0]);
|
|
|
+ paymentsToAccount0.should.be.bignumber.equal(200);
|
|
|
|
|
|
- let paymentsToAccount1 = await ppce.payments(accounts[1]);
|
|
|
- assert.equal(paymentsToAccount1, 300);
|
|
|
-
|
|
|
- let totalPayments = await ppce.totalPayments();
|
|
|
- assert.equal(totalPayments, 500);
|
|
|
+ const paymentsToAccount1 = await this.contract.payments(accounts[1]);
|
|
|
+ paymentsToAccount1.should.be.bignumber.equal(300);
|
|
|
});
|
|
|
|
|
|
it('can withdraw payment', async function () {
|
|
|
- let payee = accounts[1];
|
|
|
- let initialBalance = web3.eth.getBalance(payee);
|
|
|
-
|
|
|
- await ppce.callSend(payee, amount);
|
|
|
-
|
|
|
- let payment1 = await ppce.payments(payee);
|
|
|
- assert.equal(payment1, amount);
|
|
|
+ const payee = accounts[1];
|
|
|
+ const initialBalance = web3.eth.getBalance(payee);
|
|
|
|
|
|
- let totalPayments = await ppce.totalPayments();
|
|
|
- assert.equal(totalPayments, amount);
|
|
|
+ await this.contract.callTransfer(payee, amount);
|
|
|
|
|
|
- await ppce.withdrawPayments({ from: payee });
|
|
|
- let payment2 = await ppce.payments(payee);
|
|
|
- assert.equal(payment2, 0);
|
|
|
+ const payment1 = await this.contract.payments(payee);
|
|
|
+ payment1.should.be.bignumber.equal(amount);
|
|
|
|
|
|
- totalPayments = await ppce.totalPayments();
|
|
|
- assert.equal(totalPayments, 0);
|
|
|
+ await this.contract.withdrawPayments({ from: payee });
|
|
|
+ const payment2 = await this.contract.payments(payee);
|
|
|
+ payment2.should.be.bignumber.equal(0);
|
|
|
|
|
|
- let balance = web3.eth.getBalance(payee);
|
|
|
- assert(Math.abs(balance - initialBalance - amount) < 1e16);
|
|
|
+ const balance = web3.eth.getBalance(payee);
|
|
|
+ Math.abs(balance - initialBalance - amount).should.be.lt(1e16);
|
|
|
});
|
|
|
});
|