2020-01-09 04:34:58 +01:00
|
|
|
import assert from 'assert'
|
|
|
|
import sinon from 'sinon'
|
2020-12-16 22:14:49 +01:00
|
|
|
import { ObservableStore } from '@metamask/obs-store'
|
2020-01-09 04:34:58 +01:00
|
|
|
import EnsController from '../../../../app/scripts/controllers/ens'
|
2019-11-01 18:54:00 +01:00
|
|
|
|
|
|
|
const ZERO_ADDRESS = '0x0000000000000000000000000000000000000000'
|
|
|
|
const ZERO_X_ERROR_ADDRESS = '0x'
|
|
|
|
|
|
|
|
describe('EnsController', function () {
|
|
|
|
describe('#constructor', function () {
|
2020-02-11 17:51:13 +01:00
|
|
|
it('should construct the controller given a provider and a network', async function () {
|
2019-11-01 18:54:00 +01:00
|
|
|
const currentNetworkId = '3'
|
|
|
|
const networkStore = new ObservableStore(currentNetworkId)
|
|
|
|
const ens = new EnsController({
|
2020-11-03 00:41:28 +01:00
|
|
|
provider: {},
|
2019-11-01 18:54:00 +01:00
|
|
|
networkStore,
|
|
|
|
})
|
|
|
|
|
|
|
|
assert.ok(ens._ens)
|
|
|
|
})
|
|
|
|
|
2020-02-11 17:51:13 +01:00
|
|
|
it('should construct the controller given an existing ENS instance', async function () {
|
2019-11-01 18:54:00 +01:00
|
|
|
const networkStore = {
|
|
|
|
subscribe: sinon.spy(),
|
|
|
|
}
|
|
|
|
const ens = new EnsController({
|
|
|
|
ens: {},
|
|
|
|
networkStore,
|
|
|
|
})
|
|
|
|
|
|
|
|
assert.ok(ens._ens)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('#reverseResolveName', function () {
|
2020-02-11 17:51:13 +01:00
|
|
|
it('should resolve to an ENS name', async function () {
|
2019-11-01 18:54:00 +01:00
|
|
|
const address = '0x8e5d75d60224ea0c33d0041e75de68b1c3cb6dd5'
|
|
|
|
const networkStore = {
|
|
|
|
subscribe: sinon.spy(),
|
|
|
|
}
|
|
|
|
const ens = new EnsController({
|
|
|
|
ens: {
|
|
|
|
reverse: sinon.stub().withArgs(address).returns('peaksignal.eth'),
|
|
|
|
lookup: sinon.stub().withArgs('peaksignal.eth').returns(address),
|
|
|
|
},
|
|
|
|
networkStore,
|
|
|
|
})
|
|
|
|
|
|
|
|
const name = await ens.reverseResolveAddress(address)
|
|
|
|
assert.equal(name, 'peaksignal.eth')
|
|
|
|
})
|
|
|
|
|
2020-02-11 17:51:13 +01:00
|
|
|
it('should only resolve an ENS name once', async function () {
|
2019-11-01 18:54:00 +01:00
|
|
|
const address = '0x8e5d75d60224ea0c33d0041e75de68b1c3cb6dd5'
|
|
|
|
const reverse = sinon.stub().withArgs(address).returns('peaksignal.eth')
|
|
|
|
const lookup = sinon.stub().withArgs('peaksignal.eth').returns(address)
|
|
|
|
const networkStore = {
|
|
|
|
subscribe: sinon.spy(),
|
|
|
|
}
|
|
|
|
const ens = new EnsController({
|
|
|
|
ens: {
|
|
|
|
reverse,
|
|
|
|
lookup,
|
|
|
|
},
|
|
|
|
networkStore,
|
|
|
|
})
|
|
|
|
|
|
|
|
assert.equal(await ens.reverseResolveAddress(address), 'peaksignal.eth')
|
|
|
|
assert.equal(await ens.reverseResolveAddress(address), 'peaksignal.eth')
|
|
|
|
assert.ok(lookup.calledOnce)
|
|
|
|
assert.ok(reverse.calledOnce)
|
|
|
|
})
|
|
|
|
|
2020-02-11 17:51:13 +01:00
|
|
|
it('should fail if the name is registered to a different address than the reverse-resolved', async function () {
|
2019-11-01 18:54:00 +01:00
|
|
|
const address = '0x8e5d75d60224ea0c33d0041e75de68b1c3cb6dd5'
|
|
|
|
const networkStore = {
|
|
|
|
subscribe: sinon.spy(),
|
|
|
|
}
|
|
|
|
const ens = new EnsController({
|
|
|
|
ens: {
|
|
|
|
reverse: sinon.stub().withArgs(address).returns('peaksignal.eth'),
|
|
|
|
lookup: sinon.stub().withArgs('peaksignal.eth').returns('0xfoo'),
|
|
|
|
},
|
|
|
|
networkStore,
|
|
|
|
})
|
|
|
|
|
|
|
|
const name = await ens.reverseResolveAddress(address)
|
|
|
|
assert.strictEqual(name, undefined)
|
|
|
|
})
|
|
|
|
|
2020-02-11 17:51:13 +01:00
|
|
|
it('should throw an error when the lookup resolves to the zero address', async function () {
|
2019-11-01 18:54:00 +01:00
|
|
|
const address = '0x8e5d75d60224ea0c33d0041e75de68b1c3cb6dd5'
|
|
|
|
const networkStore = {
|
|
|
|
subscribe: sinon.spy(),
|
|
|
|
}
|
|
|
|
const ens = new EnsController({
|
|
|
|
ens: {
|
|
|
|
reverse: sinon.stub().withArgs(address).returns('peaksignal.eth'),
|
|
|
|
lookup: sinon.stub().withArgs('peaksignal.eth').returns(ZERO_ADDRESS),
|
|
|
|
},
|
|
|
|
networkStore,
|
|
|
|
})
|
|
|
|
|
|
|
|
try {
|
|
|
|
await ens.reverseResolveAddress(address)
|
|
|
|
assert.fail('#reverseResolveAddress did not throw')
|
|
|
|
} catch (e) {
|
|
|
|
assert.ok(e)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
2020-02-11 17:51:13 +01:00
|
|
|
it('should throw an error the lookup resolves to the zero x address', async function () {
|
2019-11-01 18:54:00 +01:00
|
|
|
const address = '0x8e5d75d60224ea0c33d0041e75de68b1c3cb6dd5'
|
|
|
|
const networkStore = {
|
|
|
|
subscribe: sinon.spy(),
|
|
|
|
}
|
|
|
|
const ens = new EnsController({
|
|
|
|
ens: {
|
|
|
|
reverse: sinon.stub().withArgs(address).returns('peaksignal.eth'),
|
2020-11-03 00:41:28 +01:00
|
|
|
lookup: sinon
|
|
|
|
.stub()
|
|
|
|
.withArgs('peaksignal.eth')
|
|
|
|
.returns(ZERO_X_ERROR_ADDRESS),
|
2019-11-01 18:54:00 +01:00
|
|
|
},
|
|
|
|
networkStore,
|
|
|
|
})
|
|
|
|
|
|
|
|
try {
|
|
|
|
await ens.reverseResolveAddress(address)
|
|
|
|
assert.fail('#reverseResolveAddress did not throw')
|
|
|
|
} catch (e) {
|
|
|
|
assert.ok(e)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|