snt-gas-relay/test/identity.js

479 lines
18 KiB
JavaScript
Raw Normal View History

const TestUtils = require("../utils/testUtils.js");
const idUtils = require('../utils/identityUtils.js');
describe("Identity", function() {
this.timeout(0);
let accounts;
2018-05-13 05:46:39 -03:00
before( function(done) {
this.timeout(0);
2018-03-14 10:31:12 -04:00
EmbarkSpec.deployAll({
2018-05-13 05:46:39 -03:00
"Identity": {
args: [
[],[],[],0,0,0
]
},
2018-03-14 10:31:12 -04:00
"TestContract": {}
}, (_accounts) => {
accounts = _accounts;
done();
});
});
describe("Identity()", () => {
it("initialize with msg.sender as management key", async () => {
2018-05-13 05:46:39 -03:00
var result = await Identity.methods.keyHasPurpose(web3.utils.soliditySha3(accounts[0]), idUtils.purposes.MANAGEMENT).call()
assert.equal(
2018-05-13 05:46:39 -03:00
result,
true,
Identity.address + ".keyHasPurpose("+web3.utils.soliditySha3(accounts[0])+","+idUtils.purposes.MANAGEMENT+") is not MANAGEMENT_KEY");
});
2018-05-13 05:46:39 -03:00
});
describe("addKey(address _key, uint256 _type)", () => {
it("MANAGEMENT_KEY add a new address as ACTION_KEY", async () => {
2018-05-13 05:46:39 -03:00
assert.equal(
await Identity.methods.keyHasPurpose(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.ACTION).call(),
false);
await Identity.methods.execute(
Identity.address,
0,
2018-05-13 05:46:39 -03:00
idUtils.encode.addKey(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.ACTION, idUtils.types.ADDRESS)
).send({from: accounts[0]});
assert.equal(
2018-05-13 05:46:39 -03:00
await Identity.methods.keyHasPurpose(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.ACTION).call(),
true);
});
it("should not add key by non manager", async () => {
try {
await Identity.methods.execute(
Identity.address,
0,
2018-05-13 05:46:39 -03:00
idUtils.encode.addKey(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.MANAGEMENT, idUtils.types.ADDRESS))
.send({from: accounts[2]});
assert.fail('should have reverted before');
} catch(error) {
TestUtils.assertJump(error);
}
assert.equal(
2018-05-13 05:46:39 -03:00
await Identity.methods.keyHasPurpose(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.MANAGEMENT).call(),
false)
});
it("should not add key type 1 by actor", async () => {
await Identity.methods.execute(
Identity.address,
0,
2018-05-13 05:46:39 -03:00
idUtils.encode.addKey(web3.utils.soliditySha3(accounts[2]), idUtils.purposes.ACTION, idUtils.types.ADDRESS))
.send({from: accounts[0]});
try {
await Identity.methods.execute(
Identity.address,
0,
2018-05-13 05:46:39 -03:00
idUtils.encode.addKey(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.MANAGEMENT, idUtils.types.ADDRESS))
.send({from: accounts[2]});
assert.fail('should have reverted before');
} catch(error) {
TestUtils.assertJump(error);
}
assert.equal(
2018-05-13 05:46:39 -03:00
await Identity.methods.keyHasPurpose(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.MANAGEMENT).call(),
false);
});
2018-05-13 05:46:39 -03:00
xit("fire KeyAdded(address indexed key, uint256 indexed type)", async () => {
let receipt = await Identity.methods.execute(
Identity.address,
0,
2018-05-13 05:46:39 -03:00
idUtils.encode.addKey(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.MANAGEMENT, idUtils.types.ADDRESS))
.send({from: accounts[0]});
const keyAdded = TestUtils.eventValues(receipt, "KeyAdded");
2018-05-13 05:46:39 -03:00
assert(keyAdded.key, web3.utils.soliditySha3(accounts[1]), "Key is not correct")
assert(keyAdded.keyType, idUtils.types.ADDRESS, "Type is not correct")
});
});
describe("removeKey(address _key, uint256 _type)", () => {
it("MANAGEMENT_KEY should remove a key", async () => {
await Identity.methods.execute(
Identity.address,
0,
2018-05-13 05:46:39 -03:00
idUtils.encode.addKey(web3.utils.soliditySha3(accounts[5]), idUtils.purposes.MANAGEMENT, idUtils.types.ADDRESS))
.send({from: accounts[0]});
await Identity.methods.execute(
Identity.address,
0,
2018-05-13 05:46:39 -03:00
idUtils.encode.removeKey(web3.utils.soliditySha3(accounts[5]), idUtils.purposes.MANAGEMENT))
.send({from: accounts[0]});
assert.equal(
2018-05-13 05:46:39 -03:00
await Identity.methods.keyHasPurpose(web3.utils.soliditySha3(accounts[5]), idUtils.purposes.MANAGEMENT).call(),
false,
Identity.address+".keyHasPurpose("+web3.utils.soliditySha3(accounts[5])+","+idUtils.purposes.MANAGEMENT+") is not false")
});
it("other key should not remove a key", async () => {
await Identity.methods.execute(
Identity.address,
0,
2018-05-13 05:46:39 -03:00
idUtils.encode.addKey(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.MANAGEMENT, idUtils.types.ADDRESS))
.send({from: accounts[0]});
try {
await Identity.methods.execute(
Identity.address,
0,
2018-05-13 05:46:39 -03:00
idUtils.encode.removeKey(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.MANAGEMENT))
.send({from: accounts[2]});
assert.fail('should have reverted before');
} catch(error) {
TestUtils.assertJump(error);
}
assert.equal(
2018-05-13 05:46:39 -03:00
await Identity.methods.keyHasPurpose(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.MANAGEMENT).call(),
true,
Identity.address+".keyHasPurpose("+accounts[1]+","+idUtils.purposes.MANAGEMENT+") is not true")
});
it("actor key should not remove key", async () => {
await Identity.methods.execute(
Identity.address,
0,
2018-05-13 05:46:39 -03:00
idUtils.encode.addKey(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.ACTION, idUtils.types.ADDRESS))
.send({from: accounts[0]});
await Identity.methods.execute(
Identity.address,
0,
2018-05-13 05:46:39 -03:00
idUtils.encode.addKey(web3.utils.soliditySha3(accounts[2]), idUtils.purposes.ACTION, idUtils.types.ADDRESS))
.send({from: accounts[0]});
try {
await Identity.methods.execute(
Identity.address,
0,
2018-05-13 05:46:39 -03:00
idUtils.encode.removeKey(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.ACTION))
.send({from: accounts[2]});
assert.fail('should have reverted before');
} catch(error) {
TestUtils.assertJump(error);
}
assert.equal(
2018-05-13 05:46:39 -03:00
await Identity.methods.keyHasPurpose(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.ACTION).call(),
true,
Identity.address+".keyHasPurpose("+accounts[1]+","+idUtils.purposes.ACTION+") is not true")
});
it("MANAGEMENT_KEY should not remove itself MANAGEMENT_KEY when there is no other MANAGEMENT_KEY", async () => {
await Identity.methods.execute(
Identity.address,
0,
2018-05-13 05:46:39 -03:00
idUtils.encode.removeKey(web3.utils.soliditySha3(accounts[0]), idUtils.purposes.MANAGEMENT))
.send({from: accounts[0]});
assert.equal(
2018-05-13 05:46:39 -03:00
await Identity.methods.keyHasPurpose(web3.utils.soliditySha3(accounts[0]), idUtils.purposes.MANAGEMENT).call(),
true,
Identity.address+".keyHasPurpose("+web3.utils.soliditySha3(accounts[0])+") is not true")
});
2018-05-13 05:46:39 -03:00
xit("fire KeyRemoved(address indexed key, uint256 indexed type)", async () => {
await Identity.methods.execute(
Identity.address,
0,
2018-05-13 05:46:39 -03:00
idUtils.encode.addKey(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.ACTION, idUtils.types.ADDRESS))
.send({from: accounts[0]});
let receipt = await Identity.methods.execute(
Identity.address,
0,
2018-05-13 05:46:39 -03:00
idUtils.encode.removeKey(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.ACTION))
.send({from: accounts[0]});
2018-03-14 10:31:12 -04:00
const keyRemoved = TestUtils.eventValues(receipt, "KeyRemoved");
2018-05-13 05:46:39 -03:00
assert(keyRemoved.key, web3.utils.soliditySha3(accounts[1]), "Key is not correct");
assert(keyRemoved.keyType, idUtils.types.ADDRESS, "Type is not correct");
});
});
2018-03-14 10:31:12 -04:00
2018-05-13 05:46:39 -03:00
describe("keyHasPurpose(address _key)", () => {
2018-05-13 05:46:39 -03:00
it("should get type 3 after addKey type 3", async () => {
assert.equal(
2018-05-13 05:46:39 -03:00
await Identity.methods.keyHasPurpose(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.CLAIM_SIGNER).call(),
false,
Identity.address+".keyHasPurpose("+accounts[1]+","+idUtils.purposes.CLAIM_SIGNER+") is not false")
2018-03-14 10:31:12 -04:00
await Identity.methods.execute(
Identity.address,
0,
2018-05-13 05:46:39 -03:00
idUtils.encode.addKey(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.CLAIM_SIGNER, idUtils.types.ADDRESS))
2018-03-14 10:31:12 -04:00
.send({from: accounts[0]});
assert.equal(
2018-05-13 05:46:39 -03:00
await Identity.methods.keyHasPurpose(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.CLAIM_SIGNER).call(),
true,
Identity.address+".keyHasPurpose("+accounts[1]+","+idUtils.purposes.CLAIM_SIGNER+") is not true")
});
2018-05-13 05:46:39 -03:00
});
/*
describe("getKeysByType(uint256 _type)", () => {
it("at initialization", async () => {
});
it("after addKey", async () => {
});
it("after removeKey", async () => {
});
});
*/
2018-03-14 10:31:12 -04:00
describe("execute(address _to, uint256 _value, bytes _data)", () => {
let functionPayload;
2018-05-13 05:46:39 -03:00
xit("Identity should receive ether", async() => {
2018-03-14 10:31:12 -04:00
const amountToSend = web3.utils.toWei('0.05', "ether");
2018-03-14 15:42:04 -04:00
let idBalance0 = await web3.eth.getBalance(Identity.address);
2018-03-14 10:31:12 -04:00
await web3.eth.sendTransaction({from:accounts[0], to:Identity.address, value: amountToSend})
2018-03-14 15:42:04 -04:00
let idBalance1 = await web3.eth.getBalance(Identity.address);
2018-03-14 15:42:04 -04:00
assert.equal(web3.utils.toBN(idBalance0).add(web3.utils.toBN(amountToSend)).toString(), web3.utils.toBN(idBalance1).toString(), Identity.address + " did not receive ether");
});
2018-03-14 15:42:04 -04:00
it("ACTOR_KEY execute arbitrary transaction", async () => {
2018-03-14 10:31:12 -04:00
await Identity.methods.execute(
Identity.address,
0,
2018-05-13 05:46:39 -03:00
idUtils.encode.addKey(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.ACTION, idUtils.types.ADDRESS))
2018-03-14 10:31:12 -04:00
.send({from: accounts[0]});
2018-03-14 10:31:12 -04:00
functionPayload = web3.eth.abi.encodeFunctionCall({
name: 'test',
type: 'function',
inputs: []
}, []);
2018-03-14 10:31:12 -04:00
let receipt = await Identity.methods.execute(
TestContract.address,
0,
2018-03-14 10:31:12 -04:00
functionPayload)
.send({from: accounts[1]});
2018-03-14 15:42:04 -04:00
// @rramos - Commented because of error:
// The current provider doesn't support subscriptions: Provider
/*assert.notEqual(
await TestUtils.listenForEvent(TestContract.events.TestFunctionExecuted),
undefined,
"Test function was not executed"); */
2018-03-14 10:31:12 -04:00
});
2018-03-14 15:42:04 -04:00
it("MANAGEMENT_KEY cannot execute arbitrary transaction", async () => {
try {
2018-03-14 10:31:12 -04:00
await Identity.methods.execute(
TestContract.address,
0,
2018-03-14 10:31:12 -04:00
functionPayload)
.send({from: accounts[0]});
} catch(error) {
TestUtils.assertJump(error);
}
});
it("Other keys NOT execute arbitrary transaction", async () => {
try {
2018-03-14 10:31:12 -04:00
await Identity.methods.execute(
TestContract.address,
0,
2018-03-14 10:31:12 -04:00
functionPayload)
.send({from: accounts[3]});
assert.fail('should have reverted before');
} catch(error) {
TestUtils.assertJump(error);
}
});
2018-05-13 05:46:39 -03:00
xit("ACTION_KEY should send ether from contract", async () => {
2018-03-14 10:31:12 -04:00
await Identity.methods.execute(
Identity.address,
0,
2018-05-13 05:46:39 -03:00
idUtils.encode.addKey(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.ACTION, idUtils.types.ADDRESS))
2018-03-14 10:31:12 -04:00
.send({from: accounts[0]});
// Adding funds to contract
2018-03-14 10:31:12 -04:00
await web3.eth.sendTransaction({from:accounts[0], to:Identity.address, value: web3.utils.toWei('0.05', "ether")})
2018-03-14 10:31:12 -04:00
const amountToSend = web3.utils.toWei('0.01', "ether");
2018-03-14 15:42:04 -04:00
let idBalance0 = await web3.eth.getBalance(Identity.address);
let a2Balance0 = await web3.eth.getBalance(accounts[2]);
2018-03-14 10:31:12 -04:00
await Identity.methods.execute(
accounts[2],
amountToSend,
2018-03-14 15:42:04 -04:00
'0x')
2018-03-14 10:31:12 -04:00
.send({from: accounts[1]});
2018-03-14 15:42:04 -04:00
let idBalance1 = await web3.eth.getBalance(Identity.address);
let a2Balance1 = await web3.eth.getBalance(accounts[2]);
2018-03-14 15:42:04 -04:00
assert(web3.utils.toBN(idBalance1).toString(), web3.utils.toBN(idBalance0).sub(web3.utils.toBN(amountToSend)).toString(), "Contract did not send ether");
assert(web3.utils.toBN(a2Balance1).toString(), web3.utils.toBN(a2Balance0).add(web3.utils.toBN(amountToSend)).toString(), accounts[2] + " did not receive ether");
});
2018-05-13 05:46:39 -03:00
xit("fire ExecutionRequested(uint256 indexed executionId, address indexed to, uint256 indexed value, bytes data)", async () => {
2018-03-14 10:31:12 -04:00
await Identity.methods.execute(
Identity.address,
0,
2018-05-13 05:46:39 -03:00
idUtils.encode.addKey(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.ACTION, idUtils.types.ADDRESS))
2018-03-14 10:31:12 -04:00
.send({from: accounts[0]});
2018-03-14 10:31:12 -04:00
let receipt = await Identity.methods.execute(
TestContract.address,
0,
2018-03-14 10:31:12 -04:00
functionPayload)
.send({from: accounts[1]});
const executionRequested = TestUtils.eventValues(receipt, "ExecutionRequested");
assert(executionRequested.to, TestContract.address, "To is not correct");
assert(executionRequested.value, 0, "Value is not correct");
assert(executionRequested.data, functionPayload, "Data is not correct");
});
2018-05-13 05:46:39 -03:00
xit("fire Executed(uint256 indexed executionId, address indexed to, uint256 indexed value, bytes data)", async () => {
2018-03-14 10:31:12 -04:00
await Identity.methods.execute(
Identity.address,
0,
2018-05-13 05:46:39 -03:00
idUtils.encode.addKey(web3.utils.soliditySha3(accounts[1]), idUtils.purposes.ACTION, idUtils.types.ADDRESS))
2018-03-14 10:31:12 -04:00
.send({from: accounts[0]});
2018-03-14 10:31:12 -04:00
let receipt = await Identity.methods.execute(
TestContract.address,
0,
2018-03-14 10:31:12 -04:00
functionPayload)
.send({from: accounts[1]});
2018-03-14 10:31:12 -04:00
const executed = TestUtils.eventValues(receipt, "Executed")
assert(executed.to, TestContract.address, "To is not correct");
assert(executed.value, 0, "Value is not correct");
assert(executed.data, functionPayload, "Data is not correct");
});
});
/*
describe("setMinimumApprovalsByKeyPurpose(uint256 _type, uint8 _minimumApprovals)", () => {
it("MANAGEMENT_KEY should set minimum approvals for MANAGEMENT_KEYs", async () => {
});
it("MANAGEMENT_KEY should set minimum approvals for ACTION_KEYs", async () => {
});
it("ACTION_KEY should not be able to set minimum approvals", async () => {
});
it("Other keys should not be able to set minimum approvals", async () => {
});
});
describe("approve(bytes32 _id, bool _approve)", () => {
it("MANAGEMENT_KEY should approve a claim", async () => {
});
it("MANAGEMENT_KEY should approve a transaction", async () => {
});
it("2 out of 3 MANAGEMENT_KEY should approve a transaction and execute it", async () => {
});
2018-05-13 05:46:39 -03:00
xit("fire Approved(uint256 indexed executionId, bool approved)", async () => {
});
});
describe("getClaim(bytes32 _claimId)", () => {
it("Returns a claim by ID.", async () => {
});
});
describe("getClaimIdsByType(uint256 _claimType)", () => {
it("Returns an array of claim IDs by type.", async () => {
});
});
describe("addClaim(uint256 _claimType, address issuer, uint256 signatureType, bytes _signature, bytes _data, string _uri)", () => {
it("Requests the ADDITION of a claim from an issuer", async () => {
});
it("Requests the CHANGE of a claim from an issuer", async () => {
});
});
describe("removeClaim(bytes32 _claimId)", () => {
it("Requests the DELETION of a claim from an issuer", async () => {
});
it("Requests the DELETION of a claim from identity", async () => {
});
});
*/
});