@bitgo-beta/sdk-coin-icp 1.0.1-beta.84 → 1.0.1-beta.841
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/dist/resources/messageCompiled.d.ts +797 -0
- package/dist/resources/messageCompiled.js +1859 -0
- package/dist/src/icp.d.ts +64 -3
- package/dist/src/icp.d.ts.map +1 -1
- package/dist/src/icp.js +332 -10
- package/dist/src/lib/icpAgent.d.ts +36 -0
- package/dist/src/lib/icpAgent.d.ts.map +1 -0
- package/dist/src/lib/icpAgent.js +90 -0
- package/dist/src/lib/iface.d.ts +195 -0
- package/dist/src/lib/iface.d.ts.map +1 -0
- package/dist/src/lib/iface.js +44 -0
- package/dist/src/lib/index.d.ts +4 -0
- package/dist/src/lib/index.d.ts.map +1 -1
- package/dist/src/lib/index.js +12 -2
- package/dist/src/lib/signedTransactionBuilder.d.ts +9 -0
- package/dist/src/lib/signedTransactionBuilder.d.ts.map +1 -0
- package/dist/src/lib/signedTransactionBuilder.js +64 -0
- package/dist/src/lib/transaction.d.ts +54 -0
- package/dist/src/lib/transaction.d.ts.map +1 -0
- package/dist/src/lib/transaction.js +255 -0
- package/dist/src/lib/transactionBuilder.d.ts +58 -28
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilder.js +127 -40
- package/dist/src/lib/transactionBuilderFactory.d.ts +15 -14
- package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilderFactory.js +43 -27
- package/dist/src/lib/transferBuilder.d.ts +7 -24
- package/dist/src/lib/transferBuilder.d.ts.map +1 -1
- package/dist/src/lib/transferBuilder.js +88 -43
- package/dist/src/lib/unsignedTransactionBuilder.d.ts +13 -0
- package/dist/src/lib/unsignedTransactionBuilder.d.ts.map +1 -0
- package/dist/src/lib/unsignedTransactionBuilder.js +90 -0
- package/dist/src/lib/utils.d.ts +286 -8
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +615 -53
- package/dist/src/ticp.d.ts +0 -4
- package/dist/src/ticp.d.ts.map +1 -1
- package/dist/src/ticp.js +1 -7
- package/dist/test/resources/icp.d.ts +268 -0
- package/dist/test/resources/icp.d.ts.map +1 -0
- package/dist/test/resources/icp.js +377 -0
- package/dist/test/unit/getBuilderFactory.d.ts +3 -0
- package/dist/test/unit/getBuilderFactory.d.ts.map +1 -0
- package/dist/test/unit/getBuilderFactory.js +10 -0
- package/dist/test/unit/icp.d.ts +2 -0
- package/dist/test/unit/icp.d.ts.map +1 -0
- package/dist/test/unit/icp.js +418 -0
- package/dist/test/unit/keyPair.d.ts +2 -0
- package/dist/test/unit/keyPair.d.ts.map +1 -0
- package/dist/test/unit/keyPair.js +107 -0
- package/dist/test/unit/transaction.d.ts +2 -0
- package/dist/test/unit/transaction.d.ts.map +1 -0
- package/dist/test/unit/transaction.js +109 -0
- package/dist/test/unit/transactionBuilder/transactionBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/transactionBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/transactionBuilder.js +274 -0
- package/dist/test/unit/transactionBuilder/transactionRecover.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/transactionRecover.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/transactionRecover.js +188 -0
- package/dist/test/unit/utils.d.ts +2 -0
- package/dist/test/unit/utils.d.ts.map +1 -0
- package/dist/test/unit/utils.js +206 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +23 -12
- package/.eslintignore +0 -4
- package/.mocharc.yml +0 -8
- package/CHANGELOG.md +0 -54
|
@@ -0,0 +1,418 @@
|
|
|
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
|
+
const sdk_test_1 = require("@bitgo-beta/sdk-test");
|
|
40
|
+
const sdk_api_1 = require("@bitgo-beta/sdk-api");
|
|
41
|
+
const utils_1 = __importDefault(require("../../src/lib/utils"));
|
|
42
|
+
const getBuilderFactory_1 = require("./getBuilderFactory");
|
|
43
|
+
const index_1 = require("../../src/index");
|
|
44
|
+
const nock_1 = __importDefault(require("nock"));
|
|
45
|
+
const testData = __importStar(require("../resources/icp"));
|
|
46
|
+
const assert_1 = __importDefault(require("assert"));
|
|
47
|
+
const should_1 = __importDefault(require("should"));
|
|
48
|
+
nock_1.default.enableNetConnect();
|
|
49
|
+
const bitgo = sdk_test_1.TestBitGo.decorate(sdk_api_1.BitGoAPI, { env: 'test' });
|
|
50
|
+
bitgo.safeRegister('icp', index_1.Icp.createInstance);
|
|
51
|
+
describe('Internet computer', function () {
|
|
52
|
+
let bitgo;
|
|
53
|
+
let basecoin;
|
|
54
|
+
const factory = (0, getBuilderFactory_1.getBuilderFactory)('icp');
|
|
55
|
+
let txBuilder;
|
|
56
|
+
before(async function () {
|
|
57
|
+
bitgo = sdk_test_1.TestBitGo.decorate(sdk_api_1.BitGoAPI, { env: 'test' });
|
|
58
|
+
bitgo.safeRegister('icp', index_1.Icp.createInstance);
|
|
59
|
+
bitgo.safeRegister('ticp', index_1.Ticp.createInstance);
|
|
60
|
+
bitgo.initializeTestVars();
|
|
61
|
+
basecoin = bitgo.coin('icp');
|
|
62
|
+
txBuilder = factory.getTransferBuilder();
|
|
63
|
+
txBuilder.sender(testData.Accounts.account1.address, testData.Accounts.account1.publicKey);
|
|
64
|
+
txBuilder.receiverId(testData.Accounts.account2.address);
|
|
65
|
+
txBuilder.amount('10');
|
|
66
|
+
txBuilder.memo(testData.MetaDataWithMemo.memo);
|
|
67
|
+
await txBuilder.build();
|
|
68
|
+
});
|
|
69
|
+
after(function () {
|
|
70
|
+
nock_1.default.pendingMocks().should.be.empty();
|
|
71
|
+
nock_1.default.cleanAll();
|
|
72
|
+
});
|
|
73
|
+
it('should return the right info', function () {
|
|
74
|
+
const icp = bitgo.coin('icp');
|
|
75
|
+
const ticp = bitgo.coin('ticp');
|
|
76
|
+
icp.getChain().should.equal('icp');
|
|
77
|
+
icp.getFamily().should.equal('icp');
|
|
78
|
+
icp.getFullName().should.equal('Internet Computer');
|
|
79
|
+
icp.getBaseFactor().should.equal(1e8);
|
|
80
|
+
icp.supportsTss().should.equal(true);
|
|
81
|
+
ticp.getChain().should.equal('ticp');
|
|
82
|
+
ticp.getFamily().should.equal('icp');
|
|
83
|
+
ticp.getFullName().should.equal('Testnet Internet Computer');
|
|
84
|
+
ticp.getBaseFactor().should.equal(1e8);
|
|
85
|
+
icp.supportsTss().should.equal(true);
|
|
86
|
+
});
|
|
87
|
+
describe('Address creation', () => {
|
|
88
|
+
const hexEncodedPublicKey = '047a83e378053f87b49aeae53b3ed274c8b2ffbe59d9a51e3c4d850ca8ac1684f7131b778317c0db04de661c7d08321d60c0507868af41fe3150d21b3c6c757367';
|
|
89
|
+
const hexEncodedPublicKey2 = '02ad010ce68b75266c723bf25fbe3a0c48eb29f14b25925b06b7f5026a0f12702e';
|
|
90
|
+
const invalidPublicKey = 'invalid-public-key';
|
|
91
|
+
const validAccountID = '8b84c3a3529d02a9decb5b1a27e7c8d886e17e07ea0a538269697ef09c2a27b4';
|
|
92
|
+
const validAccountID2 = '2b9b89604362e185544c8bba76cadff1a3af26e1467e8530d13743a08a52dd7b';
|
|
93
|
+
it('should return true when validating a hex encoded public key', function () {
|
|
94
|
+
basecoin.isValidPub(hexEncodedPublicKey).should.equal(true);
|
|
95
|
+
});
|
|
96
|
+
it('should return true when validating a hex encoded public key with 33 bytes ', function () {
|
|
97
|
+
basecoin.isValidPub(hexEncodedPublicKey2).should.equal(true);
|
|
98
|
+
});
|
|
99
|
+
it('should return false when validating a invalid public key', function () {
|
|
100
|
+
basecoin.isValidPub(invalidPublicKey).should.equal(false);
|
|
101
|
+
});
|
|
102
|
+
it('should return valid address from a valid hex encoded public key', async function () {
|
|
103
|
+
const accountID = await basecoin.getAddressFromPublicKey(hexEncodedPublicKey);
|
|
104
|
+
accountID.should.deepEqual(validAccountID);
|
|
105
|
+
});
|
|
106
|
+
it('should return valid address from a valid hex encoded public key with 33 bytes', async function () {
|
|
107
|
+
const accountID = await basecoin.getAddressFromPublicKey(hexEncodedPublicKey2);
|
|
108
|
+
accountID.should.deepEqual(validAccountID2);
|
|
109
|
+
});
|
|
110
|
+
it('should throw an error when invalid public key is provided', function () {
|
|
111
|
+
(() => basecoin.getAddressFromPublicKey(invalidPublicKey)).should.throw('Invalid hex-encoded public key format.');
|
|
112
|
+
});
|
|
113
|
+
it('should return valid address from a valid hex encoded public key', function () {
|
|
114
|
+
const accountID = utils_1.default.getAddressFromPublicKey(hexEncodedPublicKey);
|
|
115
|
+
accountID.should.deepEqual(validAccountID);
|
|
116
|
+
});
|
|
117
|
+
it('should throw an error when invalid public key is provided', function () {
|
|
118
|
+
(() => utils_1.default.getAddressFromPublicKey(invalidPublicKey)).should.throw('Invalid hex-encoded public key format.');
|
|
119
|
+
});
|
|
120
|
+
});
|
|
121
|
+
describe('Generate wallet key pair: ', () => {
|
|
122
|
+
it('should generate key pair', () => {
|
|
123
|
+
const kp = basecoin.generateKeyPair();
|
|
124
|
+
basecoin.isValidPub(kp.pub).should.equal(true);
|
|
125
|
+
basecoin.isValidPrv(kp.prv).should.equal(true);
|
|
126
|
+
});
|
|
127
|
+
it('should generate key pair from seed', () => {
|
|
128
|
+
const seed = Buffer.from('9d61b19deffd5a60ba844af492ec2cc44449c5697b326919703bac031cae7f60', 'hex');
|
|
129
|
+
const kp = basecoin.generateKeyPair(seed);
|
|
130
|
+
basecoin.isValidPub(kp.pub).should.equal(true);
|
|
131
|
+
basecoin.isValidPrv(kp.prv).should.equal(true);
|
|
132
|
+
});
|
|
133
|
+
});
|
|
134
|
+
describe('Sign a raw txn with a private key', () => {
|
|
135
|
+
it('should sign a raw txn with a private key', async () => {
|
|
136
|
+
const unsignedTxn = txBuilder.transaction.unsignedTransaction;
|
|
137
|
+
unsignedTxn.should.be.a.String();
|
|
138
|
+
const payloadsData = txBuilder.transaction.payloadsData;
|
|
139
|
+
const serializedTxFormat = {
|
|
140
|
+
serializedTxHex: payloadsData,
|
|
141
|
+
publicKey: testData.Accounts.account1.publicKey,
|
|
142
|
+
};
|
|
143
|
+
const serializedTxHex = Buffer.from(JSON.stringify(serializedTxFormat), 'utf-8').toString('hex');
|
|
144
|
+
const signedTxn = await basecoin.signTransaction({
|
|
145
|
+
txPrebuild: {
|
|
146
|
+
txHex: serializedTxHex,
|
|
147
|
+
},
|
|
148
|
+
prv: testData.Accounts.account1.secretKey,
|
|
149
|
+
});
|
|
150
|
+
signedTxn.should.be.a.string;
|
|
151
|
+
const parsedTransaction = await factory.parseTransaction(signedTxn.txHex, true);
|
|
152
|
+
should_1.default.equal(parsedTransaction.operations[0].account.address, testData.Accounts.account1.address);
|
|
153
|
+
should_1.default.equal(parsedTransaction.operations[1].account.address, testData.Accounts.account2.address);
|
|
154
|
+
should_1.default.equal(parsedTransaction.operations[2].account.address, testData.Accounts.account1.address);
|
|
155
|
+
should_1.default.equal(parsedTransaction.operations[0].amount.value, '-10');
|
|
156
|
+
should_1.default.equal(parsedTransaction.account_identifier_signers[0].address, testData.Accounts.account1.address);
|
|
157
|
+
});
|
|
158
|
+
});
|
|
159
|
+
describe('Verify a transaction', () => {
|
|
160
|
+
it('should successfully verify a transaction with signable Hex', async () => {
|
|
161
|
+
const unsignedTxn = txBuilder.transaction.unsignedTransaction;
|
|
162
|
+
unsignedTxn.should.be.a.String();
|
|
163
|
+
const payloadsData = txBuilder.transaction.payloadsData;
|
|
164
|
+
const serializedTxFormat = {
|
|
165
|
+
serializedTxHex: payloadsData,
|
|
166
|
+
publicKey: testData.Accounts.account1.publicKey,
|
|
167
|
+
};
|
|
168
|
+
const signableHex = payloadsData.payloads[0].hex_bytes;
|
|
169
|
+
const serializedTxHex = Buffer.from(JSON.stringify(serializedTxFormat), 'utf-8').toString('hex');
|
|
170
|
+
const txParams = {
|
|
171
|
+
recipients: [
|
|
172
|
+
{
|
|
173
|
+
address: testData.Accounts.account2.address,
|
|
174
|
+
amount: '10',
|
|
175
|
+
},
|
|
176
|
+
],
|
|
177
|
+
};
|
|
178
|
+
const response = await basecoin.verifyTransaction({
|
|
179
|
+
txPrebuild: {
|
|
180
|
+
txHex: serializedTxHex,
|
|
181
|
+
txInfo: signableHex,
|
|
182
|
+
},
|
|
183
|
+
txParams: txParams,
|
|
184
|
+
});
|
|
185
|
+
(0, assert_1.default)(response);
|
|
186
|
+
});
|
|
187
|
+
it('should successfully verify a transaction without signable Hex', async () => {
|
|
188
|
+
const unsignedTxn = txBuilder.transaction.unsignedTransaction;
|
|
189
|
+
unsignedTxn.should.be.a.String();
|
|
190
|
+
const payloadsData = txBuilder.transaction.payloadsData;
|
|
191
|
+
const serializedTxFormat = {
|
|
192
|
+
serializedTxHex: payloadsData,
|
|
193
|
+
publicKey: testData.Accounts.account1.publicKey,
|
|
194
|
+
};
|
|
195
|
+
const serializedTxHex = Buffer.from(JSON.stringify(serializedTxFormat), 'utf-8').toString('hex');
|
|
196
|
+
const txParams = {
|
|
197
|
+
recipients: [
|
|
198
|
+
{
|
|
199
|
+
address: testData.Accounts.account2.address,
|
|
200
|
+
amount: '10',
|
|
201
|
+
},
|
|
202
|
+
],
|
|
203
|
+
};
|
|
204
|
+
const response = await basecoin.verifyTransaction({
|
|
205
|
+
txPrebuild: {
|
|
206
|
+
txHex: serializedTxHex,
|
|
207
|
+
},
|
|
208
|
+
txParams: txParams,
|
|
209
|
+
});
|
|
210
|
+
(0, assert_1.default)(response);
|
|
211
|
+
});
|
|
212
|
+
it('should fail to verify a transaction with wrong signable Hex', async () => {
|
|
213
|
+
const unsignedTxn = txBuilder.transaction.unsignedTransaction;
|
|
214
|
+
unsignedTxn.should.be.a.String();
|
|
215
|
+
const payloadsData = txBuilder.transaction.payloadsData;
|
|
216
|
+
const serializedTxFormat = {
|
|
217
|
+
serializedTxHex: payloadsData,
|
|
218
|
+
publicKey: testData.Accounts.account1.publicKey,
|
|
219
|
+
};
|
|
220
|
+
const serializedTxHex = Buffer.from(JSON.stringify(serializedTxFormat), 'utf-8').toString('hex');
|
|
221
|
+
const txParams = {
|
|
222
|
+
recipients: [
|
|
223
|
+
{
|
|
224
|
+
address: testData.Accounts.account2.address,
|
|
225
|
+
amount: '10',
|
|
226
|
+
},
|
|
227
|
+
],
|
|
228
|
+
};
|
|
229
|
+
const wrongSignableHexValues = '0a69632d72657175657374523de3c7c5b4613155b74ede2e54493f6acbe8bf6d910154fbbb3a98ba3e0098';
|
|
230
|
+
await basecoin
|
|
231
|
+
.verifyTransaction({
|
|
232
|
+
txPrebuild: {
|
|
233
|
+
txHex: serializedTxHex,
|
|
234
|
+
txInfo: wrongSignableHexValues,
|
|
235
|
+
},
|
|
236
|
+
txParams: txParams,
|
|
237
|
+
})
|
|
238
|
+
.should.rejectedWith('generated signableHex is not equal to params.signableHex');
|
|
239
|
+
});
|
|
240
|
+
});
|
|
241
|
+
describe('Address Verification', () => {
|
|
242
|
+
const addressVerificationData = {
|
|
243
|
+
commonKeychain: '036b38ca5e63e9800b5040af498eb6e9a9c77e244ac2858edafa4bd0926a635731c3fabde9007a5771e93621d9fcb1c879660208dc79cc609fe8ddd189f7a955ab',
|
|
244
|
+
rootAddress: 'fd3eaed3e2064bd30ab497e22e8ac5a0dcadd81fa5353879dbab64e259ec70c0',
|
|
245
|
+
};
|
|
246
|
+
describe('Wallet VersionKey 1', () => {
|
|
247
|
+
let keychains;
|
|
248
|
+
before(function () {
|
|
249
|
+
keychains = [
|
|
250
|
+
{ commonKeychain: addressVerificationData.commonKeychain },
|
|
251
|
+
{ commonKeychain: addressVerificationData.commonKeychain },
|
|
252
|
+
{ commonKeychain: addressVerificationData.commonKeychain },
|
|
253
|
+
];
|
|
254
|
+
});
|
|
255
|
+
it('should verify a valid memo-based address', async function () {
|
|
256
|
+
const rootAddress = addressVerificationData.rootAddress;
|
|
257
|
+
const addressWithMemo = `${rootAddress}?memoId=123`;
|
|
258
|
+
const params = {
|
|
259
|
+
address: addressWithMemo,
|
|
260
|
+
rootAddress: rootAddress,
|
|
261
|
+
walletVersion: 1,
|
|
262
|
+
keychains: keychains,
|
|
263
|
+
index: 0,
|
|
264
|
+
};
|
|
265
|
+
const result = await basecoin.isWalletAddress(params);
|
|
266
|
+
result.should.equal(true);
|
|
267
|
+
});
|
|
268
|
+
it('should verify address with memoId=0', async function () {
|
|
269
|
+
const rootAddress = addressVerificationData.rootAddress;
|
|
270
|
+
const addressWithMemo = `${rootAddress}?memoId=0`;
|
|
271
|
+
const params = {
|
|
272
|
+
address: addressWithMemo,
|
|
273
|
+
rootAddress: rootAddress,
|
|
274
|
+
walletVersion: 1,
|
|
275
|
+
keychains: keychains,
|
|
276
|
+
index: 0,
|
|
277
|
+
};
|
|
278
|
+
const result = await basecoin.isWalletAddress(params);
|
|
279
|
+
result.should.equal(true);
|
|
280
|
+
});
|
|
281
|
+
it('should fail when extracted root does not match provided rootAddress param', async function () {
|
|
282
|
+
const rootAddress = addressVerificationData.rootAddress;
|
|
283
|
+
const differentAddress = testData.Accounts.account2.address;
|
|
284
|
+
const addressWithMemo = `${differentAddress}?memoId=123`;
|
|
285
|
+
const params = {
|
|
286
|
+
address: addressWithMemo,
|
|
287
|
+
rootAddress: rootAddress,
|
|
288
|
+
walletVersion: 1,
|
|
289
|
+
keychains: keychains,
|
|
290
|
+
index: 0,
|
|
291
|
+
};
|
|
292
|
+
// The extracted root (differentAddress) doesn't match provided rootAddress
|
|
293
|
+
await basecoin
|
|
294
|
+
.isWalletAddress(params)
|
|
295
|
+
.should.be.rejectedWith(`address validation failure: expected ${rootAddress} but got ${differentAddress}`);
|
|
296
|
+
});
|
|
297
|
+
it('should throw error when rootAddress is missing for wallet version 1', async function () {
|
|
298
|
+
const address = `${addressVerificationData.rootAddress}?memoId=123`;
|
|
299
|
+
const params = {
|
|
300
|
+
address: address,
|
|
301
|
+
walletVersion: 1,
|
|
302
|
+
keychains: keychains,
|
|
303
|
+
index: 0,
|
|
304
|
+
};
|
|
305
|
+
await basecoin.isWalletAddress(params).should.be.rejectedWith('rootAddress is required for wallet version 1');
|
|
306
|
+
});
|
|
307
|
+
it('should throw error when memoId is missing for wallet version 1', async function () {
|
|
308
|
+
const rootAddress = addressVerificationData.rootAddress;
|
|
309
|
+
const params = {
|
|
310
|
+
address: rootAddress,
|
|
311
|
+
rootAddress: rootAddress,
|
|
312
|
+
walletVersion: 1,
|
|
313
|
+
keychains: keychains,
|
|
314
|
+
index: 0,
|
|
315
|
+
};
|
|
316
|
+
await basecoin
|
|
317
|
+
.isWalletAddress(params)
|
|
318
|
+
.should.be.rejectedWith('memoId is required for wallet version 1 addresses');
|
|
319
|
+
});
|
|
320
|
+
it('should handle large memoId values', async function () {
|
|
321
|
+
const rootAddress = addressVerificationData.rootAddress;
|
|
322
|
+
const largeMemoId = '9007199254740991';
|
|
323
|
+
const addressWithMemo = `${rootAddress}?memoId=${largeMemoId}`;
|
|
324
|
+
const params = {
|
|
325
|
+
address: addressWithMemo,
|
|
326
|
+
rootAddress: rootAddress,
|
|
327
|
+
walletVersion: 1,
|
|
328
|
+
keychains: keychains,
|
|
329
|
+
index: 0,
|
|
330
|
+
};
|
|
331
|
+
const result = await basecoin.isWalletAddress(params);
|
|
332
|
+
result.should.equal(true);
|
|
333
|
+
});
|
|
334
|
+
it('should fail when rootAddress does not match commonKeychain derivation', async function () {
|
|
335
|
+
// Use a rootAddress that doesn't match what's derived from commonKeychain
|
|
336
|
+
const invalidRootAddress = testData.Accounts.account1.address;
|
|
337
|
+
const addressWithMemo = `${invalidRootAddress}?memoId=123`;
|
|
338
|
+
const params = {
|
|
339
|
+
address: addressWithMemo,
|
|
340
|
+
rootAddress: invalidRootAddress,
|
|
341
|
+
walletVersion: 1,
|
|
342
|
+
keychains: keychains,
|
|
343
|
+
index: 0,
|
|
344
|
+
};
|
|
345
|
+
// rootAddress is cryptographically verified against commonKeychain
|
|
346
|
+
await basecoin
|
|
347
|
+
.isWalletAddress(params)
|
|
348
|
+
.should.be.rejectedWith(`address validation failure: address ${invalidRootAddress} is not a wallet address`);
|
|
349
|
+
});
|
|
350
|
+
});
|
|
351
|
+
describe('Wallet VersionKey 2+', () => {
|
|
352
|
+
let keychains;
|
|
353
|
+
before(function () {
|
|
354
|
+
keychains = [
|
|
355
|
+
{ commonKeychain: addressVerificationData.commonKeychain },
|
|
356
|
+
{ commonKeychain: addressVerificationData.commonKeychain },
|
|
357
|
+
{ commonKeychain: addressVerificationData.commonKeychain },
|
|
358
|
+
];
|
|
359
|
+
});
|
|
360
|
+
it('should verify a valid TSS root address (index 0)', async function () {
|
|
361
|
+
const params = {
|
|
362
|
+
address: addressVerificationData.rootAddress,
|
|
363
|
+
rootAddress: addressVerificationData.rootAddress,
|
|
364
|
+
keychains: keychains,
|
|
365
|
+
index: 0,
|
|
366
|
+
walletVersion: 2,
|
|
367
|
+
};
|
|
368
|
+
const result = await basecoin.isWalletAddress(params);
|
|
369
|
+
result.should.equal(true);
|
|
370
|
+
});
|
|
371
|
+
it('should throw error for invalid TSS address', async function () {
|
|
372
|
+
const invalidAddress = testData.Accounts.account2.address;
|
|
373
|
+
const params = {
|
|
374
|
+
address: invalidAddress,
|
|
375
|
+
keychains: keychains,
|
|
376
|
+
index: 0,
|
|
377
|
+
walletVersion: 2,
|
|
378
|
+
};
|
|
379
|
+
await basecoin
|
|
380
|
+
.isWalletAddress(params)
|
|
381
|
+
.should.be.rejectedWith(`address validation failure: address ${invalidAddress} is not a wallet address`);
|
|
382
|
+
});
|
|
383
|
+
it('should throw error when keychains is missing', async function () {
|
|
384
|
+
const params = {
|
|
385
|
+
address: addressVerificationData.rootAddress,
|
|
386
|
+
keychains: [],
|
|
387
|
+
index: 0,
|
|
388
|
+
walletVersion: 2,
|
|
389
|
+
};
|
|
390
|
+
await basecoin.isWalletAddress(params).should.be.rejectedWith('missing required param keychains');
|
|
391
|
+
});
|
|
392
|
+
it('should handle string index', async function () {
|
|
393
|
+
const params = {
|
|
394
|
+
address: addressVerificationData.rootAddress,
|
|
395
|
+
rootAddress: addressVerificationData.rootAddress,
|
|
396
|
+
keychains: keychains,
|
|
397
|
+
index: '0',
|
|
398
|
+
walletVersion: 2,
|
|
399
|
+
};
|
|
400
|
+
const result = await basecoin.isWalletAddress(params);
|
|
401
|
+
result.should.equal(true);
|
|
402
|
+
});
|
|
403
|
+
});
|
|
404
|
+
describe('Address validation', () => {
|
|
405
|
+
it('should throw error for invalid address format', async function () {
|
|
406
|
+
const invalidAddress = 'invalid-address';
|
|
407
|
+
const params = {
|
|
408
|
+
address: invalidAddress,
|
|
409
|
+
walletVersion: 2,
|
|
410
|
+
keychains: [{ commonKeychain: addressVerificationData.commonKeychain }],
|
|
411
|
+
index: 0,
|
|
412
|
+
};
|
|
413
|
+
await basecoin.isWalletAddress(params).should.be.rejectedWith(`invalid address: ${invalidAddress}`);
|
|
414
|
+
});
|
|
415
|
+
});
|
|
416
|
+
});
|
|
417
|
+
});
|
|
418
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icp.js","sourceRoot":"","sources":["../../../test/unit/icp.ts"],"names":[],"mappings":"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","sourcesContent":["import { TestBitGo, TestBitGoAPI } from '@bitgo-beta/sdk-test';\nimport { BitGoAPI } from '@bitgo-beta/sdk-api';\nimport utils from '../../src/lib/utils';\nimport { getBuilderFactory } from './getBuilderFactory';\n\nimport { Icp, Ticp } from '../../src/index';\nimport nock from 'nock';\nimport * as testData from '../resources/icp';\nimport assert from 'assert';\nimport should from 'should';\nnock.enableNetConnect();\n\nconst bitgo: TestBitGoAPI = TestBitGo.decorate(BitGoAPI, { env: 'test' });\nbitgo.safeRegister('icp', Icp.createInstance);\n\ndescribe('Internet computer', function () {\n  let bitgo;\n  let basecoin;\n  const factory = getBuilderFactory('icp');\n  let txBuilder: any;\n\n  before(async function () {\n    bitgo = TestBitGo.decorate(BitGoAPI, { env: 'test' });\n    bitgo.safeRegister('icp', Icp.createInstance);\n    bitgo.safeRegister('ticp', Ticp.createInstance);\n    bitgo.initializeTestVars();\n    basecoin = bitgo.coin('icp');\n\n    txBuilder = factory.getTransferBuilder();\n    txBuilder.sender(testData.Accounts.account1.address, testData.Accounts.account1.publicKey);\n    txBuilder.receiverId(testData.Accounts.account2.address);\n    txBuilder.amount('10');\n    txBuilder.memo(testData.MetaDataWithMemo.memo);\n\n    await txBuilder.build();\n  });\n\n  after(function () {\n    nock.pendingMocks().should.be.empty();\n    nock.cleanAll();\n  });\n\n  it('should return the right info', function () {\n    const icp = bitgo.coin('icp');\n    const ticp = bitgo.coin('ticp');\n\n    icp.getChain().should.equal('icp');\n    icp.getFamily().should.equal('icp');\n    icp.getFullName().should.equal('Internet Computer');\n    icp.getBaseFactor().should.equal(1e8);\n    icp.supportsTss().should.equal(true);\n\n    ticp.getChain().should.equal('ticp');\n    ticp.getFamily().should.equal('icp');\n    ticp.getFullName().should.equal('Testnet Internet Computer');\n    ticp.getBaseFactor().should.equal(1e8);\n    icp.supportsTss().should.equal(true);\n  });\n\n  describe('Address creation', () => {\n    const hexEncodedPublicKey =\n      '047a83e378053f87b49aeae53b3ed274c8b2ffbe59d9a51e3c4d850ca8ac1684f7131b778317c0db04de661c7d08321d60c0507868af41fe3150d21b3c6c757367';\n    const hexEncodedPublicKey2 = '02ad010ce68b75266c723bf25fbe3a0c48eb29f14b25925b06b7f5026a0f12702e';\n    const invalidPublicKey = 'invalid-public-key';\n    const validAccountID = '8b84c3a3529d02a9decb5b1a27e7c8d886e17e07ea0a538269697ef09c2a27b4';\n    const validAccountID2 = '2b9b89604362e185544c8bba76cadff1a3af26e1467e8530d13743a08a52dd7b';\n\n    it('should return true when validating a hex encoded public key', function () {\n      basecoin.isValidPub(hexEncodedPublicKey).should.equal(true);\n    });\n\n    it('should return true when validating a hex encoded public key with 33 bytes ', function () {\n      basecoin.isValidPub(hexEncodedPublicKey2).should.equal(true);\n    });\n\n    it('should return false when validating a invalid public key', function () {\n      basecoin.isValidPub(invalidPublicKey).should.equal(false);\n    });\n\n    it('should return valid address from a valid hex encoded public key', async function () {\n      const accountID = await basecoin.getAddressFromPublicKey(hexEncodedPublicKey);\n      accountID.should.deepEqual(validAccountID);\n    });\n\n    it('should return valid address from a valid hex encoded public key with 33 bytes', async function () {\n      const accountID = await basecoin.getAddressFromPublicKey(hexEncodedPublicKey2);\n      accountID.should.deepEqual(validAccountID2);\n    });\n\n    it('should throw an error when invalid public key is provided', function () {\n      (() => basecoin.getAddressFromPublicKey(invalidPublicKey)).should.throw('Invalid hex-encoded public key format.');\n    });\n\n    it('should return valid address from a valid hex encoded public key', function () {\n      const accountID = utils.getAddressFromPublicKey(hexEncodedPublicKey);\n      accountID.should.deepEqual(validAccountID);\n    });\n\n    it('should throw an error when invalid public key is provided', function () {\n      (() => utils.getAddressFromPublicKey(invalidPublicKey)).should.throw('Invalid hex-encoded public key format.');\n    });\n  });\n\n  describe('Generate wallet key pair: ', () => {\n    it('should generate key pair', () => {\n      const kp = basecoin.generateKeyPair();\n      basecoin.isValidPub(kp.pub).should.equal(true);\n      basecoin.isValidPrv(kp.prv).should.equal(true);\n    });\n\n    it('should generate key pair from seed', () => {\n      const seed = Buffer.from('9d61b19deffd5a60ba844af492ec2cc44449c5697b326919703bac031cae7f60', 'hex');\n      const kp = basecoin.generateKeyPair(seed);\n      basecoin.isValidPub(kp.pub).should.equal(true);\n      basecoin.isValidPrv(kp.prv).should.equal(true);\n    });\n  });\n\n  describe('Sign a raw txn with a private key', () => {\n    it('should sign a raw txn with a private key', async () => {\n      const unsignedTxn = txBuilder.transaction.unsignedTransaction;\n      unsignedTxn.should.be.a.String();\n      const payloadsData = txBuilder.transaction.payloadsData;\n      const serializedTxFormat = {\n        serializedTxHex: payloadsData,\n        publicKey: testData.Accounts.account1.publicKey,\n      };\n      const serializedTxHex = Buffer.from(JSON.stringify(serializedTxFormat), 'utf-8').toString('hex');\n      const signedTxn = await basecoin.signTransaction({\n        txPrebuild: {\n          txHex: serializedTxHex,\n        },\n        prv: testData.Accounts.account1.secretKey,\n      });\n      signedTxn.should.be.a.string;\n      const parsedTransaction = await factory.parseTransaction(signedTxn.txHex, true);\n      should.equal(parsedTransaction.operations[0].account.address, testData.Accounts.account1.address);\n      should.equal(parsedTransaction.operations[1].account.address, testData.Accounts.account2.address);\n      should.equal(parsedTransaction.operations[2].account.address, testData.Accounts.account1.address);\n      should.equal(parsedTransaction.operations[0].amount.value, '-10');\n      should.equal(parsedTransaction.account_identifier_signers[0].address, testData.Accounts.account1.address);\n    });\n  });\n\n  describe('Verify a transaction', () => {\n    it('should successfully verify a transaction with signable Hex', async () => {\n      const unsignedTxn = txBuilder.transaction.unsignedTransaction;\n      unsignedTxn.should.be.a.String();\n      const payloadsData = txBuilder.transaction.payloadsData;\n      const serializedTxFormat = {\n        serializedTxHex: payloadsData,\n        publicKey: testData.Accounts.account1.publicKey,\n      };\n      const signableHex = payloadsData.payloads[0].hex_bytes;\n      const serializedTxHex = Buffer.from(JSON.stringify(serializedTxFormat), 'utf-8').toString('hex');\n      const txParams = {\n        recipients: [\n          {\n            address: testData.Accounts.account2.address,\n            amount: '10',\n          },\n        ],\n      };\n      const response = await basecoin.verifyTransaction({\n        txPrebuild: {\n          txHex: serializedTxHex,\n          txInfo: signableHex,\n        },\n        txParams: txParams,\n      });\n      assert(response);\n    });\n\n    it('should successfully verify a transaction without signable Hex', async () => {\n      const unsignedTxn = txBuilder.transaction.unsignedTransaction;\n      unsignedTxn.should.be.a.String();\n      const payloadsData = txBuilder.transaction.payloadsData;\n      const serializedTxFormat = {\n        serializedTxHex: payloadsData,\n        publicKey: testData.Accounts.account1.publicKey,\n      };\n      const serializedTxHex = Buffer.from(JSON.stringify(serializedTxFormat), 'utf-8').toString('hex');\n      const txParams = {\n        recipients: [\n          {\n            address: testData.Accounts.account2.address,\n            amount: '10',\n          },\n        ],\n      };\n      const response = await basecoin.verifyTransaction({\n        txPrebuild: {\n          txHex: serializedTxHex,\n        },\n        txParams: txParams,\n      });\n      assert(response);\n    });\n\n    it('should fail to verify a transaction with wrong signable Hex', async () => {\n      const unsignedTxn = txBuilder.transaction.unsignedTransaction;\n      unsignedTxn.should.be.a.String();\n      const payloadsData = txBuilder.transaction.payloadsData;\n      const serializedTxFormat = {\n        serializedTxHex: payloadsData,\n        publicKey: testData.Accounts.account1.publicKey,\n      };\n      const serializedTxHex = Buffer.from(JSON.stringify(serializedTxFormat), 'utf-8').toString('hex');\n      const txParams = {\n        recipients: [\n          {\n            address: testData.Accounts.account2.address,\n            amount: '10',\n          },\n        ],\n      };\n\n      const wrongSignableHexValues =\n        '0a69632d72657175657374523de3c7c5b4613155b74ede2e54493f6acbe8bf6d910154fbbb3a98ba3e0098';\n\n      await basecoin\n        .verifyTransaction({\n          txPrebuild: {\n            txHex: serializedTxHex,\n            txInfo: wrongSignableHexValues,\n          },\n          txParams: txParams,\n        })\n        .should.rejectedWith('generated signableHex is not equal to params.signableHex');\n    });\n  });\n\n  describe('Address Verification', () => {\n    const addressVerificationData = {\n      commonKeychain:\n        '036b38ca5e63e9800b5040af498eb6e9a9c77e244ac2858edafa4bd0926a635731c3fabde9007a5771e93621d9fcb1c879660208dc79cc609fe8ddd189f7a955ab',\n      rootAddress: 'fd3eaed3e2064bd30ab497e22e8ac5a0dcadd81fa5353879dbab64e259ec70c0',\n    };\n\n    describe('Wallet VersionKey 1', () => {\n      let keychains;\n\n      before(function () {\n        keychains = [\n          { commonKeychain: addressVerificationData.commonKeychain },\n          { commonKeychain: addressVerificationData.commonKeychain },\n          { commonKeychain: addressVerificationData.commonKeychain },\n        ];\n      });\n\n      it('should verify a valid memo-based address', async function () {\n        const rootAddress = addressVerificationData.rootAddress;\n        const addressWithMemo = `${rootAddress}?memoId=123`;\n\n        const params = {\n          address: addressWithMemo,\n          rootAddress: rootAddress,\n          walletVersion: 1,\n          keychains: keychains,\n          index: 0,\n        };\n\n        const result = await basecoin.isWalletAddress(params);\n        result.should.equal(true);\n      });\n\n      it('should verify address with memoId=0', async function () {\n        const rootAddress = addressVerificationData.rootAddress;\n        const addressWithMemo = `${rootAddress}?memoId=0`;\n\n        const params = {\n          address: addressWithMemo,\n          rootAddress: rootAddress,\n          walletVersion: 1,\n          keychains: keychains,\n          index: 0,\n        };\n\n        const result = await basecoin.isWalletAddress(params);\n        result.should.equal(true);\n      });\n\n      it('should fail when extracted root does not match provided rootAddress param', async function () {\n        const rootAddress = addressVerificationData.rootAddress;\n        const differentAddress = testData.Accounts.account2.address;\n        const addressWithMemo = `${differentAddress}?memoId=123`;\n\n        const params = {\n          address: addressWithMemo,\n          rootAddress: rootAddress,\n          walletVersion: 1,\n          keychains: keychains,\n          index: 0,\n        };\n\n        // The extracted root (differentAddress) doesn't match provided rootAddress\n        await basecoin\n          .isWalletAddress(params)\n          .should.be.rejectedWith(`address validation failure: expected ${rootAddress} but got ${differentAddress}`);\n      });\n\n      it('should throw error when rootAddress is missing for wallet version 1', async function () {\n        const address = `${addressVerificationData.rootAddress}?memoId=123`;\n\n        const params = {\n          address: address,\n          walletVersion: 1,\n          keychains: keychains,\n          index: 0,\n        };\n\n        await basecoin.isWalletAddress(params).should.be.rejectedWith('rootAddress is required for wallet version 1');\n      });\n\n      it('should throw error when memoId is missing for wallet version 1', async function () {\n        const rootAddress = addressVerificationData.rootAddress;\n\n        const params = {\n          address: rootAddress,\n          rootAddress: rootAddress,\n          walletVersion: 1,\n          keychains: keychains,\n          index: 0,\n        };\n\n        await basecoin\n          .isWalletAddress(params)\n          .should.be.rejectedWith('memoId is required for wallet version 1 addresses');\n      });\n\n      it('should handle large memoId values', async function () {\n        const rootAddress = addressVerificationData.rootAddress;\n        const largeMemoId = '9007199254740991';\n        const addressWithMemo = `${rootAddress}?memoId=${largeMemoId}`;\n\n        const params = {\n          address: addressWithMemo,\n          rootAddress: rootAddress,\n          walletVersion: 1,\n          keychains: keychains,\n          index: 0,\n        };\n\n        const result = await basecoin.isWalletAddress(params);\n        result.should.equal(true);\n      });\n\n      it('should fail when rootAddress does not match commonKeychain derivation', async function () {\n        // Use a rootAddress that doesn't match what's derived from commonKeychain\n        const invalidRootAddress = testData.Accounts.account1.address;\n        const addressWithMemo = `${invalidRootAddress}?memoId=123`;\n\n        const params = {\n          address: addressWithMemo,\n          rootAddress: invalidRootAddress,\n          walletVersion: 1,\n          keychains: keychains,\n          index: 0,\n        };\n\n        // rootAddress is cryptographically verified against commonKeychain\n        await basecoin\n          .isWalletAddress(params)\n          .should.be.rejectedWith(`address validation failure: address ${invalidRootAddress} is not a wallet address`);\n      });\n    });\n\n    describe('Wallet VersionKey 2+', () => {\n      let keychains;\n\n      before(function () {\n        keychains = [\n          { commonKeychain: addressVerificationData.commonKeychain },\n          { commonKeychain: addressVerificationData.commonKeychain },\n          { commonKeychain: addressVerificationData.commonKeychain },\n        ];\n      });\n\n      it('should verify a valid TSS root address (index 0)', async function () {\n        const params = {\n          address: addressVerificationData.rootAddress,\n          rootAddress: addressVerificationData.rootAddress,\n          keychains: keychains,\n          index: 0,\n          walletVersion: 2,\n        };\n\n        const result = await basecoin.isWalletAddress(params);\n        result.should.equal(true);\n      });\n\n      it('should throw error for invalid TSS address', async function () {\n        const invalidAddress = testData.Accounts.account2.address;\n\n        const params = {\n          address: invalidAddress,\n          keychains: keychains,\n          index: 0,\n          walletVersion: 2,\n        };\n\n        await basecoin\n          .isWalletAddress(params)\n          .should.be.rejectedWith(`address validation failure: address ${invalidAddress} is not a wallet address`);\n      });\n\n      it('should throw error when keychains is missing', async function () {\n        const params = {\n          address: addressVerificationData.rootAddress,\n          keychains: [],\n          index: 0,\n          walletVersion: 2,\n        };\n\n        await basecoin.isWalletAddress(params).should.be.rejectedWith('missing required param keychains');\n      });\n\n      it('should handle string index', async function () {\n        const params = {\n          address: addressVerificationData.rootAddress,\n          rootAddress: addressVerificationData.rootAddress,\n          keychains: keychains,\n          index: '0',\n          walletVersion: 2,\n        };\n\n        const result = await basecoin.isWalletAddress(params);\n        result.should.equal(true);\n      });\n    });\n\n    describe('Address validation', () => {\n      it('should throw error for invalid address format', async function () {\n        const invalidAddress = 'invalid-address';\n\n        const params = {\n          address: invalidAddress,\n          walletVersion: 2,\n          keychains: [{ commonKeychain: addressVerificationData.commonKeychain }],\n          index: 0,\n        };\n\n        await basecoin.isWalletAddress(params).should.be.rejectedWith(`invalid address: ${invalidAddress}`);\n      });\n    });\n  });\n});\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"keyPair.d.ts","sourceRoot":"","sources":["../../../test/unit/keyPair.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,107 @@
|
|
|
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 should_1 = __importDefault(require("should"));
|
|
7
|
+
const keyPair_1 = require("../../src/lib/keyPair");
|
|
8
|
+
const crypto_1 = require("crypto");
|
|
9
|
+
describe('ICP KeyPair', () => {
|
|
10
|
+
describe('constructor', () => {
|
|
11
|
+
it('should generate a key pair with a random seed when no source is provided', () => {
|
|
12
|
+
const keyPair = new keyPair_1.KeyPair();
|
|
13
|
+
should_1.default.exist(keyPair);
|
|
14
|
+
const publicKey = keyPair.getKeys().pub;
|
|
15
|
+
const privateKey = keyPair.getKeys().prv;
|
|
16
|
+
should_1.default.exist(publicKey);
|
|
17
|
+
should_1.default.exist(privateKey);
|
|
18
|
+
publicKey.should.be.a.String();
|
|
19
|
+
if (privateKey) {
|
|
20
|
+
privateKey.should.be.a.String();
|
|
21
|
+
}
|
|
22
|
+
});
|
|
23
|
+
it('should generate a key pair from a given seed', () => {
|
|
24
|
+
const seed = (0, crypto_1.randomBytes)(32);
|
|
25
|
+
const keyPair = new keyPair_1.KeyPair({ seed });
|
|
26
|
+
should_1.default.exist(keyPair);
|
|
27
|
+
const publicKey = keyPair.getKeys().pub;
|
|
28
|
+
const privateKey = keyPair.getKeys().prv;
|
|
29
|
+
should_1.default.exist(publicKey);
|
|
30
|
+
should_1.default.exist(privateKey);
|
|
31
|
+
publicKey.should.be.a.String();
|
|
32
|
+
if (privateKey) {
|
|
33
|
+
privateKey.should.be.a.String();
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
it('should generate a key pair from a public key', () => {
|
|
37
|
+
const tempKeyPair = new keyPair_1.KeyPair();
|
|
38
|
+
const publicKey = tempKeyPair.getKeys().pub;
|
|
39
|
+
const keyPair = new keyPair_1.KeyPair({ pub: publicKey });
|
|
40
|
+
should_1.default.exist(keyPair);
|
|
41
|
+
should_1.default.exist(keyPair.getKeys().pub);
|
|
42
|
+
should_1.default.equal(keyPair.getKeys().pub, publicKey);
|
|
43
|
+
});
|
|
44
|
+
it('should generate different key pairs for different seeds', () => {
|
|
45
|
+
const seed1 = (0, crypto_1.randomBytes)(32);
|
|
46
|
+
const seed2 = (0, crypto_1.randomBytes)(32);
|
|
47
|
+
const keyPair1 = new keyPair_1.KeyPair({ seed: seed1 });
|
|
48
|
+
const keyPair2 = new keyPair_1.KeyPair({ seed: seed2 });
|
|
49
|
+
should_1.default.notEqual(keyPair1.getKeys().pub, keyPair2.getKeys().pub);
|
|
50
|
+
should_1.default.notEqual(keyPair1.getKeys().prv, keyPair2.getKeys().prv);
|
|
51
|
+
});
|
|
52
|
+
it('should generate the same key pair for the same seed', () => {
|
|
53
|
+
const seed = (0, crypto_1.randomBytes)(32);
|
|
54
|
+
const keyPair1 = new keyPair_1.KeyPair({ seed });
|
|
55
|
+
const keyPair2 = new keyPair_1.KeyPair({ seed });
|
|
56
|
+
should_1.default.equal(keyPair1.getKeys().pub, keyPair2.getKeys().pub);
|
|
57
|
+
should_1.default.equal(keyPair1.getKeys().prv, keyPair2.getKeys().prv);
|
|
58
|
+
});
|
|
59
|
+
});
|
|
60
|
+
describe('KeyPair getKeys()', () => {
|
|
61
|
+
it('should return valid public and private keys for a randomly generated key pair', () => {
|
|
62
|
+
const keyPair = new keyPair_1.KeyPair();
|
|
63
|
+
const keys = keyPair.getKeys();
|
|
64
|
+
should_1.default.exist(keys);
|
|
65
|
+
should_1.default.exist(keys.pub);
|
|
66
|
+
should_1.default.exist(keys.prv);
|
|
67
|
+
keys.pub.should.be.a.String();
|
|
68
|
+
keys.pub.length.should.be.greaterThan(0);
|
|
69
|
+
if (keys.prv) {
|
|
70
|
+
keys.prv.should.be.a.String();
|
|
71
|
+
keys.prv.length.should.be.greaterThan(0);
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
it('should return valid public and private keys for a key pair generated with a seed', () => {
|
|
75
|
+
const seed = (0, crypto_1.randomBytes)(32);
|
|
76
|
+
const keyPair = new keyPair_1.KeyPair({ seed });
|
|
77
|
+
const keys = keyPair.getKeys();
|
|
78
|
+
should_1.default.exist(keys);
|
|
79
|
+
should_1.default.exist(keys.pub);
|
|
80
|
+
should_1.default.exist(keys.prv);
|
|
81
|
+
keys.pub.should.be.a.String();
|
|
82
|
+
if (keys.prv) {
|
|
83
|
+
keys.prv.should.be.a.String();
|
|
84
|
+
}
|
|
85
|
+
});
|
|
86
|
+
it('should return only a public key when a key pair is generated from a public key', () => {
|
|
87
|
+
const tempKeyPair = new keyPair_1.KeyPair();
|
|
88
|
+
const publicKey = tempKeyPair.getKeys().pub;
|
|
89
|
+
const keyPair = new keyPair_1.KeyPair({ pub: publicKey });
|
|
90
|
+
const keys = keyPair.getKeys();
|
|
91
|
+
should_1.default.exist(keys);
|
|
92
|
+
should_1.default.exist(keys.pub);
|
|
93
|
+
should_1.default.equal(keys.pub, publicKey);
|
|
94
|
+
should_1.default.not.exist(keys.prv);
|
|
95
|
+
});
|
|
96
|
+
it('should generate consistent keys for the same seed', () => {
|
|
97
|
+
const seed = (0, crypto_1.randomBytes)(32);
|
|
98
|
+
const keyPair1 = new keyPair_1.KeyPair({ seed });
|
|
99
|
+
const keyPair2 = new keyPair_1.KeyPair({ seed });
|
|
100
|
+
const keys1 = keyPair1.getKeys();
|
|
101
|
+
const keys2 = keyPair2.getKeys();
|
|
102
|
+
should_1.default.equal(keys1.pub, keys2.pub);
|
|
103
|
+
should_1.default.equal(keys1.prv, keys2.prv);
|
|
104
|
+
});
|
|
105
|
+
});
|
|
106
|
+
});
|
|
107
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keyPair.js","sourceRoot":"","sources":["../../../test/unit/keyPair.ts"],"names":[],"mappings":"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","sourcesContent":["import should from 'should';\nimport { KeyPair } from '../../src/lib/keyPair';\nimport { randomBytes } from 'crypto';\n\ndescribe('ICP KeyPair', () => {\n  describe('constructor', () => {\n    it('should generate a key pair with a random seed when no source is provided', () => {\n      const keyPair = new KeyPair();\n      should.exist(keyPair);\n      const publicKey = keyPair.getKeys().pub;\n      const privateKey = keyPair.getKeys().prv;\n      should.exist(publicKey);\n      should.exist(privateKey);\n      publicKey.should.be.a.String();\n      if (privateKey) {\n        privateKey.should.be.a.String();\n      }\n    });\n\n    it('should generate a key pair from a given seed', () => {\n      const seed = randomBytes(32);\n      const keyPair = new KeyPair({ seed });\n      should.exist(keyPair);\n      const publicKey = keyPair.getKeys().pub;\n      const privateKey = keyPair.getKeys().prv;\n      should.exist(publicKey);\n      should.exist(privateKey);\n      publicKey.should.be.a.String();\n      if (privateKey) {\n        privateKey.should.be.a.String();\n      }\n    });\n\n    it('should generate a key pair from a public key', () => {\n      const tempKeyPair = new KeyPair();\n      const publicKey = tempKeyPair.getKeys().pub;\n      const keyPair = new KeyPair({ pub: publicKey });\n\n      should.exist(keyPair);\n      should.exist(keyPair.getKeys().pub);\n      should.equal(keyPair.getKeys().pub, publicKey);\n    });\n\n    it('should generate different key pairs for different seeds', () => {\n      const seed1 = randomBytes(32);\n      const seed2 = randomBytes(32);\n      const keyPair1 = new KeyPair({ seed: seed1 });\n      const keyPair2 = new KeyPair({ seed: seed2 });\n\n      should.notEqual(keyPair1.getKeys().pub, keyPair2.getKeys().pub);\n      should.notEqual(keyPair1.getKeys().prv, keyPair2.getKeys().prv);\n    });\n\n    it('should generate the same key pair for the same seed', () => {\n      const seed = randomBytes(32);\n      const keyPair1 = new KeyPair({ seed });\n      const keyPair2 = new KeyPair({ seed });\n\n      should.equal(keyPair1.getKeys().pub, keyPair2.getKeys().pub);\n      should.equal(keyPair1.getKeys().prv, keyPair2.getKeys().prv);\n    });\n  });\n\n  describe('KeyPair getKeys()', () => {\n    it('should return valid public and private keys for a randomly generated key pair', () => {\n      const keyPair = new KeyPair();\n      const keys = keyPair.getKeys();\n\n      should.exist(keys);\n      should.exist(keys.pub);\n      should.exist(keys.prv);\n      keys.pub.should.be.a.String();\n      keys.pub.length.should.be.greaterThan(0);\n      if (keys.prv) {\n        keys.prv.should.be.a.String();\n        keys.prv.length.should.be.greaterThan(0);\n      }\n    });\n\n    it('should return valid public and private keys for a key pair generated with a seed', () => {\n      const seed = randomBytes(32);\n      const keyPair = new KeyPair({ seed });\n      const keys = keyPair.getKeys();\n\n      should.exist(keys);\n      should.exist(keys.pub);\n      should.exist(keys.prv);\n      keys.pub.should.be.a.String();\n      if (keys.prv) {\n        keys.prv.should.be.a.String();\n      }\n    });\n\n    it('should return only a public key when a key pair is generated from a public key', () => {\n      const tempKeyPair = new KeyPair();\n      const publicKey = tempKeyPair.getKeys().pub;\n      const keyPair = new KeyPair({ pub: publicKey });\n      const keys = keyPair.getKeys();\n\n      should.exist(keys);\n      should.exist(keys.pub);\n      should.equal(keys.pub, publicKey);\n      should.not.exist(keys.prv);\n    });\n\n    it('should generate consistent keys for the same seed', () => {\n      const seed = randomBytes(32);\n      const keyPair1 = new KeyPair({ seed });\n      const keyPair2 = new KeyPair({ seed });\n\n      const keys1 = keyPair1.getKeys();\n      const keys2 = keyPair2.getKeys();\n\n      should.equal(keys1.pub, keys2.pub);\n      should.equal(keys1.prv, keys2.prv);\n    });\n  });\n});\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../test/unit/transaction.ts"],"names":[],"mappings":""}
|