2018-05-05 17:11:53 +02:00
|
|
|
import assert from 'assert'
|
|
|
|
import proxyquire from 'proxyquire'
|
|
|
|
import sinon from 'sinon'
|
|
|
|
|
|
|
|
import {
|
|
|
|
REQUIRED_ERROR,
|
|
|
|
INVALID_RECIPIENT_ADDRESS_ERROR,
|
2019-01-22 20:05:59 +01:00
|
|
|
KNOWN_RECIPIENT_ADDRESS_ERROR,
|
2018-05-05 17:11:53 +02:00
|
|
|
} from '../../../send.constants'
|
|
|
|
|
|
|
|
const stubs = {
|
|
|
|
isValidAddress: sinon.stub().callsFake(to => Boolean(to.match(/^[0xabcdef123456798]+$/))),
|
|
|
|
}
|
|
|
|
|
2019-07-31 21:56:44 +02:00
|
|
|
const toRowUtils = proxyquire('../add-recipient.js', {
|
2019-04-17 21:15:13 +02:00
|
|
|
'../../../../helpers/utils/util': {
|
2018-05-05 17:11:53 +02:00
|
|
|
isValidAddress: stubs.isValidAddress,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
const {
|
|
|
|
getToErrorObject,
|
2019-01-23 19:09:56 +01:00
|
|
|
getToWarningObject,
|
2018-05-05 17:11:53 +02:00
|
|
|
} = toRowUtils
|
|
|
|
|
2019-07-31 21:56:44 +02:00
|
|
|
describe('add-recipient utils', () => {
|
2018-05-05 17:11:53 +02:00
|
|
|
|
|
|
|
describe('getToErrorObject()', () => {
|
|
|
|
it('should return a required error if to is falsy', () => {
|
|
|
|
assert.deepEqual(getToErrorObject(null), {
|
|
|
|
to: REQUIRED_ERROR,
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2018-10-01 14:50:33 +02:00
|
|
|
it('should return null if to is falsy and hexData is truthy', () => {
|
|
|
|
assert.deepEqual(getToErrorObject(null, undefined, true), {
|
|
|
|
to: null,
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2018-05-05 17:11:53 +02:00
|
|
|
it('should return an invalid recipient error if to is truthy but invalid', () => {
|
|
|
|
assert.deepEqual(getToErrorObject('mockInvalidTo'), {
|
|
|
|
to: INVALID_RECIPIENT_ADDRESS_ERROR,
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return null if to is truthy and valid', () => {
|
|
|
|
assert.deepEqual(getToErrorObject('0xabc123'), {
|
|
|
|
to: null,
|
|
|
|
})
|
|
|
|
})
|
2018-06-14 15:55:55 +02:00
|
|
|
|
|
|
|
it('should return the passed error if to is truthy but invalid if to is truthy and valid', () => {
|
|
|
|
assert.deepEqual(getToErrorObject('invalid #$ 345878', 'someExplicitError'), {
|
|
|
|
to: 'someExplicitError',
|
|
|
|
})
|
|
|
|
})
|
2019-01-22 20:05:59 +01:00
|
|
|
|
2019-05-08 19:34:56 +02:00
|
|
|
it('should return null if to is truthy but part of state tokens', () => {
|
2019-01-22 20:05:59 +01:00
|
|
|
assert.deepEqual(getToErrorObject('0xabc123', undefined, false, [{'address': '0xabc123'}], {'address': '0xabc123'}), {
|
2019-05-08 19:34:56 +02:00
|
|
|
to: null,
|
2019-01-22 20:05:59 +01:00
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should null if to is truthy part of tokens but selectedToken falsy', () => {
|
|
|
|
assert.deepEqual(getToErrorObject('0xabc123', undefined, false, [{'address': '0xabc123'}]), {
|
|
|
|
to: null,
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2019-05-08 19:34:56 +02:00
|
|
|
it('should return null if to is truthy but part of contract metadata', () => {
|
2019-01-22 20:05:59 +01:00
|
|
|
assert.deepEqual(getToErrorObject('0x89d24a6b4ccb1b6faa2625fe562bdd9a23260359', undefined, false, [{'address': '0xabc123'}], {'address': '0xabc123'}), {
|
2019-05-08 19:34:56 +02:00
|
|
|
to: null,
|
2019-01-22 20:05:59 +01:00
|
|
|
})
|
|
|
|
})
|
|
|
|
it('should null if to is truthy part of contract metadata but selectedToken falsy', () => {
|
|
|
|
assert.deepEqual(getToErrorObject('0x89d24a6b4ccb1b6faa2625fe562bdd9a23260359', undefined, false, [{'address': '0xabc123'}], {'address': '0xabc123'}), {
|
2019-05-08 19:34:56 +02:00
|
|
|
to: null,
|
2019-01-22 20:05:59 +01:00
|
|
|
})
|
|
|
|
})
|
2018-05-05 17:11:53 +02:00
|
|
|
})
|
|
|
|
|
2019-01-23 19:09:56 +01:00
|
|
|
describe('getToWarningObject()', () => {
|
|
|
|
it('should return a known address recipient if to is truthy but part of state tokens', () => {
|
|
|
|
assert.deepEqual(getToWarningObject('0xabc123', undefined, [{'address': '0xabc123'}], {'address': '0xabc123'}), {
|
|
|
|
to: KNOWN_RECIPIENT_ADDRESS_ERROR,
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should null if to is truthy part of tokens but selectedToken falsy', () => {
|
|
|
|
assert.deepEqual(getToWarningObject('0xabc123', undefined, [{'address': '0xabc123'}]), {
|
|
|
|
to: null,
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return a known address recipient if to is truthy but part of contract metadata', () => {
|
|
|
|
assert.deepEqual(getToWarningObject('0x89d24a6b4ccb1b6faa2625fe562bdd9a23260359', undefined, [{'address': '0xabc123'}], {'address': '0xabc123'}), {
|
|
|
|
to: KNOWN_RECIPIENT_ADDRESS_ERROR,
|
|
|
|
})
|
|
|
|
})
|
|
|
|
it('should null if to is truthy part of contract metadata but selectedToken falsy', () => {
|
|
|
|
assert.deepEqual(getToWarningObject('0x89d24a6b4ccb1b6faa2625fe562bdd9a23260359', undefined, [{'address': '0xabc123'}], {'address': '0xabc123'}), {
|
|
|
|
to: KNOWN_RECIPIENT_ADDRESS_ERROR,
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2018-05-05 17:11:53 +02:00
|
|
|
})
|