@0xcert/ethereum-gateway-contracts
Version:
Smart contracts used by the gateway on the Ethereum blockchain.
147 lines • 7.19 kB
JavaScript
"use strict";
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
const types_1 = require("@0xcert/ethereum-proxy-contracts/src/core/types");
const types_2 = require("@0xcert/ethereum-xcert-contracts/src/core/types");
const spec_1 = require("@specron/spec");
const types_3 = require("../../../core/types");
const common = require("../../helpers/common");
const signature_1 = require("../../helpers/signature");
const spec = new spec_1.Spec();
spec.before((ctx) => __awaiter(void 0, void 0, void 0, function* () {
const accounts = yield ctx.web3.eth.getAccounts();
ctx.set('owner', accounts[0]);
ctx.set('jane', accounts[1]);
ctx.set('sara', accounts[2]);
}));
spec.before((ctx) => __awaiter(void 0, void 0, void 0, function* () {
ctx.set('id1', '1');
ctx.set('digest1', '0x1e205550c221490347e5e2393a02e94d284bbe9903f023ba098355b8d75974c8');
}));
spec.beforeEach((ctx) => __awaiter(void 0, void 0, void 0, function* () {
const cat = yield ctx.deploy({
src: '@0xcert/ethereum-xcert-contracts/build/xcert-mock.json',
contract: 'XcertMock',
args: ['cat', 'CAT', 'https://0xcert.org/', '.json', '0xa65de9e6', []],
});
ctx.set('cat', cat);
}));
spec.beforeEach((ctx) => __awaiter(void 0, void 0, void 0, function* () {
const createProxy = yield ctx.deploy({
src: '@0xcert/ethereum-proxy-contracts/build/xcert-create-proxy.json',
contract: 'XcertCreateProxy',
});
ctx.set('createProxy', createProxy);
}));
spec.beforeEach((ctx) => __awaiter(void 0, void 0, void 0, function* () {
const createProxy = ctx.get('createProxy');
const owner = ctx.get('owner');
const actionsGateway = yield ctx.deploy({
src: './build/actions-gateway.json',
contract: 'ActionsGateway',
});
yield actionsGateway.instance.methods.grantAbilities(owner, types_3.ActionsGatewayAbilities.SET_PROXIES).send();
yield actionsGateway.instance.methods.addProxy(createProxy.receipt._address, 0).send({ from: owner });
ctx.set('actionsGateway', actionsGateway);
}));
spec.beforeEach((ctx) => __awaiter(void 0, void 0, void 0, function* () {
const actionsGateway = ctx.get('actionsGateway');
const owner = ctx.get('owner');
const createProxy = ctx.get('createProxy');
yield createProxy.instance.methods.grantAbilities(actionsGateway.receipt._address, types_1.XcertCreateProxyAbilities.EXECUTE).send({ from: owner });
}));
spec.test('fails if a signature is missing', (ctx) => __awaiter(void 0, void 0, void 0, function* () {
const actionsGateway = ctx.get('actionsGateway');
const createProxy = ctx.get('createProxy');
const jane = ctx.get('jane');
const owner = ctx.get('owner');
const sara = ctx.get('sara');
const cat = ctx.get('cat');
const id = ctx.get('id1');
const digest = ctx.get('digest1');
const actions = [
{
proxyId: 0,
contractAddress: cat.receipt._address,
params: `${digest}${id.substring(2)}${jane.substring(2)}00`,
},
];
const orderData = {
signers: [owner, jane, sara],
actions,
seed: common.getCurrentTime(),
expirationTimestamp: common.getCurrentTime() + 3600,
};
const createTuple = ctx.tuple(orderData);
const claim = yield actionsGateway.instance.methods.getOrderDataClaim(createTuple).call();
const signature1 = yield signature_1.getSignature(ctx.web3, claim, owner);
const signature2 = yield signature_1.getSignature(ctx.web3, claim, jane);
const signatureDataTuple = ctx.tuple([signature1, signature2]);
yield cat.instance.methods.grantAbilities(createProxy.receipt._address, types_2.XcertAbilities.CREATE_ASSET).send({ from: owner });
yield ctx.reverts(() => actionsGateway.instance.methods.perform(createTuple, signatureDataTuple).send({ from: jane }));
}));
spec.test('fails when proxy does not have the create rights', (ctx) => __awaiter(void 0, void 0, void 0, function* () {
const actionsGateway = ctx.get('actionsGateway');
const jane = ctx.get('jane');
const owner = ctx.get('owner');
const cat = ctx.get('cat');
const id = ctx.get('id1');
const digest = ctx.get('digest1');
const actions = [
{
proxyId: 0,
contractAddress: cat.receipt._address,
params: `${digest}${id.substring(2)}${jane.substring(2)}00`,
},
];
const orderData = {
signers: [owner],
actions,
seed: common.getCurrentTime(),
expirationTimestamp: common.getCurrentTime() + 3600,
};
const createTuple = ctx.tuple(orderData);
const claim = yield actionsGateway.instance.methods.getOrderDataClaim(createTuple).call();
const signature1 = yield signature_1.getSignature(ctx.web3, claim, owner);
const signatureDataTuple = ctx.tuple([signature1]);
yield ctx.reverts(() => actionsGateway.instance.methods.perform(createTuple, signatureDataTuple).send({ from: jane }), '017001');
}));
spec.test('fails if maker does not have asset creating ability', (ctx) => __awaiter(void 0, void 0, void 0, function* () {
const actionsGateway = ctx.get('actionsGateway');
const createProxy = ctx.get('createProxy');
const jane = ctx.get('jane');
const owner = ctx.get('owner');
const cat = ctx.get('cat');
const id = ctx.get('id1');
const digest = ctx.get('digest1');
const actions = [
{
proxyId: 0,
contractAddress: cat.receipt._address,
params: `${digest}${id.substring(2)}${jane.substring(2)}00`,
},
];
const orderData = {
signers: [owner],
actions,
seed: common.getCurrentTime(),
expirationTimestamp: common.getCurrentTime() + 3600,
};
const createTuple = ctx.tuple(orderData);
const claim = yield actionsGateway.instance.methods.getOrderDataClaim(createTuple).call();
const signature1 = yield signature_1.getSignature(ctx.web3, claim, owner);
const signatureDataTuple = ctx.tuple([signature1]);
yield cat.instance.methods.revokeAbilities(owner, types_2.XcertAbilities.ALLOW_CREATE_ASSET).send({ from: owner });
yield cat.instance.methods.grantAbilities(createProxy.receipt._address, types_2.XcertAbilities.CREATE_ASSET).send({ from: owner });
yield ctx.reverts(() => actionsGateway.instance.methods.perform(createTuple, signatureDataTuple).send({ from: jane }), '015009');
}));
exports.default = spec;
//# sourceMappingURL=create-perform-fail.test.js.map