update test for ENSSubDomainRegistry

This commit is contained in:
Barry Gitarts 2018-07-18 10:30:44 -04:00
parent c7b61f52ba
commit 94fcf57fc5
3 changed files with 425 additions and 418 deletions

View File

@ -6,7 +6,7 @@ exports.Test = (contractsConfig, afterDeploy) => {
var Controlled; var Controlled;
var accountsArr; var accountsArr;
before(function(done) { before(function(done) {
EmbarkSpec.deployAll(contractsConfig, async function(accounts) { config(contractsConfig, async function(accounts) {
Controlled = Contract; Controlled = Contract;
accountsArr = accounts; accountsArr = accounts;
await afterDeploy(accounts, Contract); await afterDeploy(accounts, Contract);
@ -26,4 +26,4 @@ exports.Test = (contractsConfig, afterDeploy) => {
assert(controller, accountsArr[1]); assert(controller, accountsArr[1]);
}); });
}); });
} }

View File

@ -11,7 +11,7 @@ contract('ENS', function () {
var contractsConfig = { var contractsConfig = {
"ENSRegistry": { }, "ENSRegistry": { },
}; };
EmbarkSpec.deployAll(contractsConfig, function(accounts) { config(contractsConfig, function(accounts) {
ens = ENSRegistry; ens = ENSRegistry;
accountsArr = accounts; accountsArr = accounts;
done() done()

View File

@ -1,454 +1,461 @@
const utils = require('../utils/testUtils.js'); const utils = require('../utils/testUtils.js');
const web3Utils = require('web3-utils'); const web3Utils = require('web3-utils');
const namehash = require('eth-ens-namehash'); const namehash = require('eth-ens-namehash');
const TestToken = require('Embark/contracts/TestToken');
const ENSRegistry = require('Embark/contracts/ENSRegistry');
const PublicResolver = require('Embark/contracts/PublicResolver');
const ENSSubdomainRegistry = require('Embark/contracts/ENSSubdomainRegistry');
var contractsConfig = {
"TestToken": {
},
"ENSRegistry": {
"onDeploy": [
"ENSRegistry.methods.setSubnodeOwner('0x0000000000000000000000000000000000000000000000000000000000000000', '0x4f5b812789fc606be1b3b16908db13fc7a9adf7ca72641f84d75b47069d3d7f0', web3.eth.defaultAccount).send()"
]
},
"PublicResolver": {
"args": [
"$ENSRegistry"
]
},
"ENSSubdomainRegistry": {
"args": [
"$TestToken",
"$ENSRegistry",
"$PublicResolver",
"0x0"
],
"onDeploy": [
"ENSRegistry.methods.setSubnodeOwner('0x93cdeb708b7545dc668eb9280176169d1c33cfd8ed6f04690a0bcc88a93fc4ae', '0xbd99f8d5e7f81d2d7c1da34b67a2bb3a94dd8c9b0ab40ddc077621b98405983b', ENSSubdomainRegistry.address).send()",
"ENSRegistry.methods.setSubnodeOwner('0x93cdeb708b7545dc668eb9280176169d1c33cfd8ed6f04690a0bcc88a93fc4ae', '0x7b4768a525e733422bf968587a91b4036e5176d36f44a9fb5b29d0bca03ab3a3', ENSSubdomainRegistry.address).send()"
]
},
"UpdatedENSSubdomainRegistry": {
"instanceOf" : "ENSSubdomainRegistry",
"args": [
"$TestToken",
"$ENSRegistry",
"$PublicResolver",
"$ENSSubdomainRegistry"
]
}
};
config({ contracts: contractsConfig });
contract('ENSSubdomainRegistry', function () { contract('ENSSubdomainRegistry', function () {
this.timeout(0); //this.timeout(0);
let domains = { let domains = {
free : { free : {
name: 'freedomain.eth', name: 'freedomain.eth',
price: 0, price: 0,
namehash: namehash.hash('freedomain.eth') namehash: namehash.hash('freedomain.eth')
}, },
paid : { paid : {
name: 'stateofus.eth', name: 'stateofus.eth',
price: 100000000, price: 100000000,
namehash: namehash.hash('stateofus.eth') namehash: namehash.hash('stateofus.eth')
}
} }
let ens; }
let accountsArr; let ens;
let accountsArr;
before(function(done) { before(function(done) {
var contractsConfig = { web3.eth.getAccounts().then(async (accounts) => {
"TestToken": { ens = ENSRegistry;
accountsArr = accounts;
}, await utils.increaseTime(1 * utils.timeUnits.days) //time cannot start zero
"ENSRegistry": { done();
"onDeploy": [ })
"ENSRegistry.methods.setSubnodeOwner('0x0000000000000000000000000000000000000000000000000000000000000000', '0x4f5b812789fc606be1b3b16908db13fc7a9adf7ca72641f84d75b47069d3d7f0', web3.eth.defaultAccount).send()" });
]
},
"PublicResolver": {
"args": [
"$ENSRegistry"
]
},
"ENSSubdomainRegistry": {
"args": [
"$TestToken",
"$ENSRegistry",
"$PublicResolver",
"0x0"
],
"onDeploy": [
"ENSRegistry.methods.setSubnodeOwner('0x93cdeb708b7545dc668eb9280176169d1c33cfd8ed6f04690a0bcc88a93fc4ae', '0xbd99f8d5e7f81d2d7c1da34b67a2bb3a94dd8c9b0ab40ddc077621b98405983b', ENSSubdomainRegistry.address).send()",
"ENSRegistry.methods.setSubnodeOwner('0x93cdeb708b7545dc668eb9280176169d1c33cfd8ed6f04690a0bcc88a93fc4ae', '0x7b4768a525e733422bf968587a91b4036e5176d36f44a9fb5b29d0bca03ab3a3', ENSSubdomainRegistry.address).send()"
]
},
"UpdatedENSSubdomainRegistry": {
"instanceOf" : "ENSSubdomainRegistry",
"args": [
"$TestToken",
"$ENSRegistry",
"$PublicResolver",
"$ENSSubdomainRegistry"
]
}
}; it('should add free domain', async () => {
EmbarkSpec.deployAll(contractsConfig, async (accounts) => { let result = await ENSSubdomainRegistry.methods.setDomainPrice(domains.free.namehash, 0).send({from: accountsArr[0]});
ens = ENSRegistry; assert.equal(result.events.DomainPrice.returnValues.price, domains.free.price);
accountsArr = accounts; assert.equal(result.events.DomainPrice.returnValues.namehash, domains.free.namehash);
await utils.increaseTime(1 * utils.timeUnits.days) //time cannot start zero result = await ENSSubdomainRegistry.methods.getPrice(domains.free.namehash).call()
done() assert.equal(result, 0);
}); result = await ENSSubdomainRegistry.methods.domains(domains.free.namehash).call()
});
it('should add free domain', async () => { assert(result.state, 1)
let result = await ENSSubdomainRegistry.methods.setDomainPrice(domains.free.namehash, 0).send({from: accountsArr[0]}); assert(result.price, domains.free.price)
assert.equal(result.events.DomainPrice.returnValues.price, domains.free.price); });
assert.equal(result.events.DomainPrice.returnValues.namehash, domains.free.namehash);
result = await ENSSubdomainRegistry.methods.getPrice(domains.free.namehash).call()
assert.equal(result, 0);
result = await ENSSubdomainRegistry.methods.domains(domains.free.namehash).call()
assert(result.state, 1)
assert(result.price, domains.free.price)
});
it('should add paid domain', async () => {
let initialPrice = 100
let result = await ENSSubdomainRegistry.methods.setDomainPrice(domains.paid.namehash, initialPrice).send({from: accountsArr[0]});
assert.equal(result.events.DomainPrice.returnValues.price, initialPrice);
assert.equal(result.events.DomainPrice.returnValues.namehash, domains.paid.namehash);
result = await ENSSubdomainRegistry.methods.getPrice(domains.paid.namehash).call()
assert.equal(result, initialPrice);
result = await ENSSubdomainRegistry.methods.domains(domains.free.namehash).call()
assert(result.state, 1)
assert(result.price, domains.paid.price)
});
it('should change paid domain price', async () => { it('should add paid domain', async () => {
let newPrice = domains.paid.price; let initialPrice = 100
let result = await ENSSubdomainRegistry.methods.updateDomainPrice(domains.paid.namehash, newPrice).send({from: accountsArr[0]}); let result = await ENSSubdomainRegistry.methods.setDomainPrice(domains.paid.namehash, initialPrice).send({from: accountsArr[0]});
assert.equal(result.events.DomainPrice.returnValues.price, newPrice, "Wrong price at event"); assert.equal(result.events.DomainPrice.returnValues.price, initialPrice);
assert.equal(result.events.DomainPrice.returnValues.namehash, domains.paid.namehash, "Wrong namehash at event"); assert.equal(result.events.DomainPrice.returnValues.namehash, domains.paid.namehash);
result = await ENSSubdomainRegistry.methods.getPrice(domains.paid.namehash).call() result = await ENSSubdomainRegistry.methods.getPrice(domains.paid.namehash).call()
assert.equal(result, newPrice, "Wrong return value at getPrice"); assert.equal(result, initialPrice);
result = await ENSSubdomainRegistry.methods.domains(domains.paid.namehash).call() result = await ENSSubdomainRegistry.methods.domains(domains.free.namehash).call()
assert(result.state, 1)
assert(result.state, 1) assert(result.price, domains.paid.price)
assert(result.price, newPrice) });
});
it('should change paid domain price', async () => {
let newPrice = domains.paid.price;
let result = await ENSSubdomainRegistry.methods.updateDomainPrice(domains.paid.namehash, newPrice).send({from: accountsArr[0]});
assert.equal(result.events.DomainPrice.returnValues.price, newPrice, "Wrong price at event");
assert.equal(result.events.DomainPrice.returnValues.namehash, domains.paid.namehash, "Wrong namehash at event");
result = await ENSSubdomainRegistry.methods.getPrice(domains.paid.namehash).call()
assert.equal(result, newPrice, "Wrong return value at getPrice");
result = await ENSSubdomainRegistry.methods.domains(domains.paid.namehash).call()
assert(result.state, 1)
assert(result.price, newPrice)
});
it('should register free subdomain', async () => { it('should register free subdomain', async () => {
let subdomain = 'alice'; let subdomain = 'alice';
let usernameHash = namehash.hash(subdomain + '.' + domains.free.name); let usernameHash = namehash.hash(subdomain + '.' + domains.free.name);
let registrant = accountsArr[1]; let registrant = accountsArr[1];
let result = await ENSSubdomainRegistry.methods.register( let result = await ENSSubdomainRegistry.methods.register(
web3Utils.sha3(subdomain), web3Utils.sha3(subdomain),
domains.free.namehash, domains.free.namehash,
utils.zeroAddress, utils.zeroAddress,
utils.zeroBytes32, utils.zeroBytes32,
utils.zeroBytes32, utils.zeroBytes32,
utils.zeroBytes32 utils.zeroBytes32
).send({from: registrant}); ).send({from: registrant});
//TODO: check events //TODO: check events
result = await ens.methods.owner(usernameHash).call() result = await ens.methods.owner(usernameHash).call()
assert.equal(result, registrant); assert.equal(result, registrant);
result = await ens.methods.resolver(usernameHash).call() result = await ens.methods.resolver(usernameHash).call()
assert.equal(result, utils.zeroAddress); assert.equal(result, utils.zeroAddress);
let accountBalance = await ENSSubdomainRegistry.methods.getAccountBalance(usernameHash).call(); let accountBalance = await ENSSubdomainRegistry.methods.getAccountBalance(usernameHash).call();
assert(accountBalance, 0, "Registry subdomain account balance wrong"); assert(accountBalance, 0, "Registry subdomain account balance wrong");
result = await ENSSubdomainRegistry.methods.getFundsOwner(usernameHash).call(); result = await ENSSubdomainRegistry.methods.getFundsOwner(usernameHash).call();
assert(result, registrant, "Backup owner not set"); assert(result, registrant, "Backup owner not set");
}); });
it('should register free address only resolver-defined subdomain', async () => { it('should register free address only resolver-defined subdomain', async () => {
let registrant = accountsArr[2]; let registrant = accountsArr[2];
let subdomain = 'bob'; let subdomain = 'bob';
let usernameHash = namehash.hash(subdomain + '.' + domains.free.name); let usernameHash = namehash.hash(subdomain + '.' + domains.free.name);
let result = await ENSSubdomainRegistry.methods.register( let result = await ENSSubdomainRegistry.methods.register(
web3Utils.sha3(subdomain), web3Utils.sha3(subdomain),
domains.free.namehash, domains.free.namehash,
registrant, registrant,
utils.zeroBytes32, utils.zeroBytes32,
utils.zeroBytes32, utils.zeroBytes32,
utils.zeroBytes32 utils.zeroBytes32
).send({from: registrant}); ).send({from: registrant});
//TODO: check events
result = await ens.methods.owner(usernameHash).call()
assert.equal(result, registrant, "Owner not set");
result = await ens.methods.resolver(usernameHash).call()
assert.equal(result, PublicResolver.address, "PublicResolver not set");
result = await PublicResolver.methods.addr(usernameHash).call()
assert.equal(result, registrant, "Resolved address not set");
result = await PublicResolver.methods.pubkey(usernameHash).call()
assert.equal(result[0], utils.zeroBytes32, "Unexpected resolved pubkey[0]");
assert.equal(result[1], utils.zeroBytes32, "Unexpected resolved pubkey[1]");
});
it('should register free status contact code only resolver-defined subdomain', async () => { //TODO: check events
let registrant = accountsArr[2];
let subdomain = 'bob2';
let usernameHash = namehash.hash(subdomain + '.' + domains.free.name);
let contactCode = '0x04dbb31252d9bddb4e4d362c7b9c80cba74732280737af97971f42ccbdc716f3f3efb1db366880e52d09b1bfd59842e833f3004088892b7d14b9ce9e957cea9a82';
let result = await ENSSubdomainRegistry.methods.register(
web3Utils.sha3(subdomain),
domains.free.namehash,
registrant,
utils.zeroBytes32,
utils.zeroBytes32,
contactCode
).send({from: registrant});
result = await ens.methods.owner(usernameHash).call() result = await ens.methods.owner(usernameHash).call()
assert.equal(result, registrant, "Owner not set"); assert.equal(result, registrant, "Owner not set");
result = await ens.methods.resolver(usernameHash).call() result = await ens.methods.resolver(usernameHash).call()
assert.equal(result, PublicResolver.address, "PublicResolver not set"); assert.equal(result, PublicResolver.address, "PublicResolver not set");
result = await PublicResolver.methods.text(usernameHash, "statusAccount").call() result = await PublicResolver.methods.addr(usernameHash).call()
assert.equal(result, contactCode, "Resolved contact code not set"); assert.equal(result, registrant, "Resolved address not set");
result = await PublicResolver.methods.pubkey(usernameHash).call() result = await PublicResolver.methods.pubkey(usernameHash).call()
assert.equal(result[0], utils.zeroBytes32, "Unexpected resolved pubkey[0]"); assert.equal(result[0], utils.zeroBytes32, "Unexpected resolved pubkey[0]");
assert.equal(result[1], utils.zeroBytes32, "Unexpected resolved pubkey[1]"); assert.equal(result[1], utils.zeroBytes32, "Unexpected resolved pubkey[1]");
});
it('should register free status contact code only resolver-defined subdomain', async () => {
let registrant = accountsArr[2];
let subdomain = 'bob2';
let usernameHash = namehash.hash(subdomain + '.' + domains.free.name);
let contactCode = '0x04dbb31252d9bddb4e4d362c7b9c80cba74732280737af97971f42ccbdc716f3f3efb1db366880e52d09b1bfd59842e833f3004088892b7d14b9ce9e957cea9a82';
let result = await ENSSubdomainRegistry.methods.register(
web3Utils.sha3(subdomain),
domains.free.namehash,
registrant,
utils.zeroBytes32,
utils.zeroBytes32,
contactCode
).send({from: registrant});
result = await ens.methods.owner(usernameHash).call()
assert.equal(result, registrant, "Owner not set");
result = await ens.methods.resolver(usernameHash).call()
assert.equal(result, PublicResolver.address, "PublicResolver not set");
result = await PublicResolver.methods.text(usernameHash, "statusAccount").call()
assert.equal(result, contactCode, "Resolved contact code not set");
result = await PublicResolver.methods.pubkey(usernameHash).call()
assert.equal(result[0], utils.zeroBytes32, "Unexpected resolved pubkey[0]");
assert.equal(result[1], utils.zeroBytes32, "Unexpected resolved pubkey[1]");
}); });
it('should register free pubkey only resolver-defined subdomain', async () => { it('should register free pubkey only resolver-defined subdomain', async () => {
let subdomain = 'carlos'; let subdomain = 'carlos';
let registrant = accountsArr[3]; let registrant = accountsArr[3];
let usernameHash = namehash.hash(subdomain + '.' + domains.free.name); let usernameHash = namehash.hash(subdomain + '.' + domains.free.name);
let pubkey = [web3Utils.sha3("0"), web3Utils.sha3("1")]; let pubkey = [web3Utils.sha3("0"), web3Utils.sha3("1")];
let result = await ENSSubdomainRegistry.methods.register( let result = await ENSSubdomainRegistry.methods.register(
web3Utils.sha3(subdomain), web3Utils.sha3(subdomain),
domains.free.namehash, domains.free.namehash,
utils.zeroAddress, utils.zeroAddress,
pubkey[0], pubkey[0],
pubkey[1], pubkey[1],
utils.zeroBytes32 utils.zeroBytes32
).send({from: registrant}); ).send({from: registrant});
//TODO: check events //TODO: check events
result = await ens.methods.owner(usernameHash).call() result = await ens.methods.owner(usernameHash).call()
assert.equal(result, registrant, "Owner not set"); assert.equal(result, registrant, "Owner not set");
result = await ens.methods.resolver(usernameHash).call() result = await ens.methods.resolver(usernameHash).call()
assert.equal(result, PublicResolver.address, "PublicResolver not set"); assert.equal(result, PublicResolver.address, "PublicResolver not set");
result = await PublicResolver.methods.addr(usernameHash).call() result = await PublicResolver.methods.addr(usernameHash).call()
assert.equal(result, utils.zeroAddress, "Resolved address unexpectedlly set"); assert.equal(result, utils.zeroAddress, "Resolved address unexpectedlly set");
result = await PublicResolver.methods.pubkey(usernameHash).call() result = await PublicResolver.methods.pubkey(usernameHash).call()
assert.equal(result[0], pubkey[0], "Resolved pubkey[0] not set"); assert.equal(result[0], pubkey[0], "Resolved pubkey[0] not set");
assert.equal(result[1], pubkey[1], "Resolved pubkey[1] not set"); assert.equal(result[1], pubkey[1], "Resolved pubkey[1] not set");
}); });
it('should register free full resolver-defined subdomain', async () => {
let registrant = accountsArr[4];
let subdomain = 'david';
let usernameHash = namehash.hash(subdomain + '.' + domains.free.name);
let pubkey = [web3Utils.sha3("2"), web3Utils.sha3("3")];
let result = await ENSSubdomainRegistry.methods.register(
web3Utils.sha3(subdomain),
domains.free.namehash,
registrant,
pubkey[0],
pubkey[1],
utils.zeroBytes32
).send({from: registrant});
//TODO: check events
result = await ens.methods.owner(usernameHash).call()
assert.equal(result, registrant, "Owner not set");
result = await ens.methods.resolver(usernameHash).call()
assert.equal(result, PublicResolver.address, "PublicResolver not set");
result = await PublicResolver.methods.addr(usernameHash).call()
assert.equal(result, registrant, "Resolved address not set");
result = await PublicResolver.methods.pubkey(usernameHash).call()
assert.equal(result[0], pubkey[0], "Resolved pubkey[0] not set");
assert.equal(result[1], pubkey[1], "Resolved pubkey[1] not set");
});
it('should release free subdomain', async () => {
let registrant = accountsArr[6];
let subdomain = 'frank';
let usernameHash = namehash.hash(subdomain + '.' + domains.free.name);
await ENSSubdomainRegistry.methods.register(
web3Utils.sha3(subdomain),
domains.free.namehash,
utils.zeroAddress,
utils.zeroBytes32,
utils.zeroBytes32,
utils.zeroBytes32
).send({from: registrant});
let releaseDelay = await ENSSubdomainRegistry.methods.releaseDelay().call();
await utils.increaseTime(releaseDelay)
let initialRegistrantBalance = await TestToken.methods.balanceOf(registrant).call();
let initialRegistryBalance = await TestToken.methods.balanceOf(ENSSubdomainRegistry.address).call();
let result = await ENSSubdomainRegistry.methods.release(
web3Utils.sha3(subdomain),
domains.free.namehash
).send({from: registrant});
//TODO: check events
result = await ens.methods.owner(usernameHash).call()
assert.equal(result, utils.zeroAddress, "Not released name ownship");
let finalRegistrantBalance = await TestToken.methods.balanceOf(registrant).call();
assert(finalRegistrantBalance, initialRegistrantBalance, "Registrant token balance unexpectectly changed")
let finalRegistryBalance = await TestToken.methods.balanceOf(ENSSubdomainRegistry.address).call();
assert(finalRegistryBalance, initialRegistryBalance, "Registry token balance unexpectectly changed")
});
it('should register empty subdomain with token cost', async () => {
let registrant = accountsArr[5];
let subdomain = 'erin';
let usernameHash = namehash.hash(subdomain + '.' + domains.paid.name);
let domainPrice = await ENSSubdomainRegistry.methods.getPrice(domains.paid.namehash).call()
await TestToken.methods.mint(domainPrice).send({from: registrant});
let initialRegistrantBalance = await TestToken.methods.balanceOf(registrant).call();
let initialRegistryBalance = await TestToken.methods.balanceOf(ENSSubdomainRegistry.address).call();
await TestToken.methods.approve(ENSSubdomainRegistry.address, domainPrice).send({from: registrant});
let result = await ENSSubdomainRegistry.methods.register(
web3Utils.sha3(subdomain),
domains.paid.namehash,
utils.zeroAddress,
utils.zeroBytes32,
utils.zeroBytes32,
utils.zeroBytes32
).send({from: registrant});
//TODO: check events
result = await ens.methods.owner(namehash.hash(subdomain + '.' + domains.paid.name)).call()
assert.equal(result, registrant);
result = await ens.methods.resolver(namehash.hash(subdomain + '.' + domains.paid.name)).call()
assert.equal(result, utils.zeroAddress);
let accountBalance = await ENSSubdomainRegistry.methods.getAccountBalance(usernameHash).call();
assert(accountBalance, domainPrice, "Registry subdomain account balance wrong");
let finalRegistrantBalance = await TestToken.methods.balanceOf(registrant).call();
assert(finalRegistrantBalance, +initialRegistrantBalance-domainPrice, "User final balance wrong")
let finalRegistryBalance = await TestToken.methods.balanceOf(ENSSubdomainRegistry.address).call();
assert(finalRegistryBalance, +finalRegistryBalance+domainPrice, "Registry final balance wrong")
});
it('should release subdomain with cost', async () => {; it('should register free full resolver-defined subdomain', async () => {
let registrant = accountsArr[6]; let registrant = accountsArr[4];
let subdomain = 'frank'; let subdomain = 'david';
let usernameHash = namehash.hash(subdomain + '.' + domains.paid.name); let usernameHash = namehash.hash(subdomain + '.' + domains.free.name);
let labelHash = web3Utils.sha3(subdomain); let pubkey = [web3Utils.sha3("2"), web3Utils.sha3("3")];
let domainPrice = await ENSSubdomainRegistry.methods.getPrice(domains.paid.namehash).call()
await TestToken.methods.mint(domainPrice).send({from: registrant});
await TestToken.methods.approve(ENSSubdomainRegistry.address, domainPrice).send({from: registrant});
let result = await ENSSubdomainRegistry.methods.register(
labelHash,
domains.paid.namehash,
utils.zeroAddress,
utils.zeroBytes32,
utils.zeroBytes32,
utils.zeroBytes32
).send({from: registrant});
//TODO: check events let result = await ENSSubdomainRegistry.methods.register(
web3Utils.sha3(subdomain),
let releaseDelay = await ENSSubdomainRegistry.methods.releaseDelay().call(); domains.free.namehash,
utils.increaseTime(releaseDelay) registrant,
pubkey[0],
let initialAccountBalance = await ENSSubdomainRegistry.methods.getAccountBalance(usernameHash).call(); pubkey[1],
let initialRegistrantBalance = await TestToken.methods.balanceOf(registrant).call(); utils.zeroBytes32
let initialRegistryBalance = await TestToken.methods.balanceOf(ENSSubdomainRegistry.address).call(); ).send({from: registrant});
await ENSSubdomainRegistry.methods.release(
web3Utils.sha3(subdomain),
domains.paid.namehash
).send({from: registrant});
let finalAccountBalance = await ENSSubdomainRegistry.methods.getAccountBalance(usernameHash).call();
assert(finalAccountBalance, 0, "Final balance didnt zeroed");
let finalRegistrantBalance = await TestToken.methods.balanceOf(registrant).call();
assert(finalRegistrantBalance, +initialRegistrantBalance+initialAccountBalance, "Releaser token balance didnt increase")
let finalRegistryBalance = await TestToken.methods.balanceOf(ENSSubdomainRegistry.address).call();
assert(finalRegistryBalance, +initialRegistryBalance-initialAccountBalance, "Registry token balance didnt decrease")
});
it('should release transfered subdomain with cost', async () => { //TODO: check events
let registrant = accountsArr[7];
let subdomain = 'grace';
let usernameHash = namehash.hash(subdomain + '.' + domains.paid.name);
let labelHash = web3Utils.sha3(subdomain);
let newOwner = accountsArr[8];
let domainPrice = await ENSSubdomainRegistry.methods.getPrice(domains.paid.namehash).call() result = await ens.methods.owner(usernameHash).call()
await TestToken.methods.mint(domainPrice).send({from: registrant}); assert.equal(result, registrant, "Owner not set");
await TestToken.methods.approve(ENSSubdomainRegistry.address, domainPrice).send({from: registrant}); result = await ens.methods.resolver(usernameHash).call()
await ENSSubdomainRegistry.methods.register( assert.equal(result, PublicResolver.address, "PublicResolver not set");
labelHash, result = await PublicResolver.methods.addr(usernameHash).call()
domains.paid.namehash, assert.equal(result, registrant, "Resolved address not set");
utils.zeroAddress, result = await PublicResolver.methods.pubkey(usernameHash).call()
utils.zeroBytes32, assert.equal(result[0], pubkey[0], "Resolved pubkey[0] not set");
utils.zeroBytes32, assert.equal(result[1], pubkey[1], "Resolved pubkey[1] not set");
utils.zeroBytes32 });
).send({from: registrant});
await ens.methods.setOwner(usernameHash, newOwner).send({from: registrant});
let releaseDelay = await ENSSubdomainRegistry.methods.releaseDelay().call(); it('should release free subdomain', async () => {
await utils.increaseTime(releaseDelay) let registrant = accountsArr[6];
let subdomain = 'frank';
let usernameHash = namehash.hash(subdomain + '.' + domains.free.name);
let initialAccountBalance = await ENSSubdomainRegistry.methods.getAccountBalance(usernameHash).call(); await ENSSubdomainRegistry.methods.register(
let initialRegistrantBalance = await TestToken.methods.balanceOf(newOwner).call(); web3Utils.sha3(subdomain),
let initialRegistryBalance = await TestToken.methods.balanceOf(ENSSubdomainRegistry.address).call(); domains.free.namehash,
utils.zeroAddress,
let result = await ENSSubdomainRegistry.methods.release( utils.zeroBytes32,
web3Utils.sha3(subdomain), utils.zeroBytes32,
domains.paid.namehash utils.zeroBytes32
).send({from: newOwner}); ).send({from: registrant});
let releaseDelay = await ENSSubdomainRegistry.methods.releaseDelay().call();
//TODO: check events await utils.increaseTime(releaseDelay)
let finalAccountBalance = await ENSSubdomainRegistry.methods.getAccountBalance(usernameHash).call();
assert(finalAccountBalance, 0, "Final balance didnt zeroed");
let finalRegistrantBalance = await TestToken.methods.balanceOf(newOwner).call();
assert(finalRegistrantBalance, +initialRegistrantBalance+initialAccountBalance, "New owner token balance didnt increase")
let finalRegistryBalance = await TestToken.methods.balanceOf(ENSSubdomainRegistry.address).call();
assert(finalRegistryBalance, +initialRegistryBalance-initialAccountBalance, "Registry token balance didnt decrease")
});
it('should update subdomain funds owner', async () => { let initialRegistrantBalance = await TestToken.methods.balanceOf(registrant).call();
let subdomain = 'heidi'; let initialRegistryBalance = await TestToken.methods.balanceOf(ENSSubdomainRegistry.address).call();
let labelHash = web3Utils.sha3(subdomain);
let registrant = accountsArr[8];
let newOwner = accountsArr[9];
let usernameHash = namehash.hash(subdomain + '.' + domains.paid.name);
let domainPrice = await ENSSubdomainRegistry.methods.getPrice(domains.paid.namehash).call()
await TestToken.methods.mint(domainPrice).send({from: registrant});
await TestToken.methods.approve(ENSSubdomainRegistry.address, domainPrice).send({from: registrant});
await ENSSubdomainRegistry.methods.register(
labelHash,
domains.paid.namehash,
utils.zeroAddress,
utils.zeroBytes32,
utils.zeroBytes32,
utils.zeroBytes32
).send({from: registrant});
await ens.methods.setOwner(usernameHash, newOwner).send({from: registrant});
let result = await ENSSubdomainRegistry.methods.updateFundsOwner( let result = await ENSSubdomainRegistry.methods.release(
labelHash, web3Utils.sha3(subdomain),
domains.paid.namehash domains.free.namehash
).send({from: newOwner}); ).send({from: registrant});
//TODO: check events //TODO: check events
result = await ENSSubdomainRegistry.methods.getFundsOwner(usernameHash).call(); result = await ens.methods.owner(usernameHash).call()
assert(result, newOwner, "Backup owner not updated"); assert.equal(result, utils.zeroAddress, "Not released name ownship");
}); let finalRegistrantBalance = await TestToken.methods.balanceOf(registrant).call();
assert(finalRegistrantBalance, initialRegistrantBalance, "Registrant token balance unexpectectly changed")
let finalRegistryBalance = await TestToken.methods.balanceOf(ENSSubdomainRegistry.address).call();
assert(finalRegistryBalance, initialRegistryBalance, "Registry token balance unexpectectly changed")
});
it('should register empty subdomain with token cost', async () => {
let registrant = accountsArr[5];
let subdomain = 'erin';
let usernameHash = namehash.hash(subdomain + '.' + domains.paid.name);
let domainPrice = await ENSSubdomainRegistry.methods.getPrice(domains.paid.namehash).call()
await TestToken.methods.mint(domainPrice).send({from: registrant});
let initialRegistrantBalance = await TestToken.methods.balanceOf(registrant).call();
let initialRegistryBalance = await TestToken.methods.balanceOf(ENSSubdomainRegistry.address).call();
await TestToken.methods.approve(ENSSubdomainRegistry.address, domainPrice).send({from: registrant});
let result = await ENSSubdomainRegistry.methods.register(
web3Utils.sha3(subdomain),
domains.paid.namehash,
utils.zeroAddress,
utils.zeroBytes32,
utils.zeroBytes32,
utils.zeroBytes32
).send({from: registrant});
//TODO: check events
result = await ens.methods.owner(namehash.hash(subdomain + '.' + domains.paid.name)).call()
assert.equal(result, registrant);
result = await ens.methods.resolver(namehash.hash(subdomain + '.' + domains.paid.name)).call()
assert.equal(result, utils.zeroAddress);
let accountBalance = await ENSSubdomainRegistry.methods.getAccountBalance(usernameHash).call();
assert(accountBalance, domainPrice, "Registry subdomain account balance wrong");
let finalRegistrantBalance = await TestToken.methods.balanceOf(registrant).call();
assert(finalRegistrantBalance, +initialRegistrantBalance-domainPrice, "User final balance wrong")
let finalRegistryBalance = await TestToken.methods.balanceOf(ENSSubdomainRegistry.address).call();
assert(finalRegistryBalance, +finalRegistryBalance+domainPrice, "Registry final balance wrong")
});
it('should move domain to new registry and migrate', async () => { it('should release subdomain with cost', async () => {;
let price = await ENSSubdomainRegistry.methods.getPrice(domains.paid.namehash).call() let registrant = accountsArr[6];
let result = await ENSSubdomainRegistry.methods.moveDomain(UpdatedENSSubdomainRegistry.address, domains.paid.namehash).send(); let subdomain = 'frank';
let usernameHash = namehash.hash(subdomain + '.' + domains.paid.name);
//TODO: check events let labelHash = web3Utils.sha3(subdomain);
let domainPrice = await ENSSubdomainRegistry.methods.getPrice(domains.paid.namehash).call()
result = await ens.methods.owner(domains.paid.namehash).call() await TestToken.methods.mint(domainPrice).send({from: registrant});
assert(result, UpdatedENSSubdomainRegistry.address, "domain ownership not moved correctly") await TestToken.methods.approve(ENSSubdomainRegistry.address, domainPrice).send({from: registrant});
result = await UpdatedENSSubdomainRegistry.methods.getPrice(domains.paid.namehash).call() let result = await ENSSubdomainRegistry.methods.register(
assert(result, price, "updated registry didnt migrated price") labelHash,
}); domains.paid.namehash,
utils.zeroAddress,
utils.zeroBytes32,
utils.zeroBytes32,
utils.zeroBytes32
).send({from: registrant});
xit('should release moved free subdomain account balance by funds owner', async () => { //TODO: check events
});
xit('should migrate free subdomain to new registry by funds owner', async () => { let releaseDelay = await ENSSubdomainRegistry.methods.releaseDelay().call();
utils.increaseTime(releaseDelay)
});
xit('should release moved paid subdomain account balance by funds owner', async () => { let initialAccountBalance = await ENSSubdomainRegistry.methods.getAccountBalance(usernameHash).call();
let initialRegistrantBalance = await TestToken.methods.balanceOf(registrant).call();
}); let initialRegistryBalance = await TestToken.methods.balanceOf(ENSSubdomainRegistry.address).call();
await ENSSubdomainRegistry.methods.release(
web3Utils.sha3(subdomain),
domains.paid.namehash
).send({from: registrant});
let finalAccountBalance = await ENSSubdomainRegistry.methods.getAccountBalance(usernameHash).call();
assert(finalAccountBalance, 0, "Final balance didnt zeroed");
let finalRegistrantBalance = await TestToken.methods.balanceOf(registrant).call();
assert(finalRegistrantBalance, +initialRegistrantBalance+initialAccountBalance, "Releaser token balance didnt increase")
let finalRegistryBalance = await TestToken.methods.balanceOf(ENSSubdomainRegistry.address).call();
assert(finalRegistryBalance, +initialRegistryBalance-initialAccountBalance, "Registry token balance didnt decrease")
});
it('should release transfered subdomain with cost', async () => {
let registrant = accountsArr[7];
let subdomain = 'grace';
let usernameHash = namehash.hash(subdomain + '.' + domains.paid.name);
let labelHash = web3Utils.sha3(subdomain);
let newOwner = accountsArr[8];
let domainPrice = await ENSSubdomainRegistry.methods.getPrice(domains.paid.namehash).call()
await TestToken.methods.mint(domainPrice).send({from: registrant});
await TestToken.methods.approve(ENSSubdomainRegistry.address, domainPrice).send({from: registrant});
await ENSSubdomainRegistry.methods.register(
labelHash,
domains.paid.namehash,
utils.zeroAddress,
utils.zeroBytes32,
utils.zeroBytes32,
utils.zeroBytes32
).send({from: registrant});
await ens.methods.setOwner(usernameHash, newOwner).send({from: registrant});
let releaseDelay = await ENSSubdomainRegistry.methods.releaseDelay().call();
await utils.increaseTime(releaseDelay)
let initialAccountBalance = await ENSSubdomainRegistry.methods.getAccountBalance(usernameHash).call();
let initialRegistrantBalance = await TestToken.methods.balanceOf(newOwner).call();
let initialRegistryBalance = await TestToken.methods.balanceOf(ENSSubdomainRegistry.address).call();
let result = await ENSSubdomainRegistry.methods.release(
web3Utils.sha3(subdomain),
domains.paid.namehash
).send({from: newOwner});
//TODO: check events
let finalAccountBalance = await ENSSubdomainRegistry.methods.getAccountBalance(usernameHash).call();
assert(finalAccountBalance, 0, "Final balance didnt zeroed");
let finalRegistrantBalance = await TestToken.methods.balanceOf(newOwner).call();
assert(finalRegistrantBalance, +initialRegistrantBalance+initialAccountBalance, "New owner token balance didnt increase")
let finalRegistryBalance = await TestToken.methods.balanceOf(ENSSubdomainRegistry.address).call();
assert(finalRegistryBalance, +initialRegistryBalance-initialAccountBalance, "Registry token balance didnt decrease")
});
it('should update subdomain funds owner', async () => {
let subdomain = 'heidi';
let labelHash = web3Utils.sha3(subdomain);
let registrant = accountsArr[8];
let newOwner = accountsArr[9];
let usernameHash = namehash.hash(subdomain + '.' + domains.paid.name);
let domainPrice = await ENSSubdomainRegistry.methods.getPrice(domains.paid.namehash).call()
await TestToken.methods.mint(domainPrice).send({from: registrant});
await TestToken.methods.approve(ENSSubdomainRegistry.address, domainPrice).send({from: registrant});
await ENSSubdomainRegistry.methods.register(
labelHash,
domains.paid.namehash,
utils.zeroAddress,
utils.zeroBytes32,
utils.zeroBytes32,
utils.zeroBytes32
).send({from: registrant});
await ens.methods.setOwner(usernameHash, newOwner).send({from: registrant});
let result = await ENSSubdomainRegistry.methods.updateFundsOwner(
labelHash,
domains.paid.namehash
).send({from: newOwner});
//TODO: check events
result = await ENSSubdomainRegistry.methods.getFundsOwner(usernameHash).call();
assert(result, newOwner, "Backup owner not updated");
});
it('should move domain to new registry and migrate', async () => {
let price = await ENSSubdomainRegistry.methods.getPrice(domains.paid.namehash).call()
let result = await ENSSubdomainRegistry.methods.moveDomain(UpdatedENSSubdomainRegistry.address, domains.paid.namehash).send();
//TODO: check events
result = await ens.methods.owner(domains.paid.namehash).call()
assert(result, UpdatedENSSubdomainRegistry.address, "domain ownership not moved correctly")
result = await UpdatedENSSubdomainRegistry.methods.getPrice(domains.paid.namehash).call()
assert(result, price, "updated registry didnt migrated price")
});
xit('should release moved free subdomain account balance by funds owner', async () => {
});
xit('should migrate free subdomain to new registry by funds owner', async () => {
});
xit('should release moved paid subdomain account balance by funds owner', async () => {
});
xit('should migrate paid subdomain to new registry by funds owner', async () => {
});
xit('should migrate paid subdomain to new registry by funds owner', async () => {
});
}); });