@bitgo-beta/account-lib 2.24.1-alpha.48 → 2.24.1-alpha.481
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/resources/dot/index.js +6 -2
- package/dist/resources/dot/westend.d.ts +1 -1
- package/dist/resources/dot/westend.d.ts.map +1 -1
- package/dist/resources/dot/westend.js +2 -2
- package/dist/resources/dot/westend.ts +1 -1
- package/dist/src/index.d.ts +110 -4
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +259 -17
- package/dist/src/keyPair/index.js +24 -11
- package/dist/src/utils/index.d.ts +1 -0
- package/dist/src/utils/index.d.ts.map +1 -1
- package/dist/src/utils/index.js +27 -10
- package/dist/src/utils/messages/index.d.ts +10 -0
- package/dist/src/utils/messages/index.d.ts.map +1 -0
- package/dist/src/utils/messages/index.js +30 -0
- package/dist/test/resources/ed25519Deriver.d.ts +15 -0
- package/dist/test/resources/ed25519Deriver.d.ts.map +1 -0
- package/dist/test/resources/ed25519Deriver.js +18 -0
- package/dist/test/resources/testTransaction.d.ts +11 -0
- package/dist/test/resources/testTransaction.d.ts.map +1 -0
- package/dist/test/resources/testTransaction.js +19 -0
- package/dist/test/resources/testTransactionBuilder.d.ts +26 -0
- package/dist/test/resources/testTransactionBuilder.d.ts.map +1 -0
- package/dist/test/resources/testTransactionBuilder.js +47 -0
- package/dist/test/unit/coin/baseCoin/transactionBuilder.d.ts +2 -0
- package/dist/test/unit/coin/baseCoin/transactionBuilder.d.ts.map +1 -0
- package/dist/test/unit/coin/baseCoin/transactionBuilder.js +135 -0
- package/dist/test/unit/fixtures.d.ts +16 -0
- package/dist/test/unit/fixtures.d.ts.map +1 -0
- package/dist/test/unit/fixtures.js +43 -0
- package/dist/test/unit/index.d.ts +2 -0
- package/dist/test/unit/index.d.ts.map +1 -0
- package/dist/test/unit/index.js +13 -0
- package/dist/test/unit/keyPair/index.d.ts +2 -0
- package/dist/test/unit/keyPair/index.d.ts.map +1 -0
- package/dist/test/unit/keyPair/index.js +132 -0
- package/dist/test/unit/messageFactory.d.ts +2 -0
- package/dist/test/unit/messageFactory.d.ts.map +1 -0
- package/dist/test/unit/messageFactory.js +78 -0
- package/dist/test/unit/mpc/tss/ecdsa/ecdsa.d.ts +2 -0
- package/dist/test/unit/mpc/tss/ecdsa/ecdsa.d.ts.map +1 -0
- package/dist/test/unit/mpc/tss/ecdsa/ecdsa.js +333 -0
- package/dist/test/unit/mpc/tss/eddsa/eddsa.d.ts +5 -0
- package/dist/test/unit/mpc/tss/eddsa/eddsa.d.ts.map +1 -0
- package/dist/test/unit/mpc/tss/eddsa/eddsa.js +322 -0
- package/dist/test/unit/mpc/tss/fixtures/ecdsa.d.ts +130 -0
- package/dist/test/unit/mpc/tss/fixtures/ecdsa.d.ts.map +1 -0
- package/dist/test/unit/mpc/tss/fixtures/ecdsa.js +283 -0
- package/dist/test/unit/utils/crypto.d.ts +2 -0
- package/dist/test/unit/utils/crypto.d.ts.map +1 -0
- package/dist/test/unit/utils/crypto.js +60 -0
- package/dist/test/unit/utils/ed25519KeyDeriver.d.ts +2 -0
- package/dist/test/unit/utils/ed25519KeyDeriver.d.ts.map +1 -0
- package/dist/test/unit/utils/ed25519KeyDeriver.js +23 -0
- package/dist/test/unit/utils/index.d.ts +2 -0
- package/dist/test/unit/utils/index.d.ts.map +1 -0
- package/dist/test/unit/utils/index.js +61 -0
- package/dist/test/unit/utils/messages/index.d.ts +2 -0
- package/dist/test/unit/utils/messages/index.d.ts.map +1 -0
- package/dist/test/unit/utils/messages/index.js +51 -0
- package/dist/test/unit/verifyMessage.d.ts +2 -0
- package/dist/test/unit/verifyMessage.d.ts.map +1 -0
- package/dist/test/unit/verifyMessage.js +96 -0
- package/dist/tsconfig.tsbuildinfo +1 -43551
- package/package.json +77 -32
- package/.mocharc.js +0 -10
- package/CHANGELOG.md +0 -409
- package/DEVELOPER.md +0 -93
- package/resources/README.md +0 -17
- package/resources/cspr/contract/keys-manager.wasm +0 -0
- package/resources/dot/index.ts +0 -2
- package/resources/dot/mainnet.ts +0 -2
- package/resources/dot/westend.ts +0 -2
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../test/unit/keyPair/index.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
/**
|
|
40
|
+
* @prettier
|
|
41
|
+
*/
|
|
42
|
+
const assert_1 = __importDefault(require("assert"));
|
|
43
|
+
const keyPair_1 = require("../../../src/keyPair");
|
|
44
|
+
const coinModules = __importStar(require("../../../src"));
|
|
45
|
+
const statics_1 = require("@bitgo-beta/statics");
|
|
46
|
+
describe('Key Pair Factory', () => {
|
|
47
|
+
describe('coinToKey map initialization', function () {
|
|
48
|
+
const supportedCoinsExceptTestnet = Object.keys(coinModules)
|
|
49
|
+
// TODO(BG-40990): temporarily disable eth2 from the test for bls not initialized error
|
|
50
|
+
.filter((k) => coinModules[k].KeyPair && !['eth2', 'evmcoin', 'cosmossharedcoin', 'stt'].includes(k.trim().toLowerCase()));
|
|
51
|
+
supportedCoinsExceptTestnet.forEach((coinName) => {
|
|
52
|
+
it(`should initialize a ${coinName} keyPair map`, () => {
|
|
53
|
+
const keyPair = (0, keyPair_1.register)(coinName);
|
|
54
|
+
(typeof keyPair.getKeys).should.equal('function');
|
|
55
|
+
(typeof keyPair.getAddress).should.equal('function');
|
|
56
|
+
(typeof keyPair.recordKeysFromPrivateKey).should.equal('function');
|
|
57
|
+
(typeof keyPair.recordKeysFromPublicKey).should.equal('function');
|
|
58
|
+
});
|
|
59
|
+
});
|
|
60
|
+
it('should fail to instantiate an unsupported coin', () => {
|
|
61
|
+
assert_1.default.throws(() => (0, keyPair_1.register)('fakeUnsupported'));
|
|
62
|
+
});
|
|
63
|
+
});
|
|
64
|
+
describe('secp256k1 generation', function () {
|
|
65
|
+
it('should initialize eth keyPair map', () => {
|
|
66
|
+
const eth = statics_1.coins.get('eth');
|
|
67
|
+
const keyPair = (0, keyPair_1.register)(eth.name);
|
|
68
|
+
(typeof keyPair.getKeys).should.equal('function');
|
|
69
|
+
(typeof keyPair.getAddress).should.equal('function');
|
|
70
|
+
(typeof keyPair.getPublicKey).should.equal('function');
|
|
71
|
+
});
|
|
72
|
+
it('should initialize eth keyPair map with arguments', () => {
|
|
73
|
+
const eth = statics_1.coins.get('eth');
|
|
74
|
+
const uncompressedPub = '04D63D9FD9FD772A989C5B90EDB37716406356E98273E5F98FE07652247A3A827503E948A2FDBF74A981D4E0054F10EDA7042C2D469F44473D3C7791E0E326E355';
|
|
75
|
+
const pubKey = { pub: uncompressedPub };
|
|
76
|
+
const keyPair = (0, keyPair_1.register)(eth.name, pubKey);
|
|
77
|
+
(typeof keyPair.getKeys).should.equal('function');
|
|
78
|
+
(typeof keyPair.getAddress).should.equal('function');
|
|
79
|
+
(typeof keyPair.getPublicKey).should.equal('function');
|
|
80
|
+
});
|
|
81
|
+
});
|
|
82
|
+
describe('ed25519 generation', function () {
|
|
83
|
+
const fixedKeyPair = {
|
|
84
|
+
prv: 'e349d47cd4af4644afbc05b8463c0d0d19a0cc742be5c1646af2e7be8aafbd50',
|
|
85
|
+
};
|
|
86
|
+
const givenSignature = new Uint8Array(Buffer.from('b2e775827f6b3c9050524a7d2f5344db73eb92044d8e42c38357a30686a9ce3a19b8fbf8c9d1edb0f3c5232441d34b63af92805aed77097ee50076f696eaff0f', 'hex'));
|
|
87
|
+
['dot', 'tdot', 'algo', 'talgo', 'hbar', 'thbar', 'sol', 'tsol'].forEach((coinName) => {
|
|
88
|
+
describe(`${coinName} keyPair`, function () {
|
|
89
|
+
const kp = (0, keyPair_1.register)(coinName, fixedKeyPair);
|
|
90
|
+
it(`should initialize ${coinName} keyPair map`, () => {
|
|
91
|
+
const keyPair = (0, keyPair_1.register)(coinName);
|
|
92
|
+
(typeof keyPair.getKeys).should.equal('function');
|
|
93
|
+
(typeof keyPair.getAddress).should.equal('function');
|
|
94
|
+
(typeof keyPair.verifySignature).should.equal('function');
|
|
95
|
+
(typeof keyPair.signMessage).should.equal('function');
|
|
96
|
+
});
|
|
97
|
+
it(`should initialize ${coinName} keyPair map with arguments`, () => {
|
|
98
|
+
const keyPair = (0, keyPair_1.register)(coinName, fixedKeyPair);
|
|
99
|
+
(typeof keyPair.getKeys).should.equal('function');
|
|
100
|
+
(typeof keyPair.getAddress).should.equal('function');
|
|
101
|
+
(typeof keyPair.verifySignature).should.equal('function');
|
|
102
|
+
(typeof keyPair.signMessage).should.equal('function');
|
|
103
|
+
});
|
|
104
|
+
it('should get same signature from same message', () => {
|
|
105
|
+
// When
|
|
106
|
+
const signature = kp.signMessage('message');
|
|
107
|
+
// Then
|
|
108
|
+
signature.should.deepEqual(givenSignature);
|
|
109
|
+
});
|
|
110
|
+
it('should get different signature form different message', () => {
|
|
111
|
+
// When
|
|
112
|
+
const signature = kp.signMessage('wrong message');
|
|
113
|
+
// Then
|
|
114
|
+
signature.should.not.deepEqual(givenSignature);
|
|
115
|
+
});
|
|
116
|
+
it('should be verified correctly', () => {
|
|
117
|
+
// When
|
|
118
|
+
const verifyResult = kp.verifySignature('message', givenSignature);
|
|
119
|
+
// Then
|
|
120
|
+
verifyResult.should.be.True();
|
|
121
|
+
});
|
|
122
|
+
it('should not be verified wrong message', () => {
|
|
123
|
+
// When
|
|
124
|
+
const verifyResult = kp.verifySignature('wrong message', givenSignature);
|
|
125
|
+
// Then
|
|
126
|
+
verifyResult.should.be.False();
|
|
127
|
+
});
|
|
128
|
+
});
|
|
129
|
+
});
|
|
130
|
+
});
|
|
131
|
+
});
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../test/unit/keyPair/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport assert from 'assert';\nimport { register } from '../../../src/keyPair';\nimport * as coinModules from '../../../src';\nimport { coins } from '@bitgo-beta/statics';\nimport { KeyPair as EthKeyPair } from '@bitgo-beta/sdk-coin-eth';\nimport { Ed25519KeyPair } from '@bitgo-beta/sdk-core';\n\ndescribe('Key Pair Factory', () => {\n  describe('coinToKey map initialization', function () {\n    const supportedCoinsExceptTestnet = Object.keys(coinModules)\n      // TODO(BG-40990): temporarily disable eth2 from the test for bls not initialized error\n      .filter(\n        (k) =>\n          coinModules[k].KeyPair && !['eth2', 'evmcoin', 'cosmossharedcoin', 'stt'].includes(k.trim().toLowerCase()),\n      );\n\n    supportedCoinsExceptTestnet.forEach((coinName) => {\n      it(`should initialize a ${coinName} keyPair map`, () => {\n        const keyPair = register(coinName);\n        (typeof keyPair.getKeys).should.equal('function');\n        (typeof keyPair.getAddress).should.equal('function');\n        (typeof keyPair.recordKeysFromPrivateKey).should.equal('function');\n        (typeof keyPair.recordKeysFromPublicKey).should.equal('function');\n      });\n    });\n\n    it('should fail to instantiate an unsupported coin', () => {\n      assert.throws(() => register('fakeUnsupported'));\n    });\n  });\n\n  describe('secp256k1 generation', function () {\n    it('should initialize eth keyPair map', () => {\n      const eth = coins.get('eth');\n      const keyPair = register(eth.name) as EthKeyPair;\n      (typeof keyPair.getKeys).should.equal('function');\n      (typeof keyPair.getAddress).should.equal('function');\n      (typeof keyPair.getPublicKey).should.equal('function');\n    });\n\n    it('should initialize eth keyPair map with arguments', () => {\n      const eth = coins.get('eth');\n      const uncompressedPub =\n        '04D63D9FD9FD772A989C5B90EDB37716406356E98273E5F98FE07652247A3A827503E948A2FDBF74A981D4E0054F10EDA7042C2D469F44473D3C7791E0E326E355';\n      const pubKey = { pub: uncompressedPub };\n      const keyPair = register(eth.name, pubKey) as EthKeyPair;\n      (typeof keyPair.getKeys).should.equal('function');\n      (typeof keyPair.getAddress).should.equal('function');\n      (typeof keyPair.getPublicKey).should.equal('function');\n    });\n  });\n\n  describe('ed25519 generation', function () {\n    const fixedKeyPair = {\n      prv: 'e349d47cd4af4644afbc05b8463c0d0d19a0cc742be5c1646af2e7be8aafbd50',\n    };\n    const givenSignature = new Uint8Array(\n      Buffer.from(\n        'b2e775827f6b3c9050524a7d2f5344db73eb92044d8e42c38357a30686a9ce3a19b8fbf8c9d1edb0f3c5232441d34b63af92805aed77097ee50076f696eaff0f',\n        'hex',\n      ),\n    );\n\n    ['dot', 'tdot', 'algo', 'talgo', 'hbar', 'thbar', 'sol', 'tsol'].forEach((coinName) => {\n      describe(`${coinName} keyPair`, function () {\n        const kp = register(coinName, fixedKeyPair) as Ed25519KeyPair;\n\n        it(`should initialize ${coinName} keyPair map`, () => {\n          const keyPair = register(coinName) as Ed25519KeyPair;\n          (typeof keyPair.getKeys).should.equal('function');\n          (typeof keyPair.getAddress).should.equal('function');\n          (typeof keyPair.verifySignature).should.equal('function');\n          (typeof keyPair.signMessage).should.equal('function');\n        });\n\n        it(`should initialize ${coinName} keyPair map with arguments`, () => {\n          const keyPair = register(coinName, fixedKeyPair) as Ed25519KeyPair;\n          (typeof keyPair.getKeys).should.equal('function');\n          (typeof keyPair.getAddress).should.equal('function');\n          (typeof keyPair.verifySignature).should.equal('function');\n          (typeof keyPair.signMessage).should.equal('function');\n        });\n\n        it('should get same signature from same message', () => {\n          // When\n          const signature = kp.signMessage('message');\n          // Then\n          signature.should.deepEqual(givenSignature);\n        });\n\n        it('should get different signature form different message', () => {\n          // When\n          const signature = kp.signMessage('wrong message');\n          // Then\n          signature.should.not.deepEqual(givenSignature);\n        });\n\n        it('should be verified correctly', () => {\n          // When\n          const verifyResult = kp.verifySignature('message', givenSignature);\n          // Then\n          verifyResult.should.be.True();\n        });\n\n        it('should not be verified wrong message', () => {\n          // When\n          const verifyResult = kp.verifySignature('wrong message', givenSignature);\n          // Then\n          verifyResult.should.be.False();\n        });\n      });\n    });\n  });\n});\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"messageFactory.d.ts","sourceRoot":"","sources":["../../../test/unit/messageFactory.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const assert_1 = __importDefault(require("assert"));
|
|
7
|
+
const should_1 = __importDefault(require("should"));
|
|
8
|
+
const sinon_1 = __importDefault(require("sinon"));
|
|
9
|
+
const src_1 = require("../../src");
|
|
10
|
+
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
11
|
+
const statics_1 = require("@bitgo-beta/statics");
|
|
12
|
+
const fixtures_1 = require("./fixtures");
|
|
13
|
+
describe('Message Builder Factory', () => {
|
|
14
|
+
describe('getMessageBuilderFactory', () => {
|
|
15
|
+
it('should fail to instantiate an unsupported coin', () => {
|
|
16
|
+
assert_1.default.throws(() => (0, src_1.getMessageBuilderFactory)('fakeUnsupported'), (e) => {
|
|
17
|
+
return (e instanceof sdk_core_1.BuildMessageError &&
|
|
18
|
+
e.message === 'Message builder factory for coin fakeUnsupported not supported');
|
|
19
|
+
});
|
|
20
|
+
});
|
|
21
|
+
it('should succeed for supported coins', () => {
|
|
22
|
+
const ethFactory = (0, src_1.getMessageBuilderFactory)('eth');
|
|
23
|
+
should_1.default.exist(ethFactory);
|
|
24
|
+
ethFactory.should.be.instanceof(sdk_core_1.BaseMessageBuilderFactory);
|
|
25
|
+
// Verify hteth is also supported
|
|
26
|
+
const htethFactory = (0, src_1.getMessageBuilderFactory)('hteth');
|
|
27
|
+
should_1.default.exist(htethFactory);
|
|
28
|
+
htethFactory.should.be.instanceof(sdk_core_1.BaseMessageBuilderFactory);
|
|
29
|
+
});
|
|
30
|
+
it('should auto-register all non-token coins with SHARED_EVM_MESSAGE_SIGNING feature', () => {
|
|
31
|
+
const evmCoins = statics_1.coins.reduce((acc, coin) => {
|
|
32
|
+
if (coin.features.includes(statics_1.CoinFeature.SHARED_EVM_MESSAGE_SIGNING) && !coin.isToken) {
|
|
33
|
+
acc.push(coin.name);
|
|
34
|
+
}
|
|
35
|
+
return acc;
|
|
36
|
+
}, []);
|
|
37
|
+
evmCoins.length.should.be.greaterThan(0);
|
|
38
|
+
for (const coinName of evmCoins) {
|
|
39
|
+
const factory = (0, src_1.getMessageBuilderFactory)(coinName);
|
|
40
|
+
should_1.default.exist(factory, `Expected message builder factory for ${coinName}`);
|
|
41
|
+
factory.should.be.instanceof(sdk_core_1.BaseMessageBuilderFactory);
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
it('should not register token coins with SHARED_EVM_MESSAGE_SIGNING feature', () => {
|
|
45
|
+
const evmTokens = statics_1.coins.reduce((acc, coin) => {
|
|
46
|
+
if (coin.features.includes(statics_1.CoinFeature.SHARED_EVM_MESSAGE_SIGNING) && coin.isToken) {
|
|
47
|
+
acc.push(coin.name);
|
|
48
|
+
}
|
|
49
|
+
return acc;
|
|
50
|
+
}, []);
|
|
51
|
+
evmTokens.length.should.be.greaterThan(0);
|
|
52
|
+
for (const tokenName of evmTokens) {
|
|
53
|
+
assert_1.default.throws(() => (0, src_1.getMessageBuilderFactory)(tokenName), (e) => e instanceof sdk_core_1.BuildMessageError, `Token ${tokenName} should not have a message builder factory`);
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
describe('registerMessageBuilderFactory', () => {
|
|
58
|
+
// Mock message builder that implements required abstract methods
|
|
59
|
+
it('should register a new message builder factory', () => {
|
|
60
|
+
const coinName = 'fakeTestCoin';
|
|
61
|
+
const mockCoin = sinon_1.default.createStubInstance(statics_1.BaseCoin);
|
|
62
|
+
sinon_1.default
|
|
63
|
+
.stub(statics_1.coins, 'get')
|
|
64
|
+
.withArgs(coinName)
|
|
65
|
+
.returns(mockCoin);
|
|
66
|
+
const factory = (0, src_1.registerMessageBuilderFactory)(coinName, fixtures_1.MockMessageBuilderFactory);
|
|
67
|
+
should_1.default.exist(factory);
|
|
68
|
+
factory.should.be.instanceof(fixtures_1.MockMessageBuilderFactory);
|
|
69
|
+
// Verify we can get it back
|
|
70
|
+
const retrievedFactory = (0, src_1.getMessageBuilderFactory)(coinName);
|
|
71
|
+
should_1.default.exist(retrievedFactory);
|
|
72
|
+
retrievedFactory.should.be.instanceof(fixtures_1.MockMessageBuilderFactory);
|
|
73
|
+
// Restore the stub
|
|
74
|
+
sinon_1.default.restore();
|
|
75
|
+
});
|
|
76
|
+
});
|
|
77
|
+
});
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"messageFactory.js","sourceRoot":"","sources":["../../../test/unit/messageFactory.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport should from 'should';\nimport sinon from 'sinon';\nimport { getMessageBuilderFactory, registerMessageBuilderFactory } from '../../src';\nimport { BaseMessageBuilderFactory, BuildMessageError } from '@bitgo-beta/sdk-core';\nimport { coins, BaseCoin, CoinFeature } from '@bitgo-beta/statics';\nimport { MockMessageBuilderFactory } from './fixtures';\n\ndescribe('Message Builder Factory', () => {\n  describe('getMessageBuilderFactory', () => {\n    it('should fail to instantiate an unsupported coin', () => {\n      assert.throws(\n        () => getMessageBuilderFactory('fakeUnsupported'),\n        (e: Error) => {\n          return (\n            e instanceof BuildMessageError &&\n            e.message === 'Message builder factory for coin fakeUnsupported not supported'\n          );\n        },\n      );\n    });\n\n    it('should succeed for supported coins', () => {\n      const ethFactory = getMessageBuilderFactory('eth');\n      should.exist(ethFactory);\n      ethFactory.should.be.instanceof(BaseMessageBuilderFactory);\n\n      // Verify hteth is also supported\n      const htethFactory = getMessageBuilderFactory('hteth');\n      should.exist(htethFactory);\n      htethFactory.should.be.instanceof(BaseMessageBuilderFactory);\n    });\n\n    it('should auto-register all non-token coins with SHARED_EVM_MESSAGE_SIGNING feature', () => {\n      const evmCoins = coins.reduce<string[]>((acc, coin) => {\n        if (coin.features.includes(CoinFeature.SHARED_EVM_MESSAGE_SIGNING) && !coin.isToken) {\n          acc.push(coin.name);\n        }\n        return acc;\n      }, []);\n      evmCoins.length.should.be.greaterThan(0);\n\n      for (const coinName of evmCoins) {\n        const factory = getMessageBuilderFactory(coinName);\n        should.exist(factory, `Expected message builder factory for ${coinName}`);\n        factory.should.be.instanceof(BaseMessageBuilderFactory);\n      }\n    });\n\n    it('should not register token coins with SHARED_EVM_MESSAGE_SIGNING feature', () => {\n      const evmTokens = coins.reduce<string[]>((acc, coin) => {\n        if (coin.features.includes(CoinFeature.SHARED_EVM_MESSAGE_SIGNING) && coin.isToken) {\n          acc.push(coin.name);\n        }\n        return acc;\n      }, []);\n      evmTokens.length.should.be.greaterThan(0);\n\n      for (const tokenName of evmTokens) {\n        assert.throws(\n          () => getMessageBuilderFactory(tokenName),\n          (e: Error) => e instanceof BuildMessageError,\n          `Token ${tokenName} should not have a message builder factory`,\n        );\n      }\n    });\n  });\n\n  describe('registerMessageBuilderFactory', () => {\n    // Mock message builder that implements required abstract methods\n\n    it('should register a new message builder factory', () => {\n      const coinName = 'fakeTestCoin';\n      const mockCoin = sinon.createStubInstance(BaseCoin);\n      sinon\n        .stub(coins, 'get')\n        .withArgs(coinName)\n        .returns(mockCoin as unknown as BaseCoin);\n\n      const factory = registerMessageBuilderFactory(coinName, MockMessageBuilderFactory);\n      should.exist(factory);\n      factory.should.be.instanceof(MockMessageBuilderFactory);\n\n      // Verify we can get it back\n      const retrievedFactory = getMessageBuilderFactory(coinName);\n      should.exist(retrievedFactory);\n      retrievedFactory.should.be.instanceof(MockMessageBuilderFactory);\n\n      // Restore the stub\n      sinon.restore();\n    });\n  });\n});\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ecdsa.d.ts","sourceRoot":"","sources":["../../../../../../test/unit/mpc/tss/ecdsa/ecdsa.ts"],"names":[],"mappings":""}
|