* Now compiling using truffle 5.
* Migrated some test files, missing BN scientific notation usage.
* Now using BN time values.
* Migrate ERC20 tests.
* Migrate all ERC20 tests.
* Migrate utils, payment and ownership tests.
* All tests save ERC721 migrated.
* Migrated ERC721 tests.
* Fix lint errors.
* Delete old test helpers.
* Fix remaining crowdsale tests.
* Fix signature bouncer tests.
* Update how constants is used.
* Compile script pre-removes the build dir.
* Fix SafeMath tests.
* Revert "Compile script pre-removes the build dir."
This reverts commit 247e745113.
* Fix linter errors.
* Upgrade openzeppelin-test-helpers dependency.
* Update openzeppelin-test-helpers dependency.
* Define math constants globally.
* Remove unnecessary ether unit.
* Roll back reduced ether amounts in tests.
* Remove unnecessary toNumber conversions.
* Delete compile script.
* Fixed failing test.
43 lines
1.6 KiB
JavaScript
43 lines
1.6 KiB
JavaScript
const { balance, ether } = require('openzeppelin-test-helpers');
|
|
|
|
const PullPaymentMock = artifacts.require('PullPaymentMock');
|
|
|
|
contract('PullPayment', function ([_, payer, payee1, payee2]) {
|
|
const amount = ether('17');
|
|
|
|
beforeEach(async function () {
|
|
this.contract = await PullPaymentMock.new({ value: amount });
|
|
});
|
|
|
|
it('can record an async payment correctly', async function () {
|
|
await this.contract.callTransfer(payee1, 100, { from: payer });
|
|
(await this.contract.payments(payee1)).should.be.bignumber.equal('100');
|
|
});
|
|
|
|
it('can add multiple balances on one account', async function () {
|
|
await this.contract.callTransfer(payee1, 200, { from: payer });
|
|
await this.contract.callTransfer(payee1, 300, { from: payer });
|
|
(await this.contract.payments(payee1)).should.be.bignumber.equal('500');
|
|
});
|
|
|
|
it('can add balances on multiple accounts', async function () {
|
|
await this.contract.callTransfer(payee1, 200, { from: payer });
|
|
await this.contract.callTransfer(payee2, 300, { from: payer });
|
|
|
|
(await this.contract.payments(payee1)).should.be.bignumber.equal('200');
|
|
|
|
(await this.contract.payments(payee2)).should.be.bignumber.equal('300');
|
|
});
|
|
|
|
it('can withdraw payment', async function () {
|
|
(await balance.difference(payee1, async () => {
|
|
await this.contract.callTransfer(payee1, amount, { from: payer });
|
|
(await this.contract.payments(payee1)).should.be.bignumber.equal(amount);
|
|
|
|
await this.contract.withdrawPayments(payee1);
|
|
})).should.be.bignumber.equal(amount);
|
|
|
|
(await this.contract.payments(payee1)).should.be.bignumber.equal('0');
|
|
});
|
|
});
|