@bitgo-beta/sdk-coin-flrp 1.0.0-alpha.39 → 1.0.0-alpha.40
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/src/flrp.d.ts +9 -16
- package/dist/src/flrp.d.ts.map +1 -1
- package/dist/src/flrp.js +49 -75
- package/dist/src/index.d.ts +0 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +1 -2
- package/dist/src/lib/ExportInCTxBuilder.d.ts +51 -0
- package/dist/src/lib/ExportInCTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/ExportInCTxBuilder.js +188 -0
- package/dist/src/lib/ExportInPTxBuilder.d.ts +47 -0
- package/dist/src/lib/ExportInPTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/ExportInPTxBuilder.js +273 -0
- package/dist/src/lib/ImportInCTxBuilder.d.ts +48 -0
- package/dist/src/lib/ImportInCTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/ImportInCTxBuilder.js +215 -0
- package/dist/src/lib/ImportInPTxBuilder.d.ts +33 -0
- package/dist/src/lib/ImportInPTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/ImportInPTxBuilder.js +180 -0
- package/dist/src/lib/atomicInCTransactionBuilder.d.ts +18 -16
- package/dist/src/lib/atomicInCTransactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/atomicInCTransactionBuilder.js +38 -36
- package/dist/src/lib/atomicTransactionBuilder.d.ts +42 -79
- package/dist/src/lib/atomicTransactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/atomicTransactionBuilder.js +138 -281
- package/dist/src/lib/iface.d.ts +38 -61
- package/dist/src/lib/iface.d.ts.map +1 -1
- package/dist/src/lib/iface.js +13 -14
- package/dist/src/lib/index.d.ts +3 -3
- package/dist/src/lib/index.d.ts.map +1 -1
- package/dist/src/lib/index.js +8 -7
- package/dist/src/lib/keyPair.d.ts +1 -1
- package/dist/src/lib/keyPair.d.ts.map +1 -1
- package/dist/src/lib/keyPair.js +9 -5
- package/dist/src/lib/permissionlessValidatorTxBuilder.d.ts +29 -67
- package/dist/src/lib/permissionlessValidatorTxBuilder.d.ts.map +1 -1
- package/dist/src/lib/permissionlessValidatorTxBuilder.js +89 -205
- package/dist/src/lib/transaction.d.ts +11 -71
- package/dist/src/lib/transaction.d.ts.map +1 -1
- package/dist/src/lib/transaction.js +255 -204
- package/dist/src/lib/transactionBuilder.d.ts +56 -34
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilder.js +113 -70
- package/dist/src/lib/transactionBuilderFactory.d.ts +50 -30
- package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilderFactory.js +129 -72
- package/dist/src/lib/utils.d.ts +67 -153
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +178 -397
- package/dist/test/resources/account.d.ts +2 -0
- package/dist/test/resources/account.d.ts.map +1 -1
- package/dist/test/resources/account.js +3 -1
- package/dist/test/resources/transactionData/exportInC.d.ts +20 -0
- package/dist/test/resources/transactionData/exportInC.d.ts.map +1 -0
- package/dist/test/resources/transactionData/exportInC.js +34 -0
- package/dist/test/resources/transactionData/exportInP.d.ts +69 -0
- package/dist/test/resources/transactionData/exportInP.d.ts.map +1 -0
- package/dist/test/resources/transactionData/exportInP.js +140 -0
- package/dist/test/resources/transactionData/importInC.d.ts +27 -0
- package/dist/test/resources/transactionData/importInC.d.ts.map +1 -0
- package/dist/test/resources/transactionData/importInC.js +44 -0
- package/dist/test/resources/transactionData/importInP.d.ts +35 -0
- package/dist/test/resources/transactionData/importInP.d.ts.map +1 -0
- package/dist/test/resources/transactionData/importInP.js +58 -0
- package/dist/test/unit/flrp.js +449 -68
- package/dist/test/unit/lib/exportInCTxBuilder.js +95 -513
- package/dist/test/unit/lib/exportInPTxBuilder.d.ts +1 -1
- package/dist/test/unit/lib/exportInPTxBuilder.d.ts.map +1 -1
- package/dist/test/unit/lib/exportInPTxBuilder.js +110 -366
- package/dist/test/unit/lib/importInCTxBuilder.d.ts +1 -1
- package/dist/test/unit/lib/importInCTxBuilder.d.ts.map +1 -1
- package/dist/test/unit/lib/importInCTxBuilder.js +40 -251
- package/dist/test/unit/lib/importInPTxBuilder.d.ts +1 -1
- package/dist/test/unit/lib/importInPTxBuilder.d.ts.map +1 -1
- package/dist/test/unit/lib/importInPTxBuilder.js +61 -489
- package/dist/test/unit/lib/signFlowTestSuit.d.ts +20 -0
- package/dist/test/unit/lib/signFlowTestSuit.d.ts.map +1 -0
- package/dist/test/unit/lib/signFlowTestSuit.js +89 -0
- package/dist/test/unit/lib/utils.js +367 -279
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +12 -9
- package/dist/src/iface.d.ts +0 -25
- package/dist/src/iface.d.ts.map +0 -1
- package/dist/src/iface.js +0 -3
- package/dist/src/lib/constants.d.ts +0 -170
- package/dist/src/lib/constants.d.ts.map +0 -1
- package/dist/src/lib/constants.js +0 -227
- package/dist/src/lib/delegatorTxBuilder.d.ts +0 -58
- package/dist/src/lib/delegatorTxBuilder.d.ts.map +0 -1
- package/dist/src/lib/delegatorTxBuilder.js +0 -224
- package/dist/src/lib/errors.d.ts +0 -8
- package/dist/src/lib/errors.d.ts.map +0 -1
- package/dist/src/lib/errors.js +0 -19
- package/dist/src/lib/exportInCTxBuilder.d.ts +0 -77
- package/dist/src/lib/exportInCTxBuilder.d.ts.map +0 -1
- package/dist/src/lib/exportInCTxBuilder.js +0 -199
- package/dist/src/lib/exportInPTxBuilder.d.ts +0 -30
- package/dist/src/lib/exportInPTxBuilder.d.ts.map +0 -1
- package/dist/src/lib/exportInPTxBuilder.js +0 -120
- package/dist/src/lib/importInCTxBuilder.d.ts +0 -67
- package/dist/src/lib/importInCTxBuilder.d.ts.map +0 -1
- package/dist/src/lib/importInCTxBuilder.js +0 -403
- package/dist/src/lib/importInPTxBuilder.d.ts +0 -73
- package/dist/src/lib/importInPTxBuilder.d.ts.map +0 -1
- package/dist/src/lib/importInPTxBuilder.js +0 -464
- package/dist/src/lib/types.d.ts +0 -78
- package/dist/src/lib/types.d.ts.map +0 -1
- package/dist/src/lib/types.js +0 -5
- package/dist/src/lib/validatorTxBuilder.d.ts +0 -40
- package/dist/src/lib/validatorTxBuilder.d.ts.map +0 -1
- package/dist/src/lib/validatorTxBuilder.js +0 -180
- package/dist/test/unit/delegatorTxBuilder.test.d.ts +0 -2
- package/dist/test/unit/delegatorTxBuilder.test.d.ts.map +0 -1
- package/dist/test/unit/delegatorTxBuilder.test.js +0 -233
- package/dist/test/unit/lib/atomicTransactionBuilder.d.ts +0 -2
- package/dist/test/unit/lib/atomicTransactionBuilder.d.ts.map +0 -1
- package/dist/test/unit/lib/atomicTransactionBuilder.js +0 -222
- package/dist/test/unit/lib/transaction.d.ts +0 -2
- package/dist/test/unit/lib/transaction.d.ts.map +0 -1
- package/dist/test/unit/lib/transaction.js +0 -460
- package/dist/test/unit/permissionlessValidatorTxBuilder.test.d.ts +0 -2
- package/dist/test/unit/permissionlessValidatorTxBuilder.test.d.ts.map +0 -1
- package/dist/test/unit/permissionlessValidatorTxBuilder.test.js +0 -271
- package/dist/test/unit/smoke.d.ts +0 -2
- package/dist/test/unit/smoke.d.ts.map +0 -1
- package/dist/test/unit/smoke.js +0 -23
- package/dist/test/unit/transactionBuilder.test.d.ts +0 -2
- package/dist/test/unit/transactionBuilder.test.d.ts.map +0 -1
- package/dist/test/unit/transactionBuilder.test.js +0 -114
- package/dist/test/unit/validatorTxBuilder.test.d.ts +0 -2
- package/dist/test/unit/validatorTxBuilder.test.d.ts.map +0 -1
- package/dist/test/unit/validatorTxBuilder.test.js +0 -293
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
import 'should';
|
|
2
2
|
//# sourceMappingURL=exportInPTxBuilder.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"exportInPTxBuilder.d.ts","sourceRoot":"","sources":["../../../../test/unit/lib/exportInPTxBuilder.ts"],"names":[],"mappings":""}
|
|
1
|
+
{"version":3,"file":"exportInPTxBuilder.d.ts","sourceRoot":"","sources":["../../../../test/unit/lib/exportInPTxBuilder.ts"],"names":[],"mappings":"AACA,OAAO,QAAQ,CAAC"}
|
|
@@ -1,377 +1,121 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var
|
|
3
|
-
|
|
4
|
-
|
|
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
|
-
})();
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
35
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const assert_1 = __importDefault(require("assert"));
|
|
7
|
+
require("should");
|
|
8
|
+
const exportInP_1 = require("../../resources/transactionData/exportInP");
|
|
9
|
+
const lib_1 = require("../../../src/lib");
|
|
36
10
|
const statics_1 = require("@bitgo-beta/statics");
|
|
37
|
-
const
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
11
|
+
const signFlowTestSuit_1 = __importDefault(require("./signFlowTestSuit"));
|
|
12
|
+
describe('Flrp Export In P Tx Builder', () => {
|
|
13
|
+
const factory = new lib_1.TransactionBuilderFactory(statics_1.coins.get('tflrp'));
|
|
14
|
+
describe('validate txBuilder fields', () => {
|
|
15
|
+
const txBuilder = factory.getExportInPBuilder();
|
|
16
|
+
it('should fail amount low than zero', () => {
|
|
17
|
+
assert_1.default.throws(() => {
|
|
18
|
+
txBuilder.amount('-1');
|
|
19
|
+
}, (e) => e.message === 'Amount must be greater than 0');
|
|
20
|
+
});
|
|
21
|
+
it('should fail target chain id length incorrect', () => {
|
|
22
|
+
assert_1.default.throws(() => {
|
|
23
|
+
txBuilder.externalChainId(Buffer.from(exportInP_1.EXPORT_IN_P.INVALID_CHAIN_ID.slice(2)));
|
|
24
|
+
}, (e) => e.message === 'Chain id are 32 byte size');
|
|
25
|
+
});
|
|
26
|
+
it('should fail target chain id not a valid base58 string', () => {
|
|
27
|
+
assert_1.default.throws(() => {
|
|
28
|
+
txBuilder.externalChainId(exportInP_1.EXPORT_IN_P.INVALID_CHAIN_ID);
|
|
29
|
+
}, (e) => e.message === 'Non-base58 character');
|
|
30
|
+
});
|
|
31
|
+
it('should fail target chain id cb58 invalid checksum', () => {
|
|
32
|
+
assert_1.default.throws(() => {
|
|
33
|
+
txBuilder.externalChainId(exportInP_1.EXPORT_IN_P.VALID_C_CHAIN_ID.slice(2));
|
|
34
|
+
}, (e) => e.message === 'Invalid checksum');
|
|
35
|
+
});
|
|
36
|
+
it('should fail validate Utxos empty string', () => {
|
|
37
|
+
assert_1.default.throws(() => {
|
|
38
|
+
txBuilder.validateUtxos([]);
|
|
39
|
+
}, (e) => e.message === 'UTXOs array cannot be empty');
|
|
40
|
+
});
|
|
41
|
+
it('should fail validate Utxos without amount field', () => {
|
|
42
|
+
assert_1.default.throws(() => {
|
|
43
|
+
txBuilder.validateUtxos([{ outputID: '' }]);
|
|
44
|
+
}, (e) => e.message === 'UTXO missing required field: amount');
|
|
57
45
|
});
|
|
58
46
|
});
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
assert.doesNotThrow(() => {
|
|
80
|
-
builder.amount(amount);
|
|
81
|
-
}, `Should accept numeric amount: ${amount}`);
|
|
82
|
-
});
|
|
83
|
-
});
|
|
84
|
-
it('should reject zero amount', function () {
|
|
85
|
-
assert.throws(() => {
|
|
86
|
-
builder.amount(0n);
|
|
87
|
-
}, /Amount must be positive/);
|
|
88
|
-
assert.throws(() => {
|
|
89
|
-
builder.amount('0');
|
|
90
|
-
}, /Amount must be positive/);
|
|
91
|
-
assert.throws(() => {
|
|
92
|
-
builder.amount(0);
|
|
93
|
-
}, /Amount must be positive/);
|
|
94
|
-
});
|
|
95
|
-
it('should handle large amounts', function () {
|
|
96
|
-
const largeAmounts = [
|
|
97
|
-
'100000000000000000000000', // Very large amount
|
|
98
|
-
'18446744073709551615', // Near uint64 max
|
|
99
|
-
BigInt('999999999999999999999999999999'),
|
|
100
|
-
999999999999999999n,
|
|
101
|
-
];
|
|
102
|
-
largeAmounts.forEach((amount) => {
|
|
103
|
-
assert.doesNotThrow(() => {
|
|
104
|
-
builder.amount(amount);
|
|
105
|
-
}, `Should handle large amount: ${amount}`);
|
|
106
|
-
});
|
|
107
|
-
});
|
|
108
|
-
it('should reject negative amounts', function () {
|
|
109
|
-
const negativeAmounts = ['-1000', '-1'];
|
|
110
|
-
negativeAmounts.forEach((amount) => {
|
|
111
|
-
assert.throws(() => {
|
|
112
|
-
builder.amount(amount);
|
|
113
|
-
}, Error, // validateAmount should throw error for negative amounts
|
|
114
|
-
`Should reject negative amount: ${amount}`);
|
|
115
|
-
});
|
|
116
|
-
});
|
|
117
|
-
it('should reject negative bigint amounts', function () {
|
|
118
|
-
const negativeBigints = [-1n, -1000n, -999999999999n];
|
|
119
|
-
negativeBigints.forEach((amount) => {
|
|
120
|
-
assert.throws(() => {
|
|
121
|
-
builder.amount(amount);
|
|
122
|
-
}, Error, `Should reject negative bigint amount: ${amount}`);
|
|
123
|
-
});
|
|
124
|
-
});
|
|
125
|
-
it('should chain amount setting with other methods', function () {
|
|
126
|
-
const amount = 1000000000000000000n; // 1 FLR
|
|
127
|
-
assert.doesNotThrow(() => {
|
|
128
|
-
builder.amount(amount);
|
|
129
|
-
});
|
|
130
|
-
});
|
|
47
|
+
(0, signFlowTestSuit_1.default)({
|
|
48
|
+
transactionType: 'Export P2C with changeoutput',
|
|
49
|
+
newTxFactory: () => new lib_1.TransactionBuilderFactory(statics_1.coins.get('tflrp')),
|
|
50
|
+
newTxBuilder: () => new lib_1.TransactionBuilderFactory(statics_1.coins.get('tflrp'))
|
|
51
|
+
.getExportInPBuilder()
|
|
52
|
+
.threshold(exportInP_1.EXPORT_IN_P.threshold)
|
|
53
|
+
.locktime(exportInP_1.EXPORT_IN_P.locktime)
|
|
54
|
+
.fromPubKey(exportInP_1.EXPORT_IN_P.pAddresses)
|
|
55
|
+
.amount(exportInP_1.EXPORT_IN_P.amount)
|
|
56
|
+
.externalChainId(exportInP_1.EXPORT_IN_P.sourceChainId)
|
|
57
|
+
.fee(exportInP_1.EXPORT_IN_P.fee)
|
|
58
|
+
.utxos(exportInP_1.EXPORT_IN_P.outputs),
|
|
59
|
+
unsignedTxHex: exportInP_1.EXPORT_IN_P.unsignedHex,
|
|
60
|
+
halfSignedTxHex: exportInP_1.EXPORT_IN_P.halfSigntxHex,
|
|
61
|
+
fullSignedTxHex: exportInP_1.EXPORT_IN_P.fullSigntxHex,
|
|
62
|
+
privateKey: {
|
|
63
|
+
prv1: exportInP_1.EXPORT_IN_P.privateKeys[0],
|
|
64
|
+
prv2: exportInP_1.EXPORT_IN_P.privateKeys[1],
|
|
65
|
+
},
|
|
66
|
+
txHash: exportInP_1.EXPORT_IN_P.txhash,
|
|
131
67
|
});
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
68
|
+
(0, signFlowTestSuit_1.default)({
|
|
69
|
+
transactionType: 'Export P2C with 2 UTXOs',
|
|
70
|
+
newTxFactory: () => new lib_1.TransactionBuilderFactory(statics_1.coins.get('tflrp')),
|
|
71
|
+
newTxBuilder: () => new lib_1.TransactionBuilderFactory(statics_1.coins.get('tflrp'))
|
|
72
|
+
.getExportInPBuilder()
|
|
73
|
+
.threshold(exportInP_1.EXPORT_IN_P_TWO_UTXOS.threshold)
|
|
74
|
+
.locktime(exportInP_1.EXPORT_IN_P_TWO_UTXOS.locktime)
|
|
75
|
+
.fromPubKey(exportInP_1.EXPORT_IN_P_TWO_UTXOS.pAddresses)
|
|
76
|
+
.amount(exportInP_1.EXPORT_IN_P_TWO_UTXOS.amount)
|
|
77
|
+
.externalChainId(exportInP_1.EXPORT_IN_P_TWO_UTXOS.sourceChainId)
|
|
78
|
+
.fee(exportInP_1.EXPORT_IN_P_TWO_UTXOS.fee)
|
|
79
|
+
.utxos(exportInP_1.EXPORT_IN_P_TWO_UTXOS.outputs),
|
|
80
|
+
unsignedTxHex: exportInP_1.EXPORT_IN_P_TWO_UTXOS.unsignedHex,
|
|
81
|
+
halfSignedTxHex: exportInP_1.EXPORT_IN_P_TWO_UTXOS.halfSigntxHex,
|
|
82
|
+
fullSignedTxHex: exportInP_1.EXPORT_IN_P_TWO_UTXOS.fullSigntxHex,
|
|
83
|
+
privateKey: {
|
|
84
|
+
prv1: exportInP_1.EXPORT_IN_P_TWO_UTXOS.privateKeys[0],
|
|
85
|
+
prv2: exportInP_1.EXPORT_IN_P_TWO_UTXOS.privateKeys[1],
|
|
86
|
+
},
|
|
87
|
+
txHash: exportInP_1.EXPORT_IN_P_TWO_UTXOS.txhash,
|
|
137
88
|
});
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
type: 'export',
|
|
159
|
-
amount: '1000000000000000000',
|
|
160
|
-
from: 'P-flare1source',
|
|
161
|
-
to: 'C-flare1dest',
|
|
162
|
-
};
|
|
163
|
-
assert.doesNotThrow(() => {
|
|
164
|
-
builder.initBuilder(mockTx);
|
|
165
|
-
});
|
|
166
|
-
});
|
|
167
|
-
});
|
|
168
|
-
describe('Transaction Type Verification', function () {
|
|
169
|
-
it('should verify transaction type (returns false - not implemented)', function () {
|
|
170
|
-
const mockTx = { type: 'export' };
|
|
171
|
-
const result = exportInPTxBuilder_1.ExportInPTxBuilder.verifyTxType(mockTx);
|
|
172
|
-
assert.strictEqual(result, false); // Not implemented yet
|
|
173
|
-
});
|
|
174
|
-
it('should handle different transaction objects', function () {
|
|
175
|
-
const testCases = [{}, null, undefined, { type: 'import' }, { data: 'test' }];
|
|
176
|
-
testCases.forEach((testCase, index) => {
|
|
177
|
-
const result = exportInPTxBuilder_1.ExportInPTxBuilder.verifyTxType(testCase);
|
|
178
|
-
assert.strictEqual(result, false, `Test case ${index} should return false (not implemented)`);
|
|
179
|
-
});
|
|
180
|
-
});
|
|
181
|
-
it('should verify via instance method', function () {
|
|
182
|
-
const mockTx = { type: 'export' };
|
|
183
|
-
const result = builder.verifyTxType(mockTx);
|
|
184
|
-
assert.strictEqual(result, false); // Not implemented
|
|
185
|
-
});
|
|
186
|
-
it('should verify static and instance methods return same result', function () {
|
|
187
|
-
const mockTx = { type: 'export' };
|
|
188
|
-
const staticResult = exportInPTxBuilder_1.ExportInPTxBuilder.verifyTxType(mockTx);
|
|
189
|
-
const instanceResult = builder.verifyTxType(mockTx);
|
|
190
|
-
assert.strictEqual(staticResult, instanceResult);
|
|
191
|
-
});
|
|
192
|
-
});
|
|
193
|
-
describe('Transaction Building', function () {
|
|
194
|
-
it('should throw error when building (not implemented)', function () {
|
|
195
|
-
builder.amount(1000000000000000000n);
|
|
196
|
-
assert.throws(() => {
|
|
197
|
-
// Access protected method for testing
|
|
198
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
199
|
-
builder.buildFlareTransaction();
|
|
200
|
-
}, Error);
|
|
201
|
-
});
|
|
202
|
-
it('should throw specific error message', function () {
|
|
203
|
-
assert.throws(() => {
|
|
204
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
205
|
-
builder.buildFlareTransaction();
|
|
206
|
-
}, /Flare P-chain export transaction build not implemented/);
|
|
207
|
-
});
|
|
89
|
+
(0, signFlowTestSuit_1.default)({
|
|
90
|
+
transactionType: 'Export P2C with no change output',
|
|
91
|
+
newTxFactory: () => new lib_1.TransactionBuilderFactory(statics_1.coins.get('tflrp')),
|
|
92
|
+
newTxBuilder: () => new lib_1.TransactionBuilderFactory(statics_1.coins.get('tflrp'))
|
|
93
|
+
.getExportInPBuilder()
|
|
94
|
+
.threshold(exportInP_1.EXPORT_IN_P_NO_CHANGE.threshold)
|
|
95
|
+
.locktime(exportInP_1.EXPORT_IN_P_NO_CHANGE.locktime)
|
|
96
|
+
.fromPubKey(exportInP_1.EXPORT_IN_P_NO_CHANGE.pAddresses)
|
|
97
|
+
.amount(exportInP_1.EXPORT_IN_P_NO_CHANGE.amount)
|
|
98
|
+
.externalChainId(exportInP_1.EXPORT_IN_P_NO_CHANGE.sourceChainId)
|
|
99
|
+
.fee(exportInP_1.EXPORT_IN_P_NO_CHANGE.fee)
|
|
100
|
+
.utxos(exportInP_1.EXPORT_IN_P_NO_CHANGE.outputs),
|
|
101
|
+
unsignedTxHex: exportInP_1.EXPORT_IN_P_NO_CHANGE.unsignedHex,
|
|
102
|
+
halfSignedTxHex: exportInP_1.EXPORT_IN_P_NO_CHANGE.halfSigntxHex,
|
|
103
|
+
fullSignedTxHex: exportInP_1.EXPORT_IN_P_NO_CHANGE.fullSigntxHex,
|
|
104
|
+
privateKey: {
|
|
105
|
+
prv1: exportInP_1.EXPORT_IN_P_NO_CHANGE.privateKeys[0],
|
|
106
|
+
prv2: exportInP_1.EXPORT_IN_P_NO_CHANGE.privateKeys[1],
|
|
107
|
+
},
|
|
108
|
+
txHash: exportInP_1.EXPORT_IN_P_NO_CHANGE.txhash,
|
|
208
109
|
});
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
it('should consistently return empty array', function () {
|
|
218
|
-
// Call multiple times to ensure consistency
|
|
219
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
220
|
-
const result1 = builder.exportedOutputs();
|
|
221
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
222
|
-
const result2 = builder.exportedOutputs();
|
|
223
|
-
assert.deepStrictEqual(result1, result2);
|
|
224
|
-
});
|
|
225
|
-
});
|
|
226
|
-
describe('Amount Validation', function () {
|
|
227
|
-
it('should validate positive amounts', function () {
|
|
228
|
-
const positiveAmounts = [1n, 1000n, 1000000000000000000n];
|
|
229
|
-
positiveAmounts.forEach((amount) => {
|
|
230
|
-
assert.doesNotThrow(() => {
|
|
231
|
-
builder.amount(amount);
|
|
232
|
-
}, `Should validate positive amount: ${amount}`);
|
|
233
|
-
});
|
|
234
|
-
});
|
|
235
|
-
it('should reject zero amount', function () {
|
|
236
|
-
assert.throws(() => {
|
|
237
|
-
builder.amount(0n);
|
|
238
|
-
}, /Amount must be positive/);
|
|
239
|
-
});
|
|
240
|
-
it('should validate large amounts', function () {
|
|
241
|
-
const largeAmounts = [
|
|
242
|
-
BigInt('18446744073709551615'), // Max uint64
|
|
243
|
-
BigInt('999999999999999999999999999999'), // Very large
|
|
244
|
-
];
|
|
245
|
-
largeAmounts.forEach((amount) => {
|
|
246
|
-
assert.doesNotThrow(() => {
|
|
247
|
-
builder.amount(amount);
|
|
248
|
-
}, `Should validate large amount: ${amount}`);
|
|
249
|
-
});
|
|
250
|
-
});
|
|
251
|
-
});
|
|
252
|
-
describe('Integration Tests', function () {
|
|
253
|
-
it('should handle basic P-chain export setup', function () {
|
|
254
|
-
const amount = 5000000000000000000n; // 5 FLR
|
|
255
|
-
// Basic setup
|
|
256
|
-
builder.amount(amount);
|
|
257
|
-
// Should not throw during setup
|
|
258
|
-
assert.ok(true);
|
|
259
|
-
});
|
|
260
|
-
it('should handle amount conversion from different types', function () {
|
|
261
|
-
// Test conversion from string
|
|
262
|
-
builder.amount('1000000000000000000');
|
|
263
|
-
// Test conversion from number
|
|
264
|
-
builder.amount(1000000);
|
|
265
|
-
// Test direct bigint
|
|
266
|
-
builder.amount(2000000000000000000n);
|
|
267
|
-
// All conversions should work
|
|
268
|
-
assert.ok(true);
|
|
269
|
-
});
|
|
270
|
-
it('should maintain state across operations', function () {
|
|
271
|
-
// Set amount
|
|
272
|
-
builder.amount(1000000000000000000n);
|
|
273
|
-
// Initialize with transaction
|
|
274
|
-
const mockTx = { type: 'export' };
|
|
275
|
-
builder.initBuilder(mockTx);
|
|
276
|
-
// State should be maintained
|
|
277
|
-
assert.ok(true);
|
|
278
|
-
});
|
|
279
|
-
it('should handle sequential amount updates', function () {
|
|
280
|
-
// Update amount multiple times
|
|
281
|
-
builder.amount(1000n);
|
|
282
|
-
builder.amount(2000n);
|
|
283
|
-
builder.amount(3000n);
|
|
284
|
-
// Should handle updates without issues
|
|
285
|
-
assert.ok(true);
|
|
286
|
-
});
|
|
287
|
-
});
|
|
288
|
-
describe('Error Handling', function () {
|
|
289
|
-
it('should handle invalid amount types gracefully', function () {
|
|
290
|
-
const invalidAmounts = [null, undefined, {}, [], 'invalid'];
|
|
291
|
-
invalidAmounts.forEach((amount) => {
|
|
292
|
-
assert.throws(() => {
|
|
293
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
294
|
-
builder.amount(amount);
|
|
295
|
-
}, `Should throw for invalid amount: ${amount}`);
|
|
296
|
-
});
|
|
297
|
-
});
|
|
298
|
-
it('should handle edge case string amounts', function () {
|
|
299
|
-
const edgeCaseAmounts = ['', ' ', 'abc', '1.5', 'infinity', 'NaN'];
|
|
300
|
-
edgeCaseAmounts.forEach((amount) => {
|
|
301
|
-
assert.throws(() => {
|
|
302
|
-
builder.amount(amount);
|
|
303
|
-
}, `Should throw for edge case amount: ${amount}`);
|
|
304
|
-
});
|
|
305
|
-
});
|
|
306
|
-
});
|
|
307
|
-
describe('Inheritance Tests', function () {
|
|
308
|
-
it('should inherit from AtomicTransactionBuilder', function () {
|
|
309
|
-
// Test that builder has expected inherited functionality
|
|
310
|
-
assert.ok(builder);
|
|
311
|
-
// Should have initBuilder method
|
|
312
|
-
assert.ok(typeof builder.initBuilder === 'function');
|
|
313
|
-
// Should have verifyTxType method
|
|
314
|
-
assert.ok(typeof builder.verifyTxType === 'function');
|
|
315
|
-
});
|
|
316
|
-
it('should have access to inherited UTXO methods', function () {
|
|
317
|
-
// Should inherit utxos method from parent
|
|
318
|
-
assert.ok(typeof builder.utxos === 'function');
|
|
319
|
-
});
|
|
320
|
-
});
|
|
321
|
-
describe('Edge Cases', function () {
|
|
322
|
-
it('should handle rapid consecutive operations', function () {
|
|
323
|
-
// Rapid amount changes (start from 1 since 0 is not valid)
|
|
324
|
-
for (let i = 1; i <= 100; i++) {
|
|
325
|
-
builder.amount(BigInt(i * 1000));
|
|
326
|
-
}
|
|
327
|
-
// Should handle rapid operations
|
|
328
|
-
assert.ok(true);
|
|
329
|
-
});
|
|
330
|
-
it('should handle maximum bigint values', function () {
|
|
331
|
-
const maxValues = [
|
|
332
|
-
BigInt(Number.MAX_SAFE_INTEGER),
|
|
333
|
-
BigInt('18446744073709551615'), // Max uint64
|
|
334
|
-
];
|
|
335
|
-
maxValues.forEach((value) => {
|
|
336
|
-
assert.doesNotThrow(() => {
|
|
337
|
-
builder.amount(value);
|
|
338
|
-
}, `Should handle max value: ${value}`);
|
|
339
|
-
});
|
|
340
|
-
});
|
|
341
|
-
it('should handle minimum valid values', function () {
|
|
342
|
-
const minValues = [1n]; // Removed 0n since it's not valid
|
|
343
|
-
minValues.forEach((value) => {
|
|
344
|
-
assert.doesNotThrow(() => {
|
|
345
|
-
builder.amount(value);
|
|
346
|
-
}, `Should handle min value: ${value}`);
|
|
347
|
-
});
|
|
348
|
-
});
|
|
349
|
-
});
|
|
350
|
-
describe('Future Implementation Readiness', function () {
|
|
351
|
-
it('should be ready for future buildFlareTransaction implementation', function () {
|
|
352
|
-
// Setup valid state
|
|
353
|
-
builder.amount(1000000000000000000n);
|
|
354
|
-
// Current implementation throws, but structure is in place
|
|
355
|
-
assert.throws(() => {
|
|
356
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
357
|
-
builder.buildFlareTransaction();
|
|
358
|
-
}, /not implemented/);
|
|
359
|
-
});
|
|
360
|
-
it('should be ready for future verifyTxType implementation', function () {
|
|
361
|
-
// Current implementation returns false
|
|
362
|
-
const result = builder.verifyTxType({ type: 'export' });
|
|
363
|
-
assert.strictEqual(result, false);
|
|
364
|
-
// But method signature is ready for implementation
|
|
365
|
-
assert.ok(typeof builder.verifyTxType === 'function');
|
|
366
|
-
});
|
|
367
|
-
it('should be ready for future exportedOutputs implementation', function () {
|
|
368
|
-
// Current implementation returns empty array
|
|
369
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
370
|
-
const result = builder.exportedOutputs();
|
|
371
|
-
assert.ok(Array.isArray(result));
|
|
372
|
-
// But method exists and is ready for implementation
|
|
373
|
-
assert.strictEqual(result.length, 0);
|
|
110
|
+
it('Should full sign a export tx from unsigned raw tx', () => {
|
|
111
|
+
const txBuilder = new lib_1.TransactionBuilderFactory(statics_1.coins.get('tflrp')).from(exportInP_1.EXPORT_IN_P.unsignedHex);
|
|
112
|
+
txBuilder.sign({ key: exportInP_1.EXPORT_IN_P.privateKeys[0] });
|
|
113
|
+
txBuilder
|
|
114
|
+
.build()
|
|
115
|
+
.then(() => assert_1.default.fail('it can sign'))
|
|
116
|
+
.catch((err) => {
|
|
117
|
+
err.message.should.be.equal('Private key cannot sign the transaction');
|
|
374
118
|
});
|
|
375
119
|
});
|
|
376
120
|
});
|
|
377
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"exportInPTxBuilder.js","sourceRoot":"","sources":["../../../../test/unit/lib/exportInPTxBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { coins } from '@bitgo-beta/statics';\nimport * as assert from 'assert';\nimport { ExportInPTxBuilder } from '../../../src/lib/exportInPTxBuilder';\n\ndescribe('ExportInPTxBuilder', function () {\n  const coinConfig = coins.get('tflrp');\n  let builder: ExportInPTxBuilder;\n\n  beforeEach(function () {\n    builder = new ExportInPTxBuilder(coinConfig);\n  });\n\n  describe('Constructor', function () {\n    it('should initialize with coin config', function () {\n      assert.ok(builder);\n      assert.ok(builder instanceof ExportInPTxBuilder);\n    });\n\n    it('should extend AtomicTransactionBuilder', function () {\n      // Test inheritance\n      assert.ok(builder);\n    });\n\n    it('should initialize with default amount', function () {\n      // Default amount should be 0n\n      assert.ok(builder);\n    });\n  });\n\n  describe('Amount Management', function () {\n    it('should set valid bigint amounts', function () {\n      const validAmounts = [1000n, 1000000000000000000n, 999999999999999999n]; // Removed 0n\n\n      validAmounts.forEach((amount) => {\n        assert.doesNotThrow(() => {\n          builder.amount(amount);\n        }, `Should accept bigint amount: ${amount}`);\n      });\n    });\n\n    it('should set string amounts', function () {\n      const stringAmounts = ['1000', '1000000000000000000', '999999999999999999']; // Removed '0'\n\n      stringAmounts.forEach((amount) => {\n        assert.doesNotThrow(() => {\n          builder.amount(amount);\n        }, `Should accept string amount: ${amount}`);\n      });\n    });\n\n    it('should set numeric amounts', function () {\n      const numericAmounts = [1000, 2000000, 999999999]; // Removed 0\n\n      numericAmounts.forEach((amount) => {\n        assert.doesNotThrow(() => {\n          builder.amount(amount);\n        }, `Should accept numeric amount: ${amount}`);\n      });\n    });\n\n    it('should reject zero amount', function () {\n      assert.throws(() => {\n        builder.amount(0n);\n      }, /Amount must be positive/);\n\n      assert.throws(() => {\n        builder.amount('0');\n      }, /Amount must be positive/);\n\n      assert.throws(() => {\n        builder.amount(0);\n      }, /Amount must be positive/);\n    });\n\n    it('should handle large amounts', function () {\n      const largeAmounts = [\n        '100000000000000000000000', // Very large amount\n        '18446744073709551615', // Near uint64 max\n        BigInt('999999999999999999999999999999'),\n        999999999999999999n,\n      ];\n\n      largeAmounts.forEach((amount) => {\n        assert.doesNotThrow(() => {\n          builder.amount(amount);\n        }, `Should handle large amount: ${amount}`);\n      });\n    });\n\n    it('should reject negative amounts', function () {\n      const negativeAmounts = ['-1000', '-1'];\n\n      negativeAmounts.forEach((amount) => {\n        assert.throws(\n          () => {\n            builder.amount(amount);\n          },\n          Error, // validateAmount should throw error for negative amounts\n          `Should reject negative amount: ${amount}`\n        );\n      });\n    });\n\n    it('should reject negative bigint amounts', function () {\n      const negativeBigints = [-1n, -1000n, -999999999999n];\n\n      negativeBigints.forEach((amount) => {\n        assert.throws(\n          () => {\n            builder.amount(amount);\n          },\n          Error,\n          `Should reject negative bigint amount: ${amount}`\n        );\n      });\n    });\n\n    it('should chain amount setting with other methods', function () {\n      const amount = 1000000000000000000n; // 1 FLR\n\n      assert.doesNotThrow(() => {\n        builder.amount(amount);\n      });\n    });\n  });\n\n  describe('Transaction Type', function () {\n    it('should return Export transaction type', function () {\n      // Can't access protected method directly, but test doesn't throw\n      assert.ok(builder);\n    });\n  });\n\n  describe('Transaction Initialization', function () {\n    it('should initialize builder from transaction', function () {\n      const mockTx = { type: 'export', data: 'placeholder' };\n\n      assert.doesNotThrow(() => {\n        builder.initBuilder(mockTx);\n      });\n    });\n\n    it('should handle null transaction initialization', function () {\n      assert.doesNotThrow(() => {\n        builder.initBuilder(null);\n      });\n    });\n\n    it('should handle undefined transaction initialization', function () {\n      assert.doesNotThrow(() => {\n        builder.initBuilder(undefined);\n      });\n    });\n\n    it('should handle object transaction initialization', function () {\n      const mockTx = {\n        id: 'test-tx',\n        type: 'export',\n        amount: '1000000000000000000',\n        from: 'P-flare1source',\n        to: 'C-flare1dest',\n      };\n\n      assert.doesNotThrow(() => {\n        builder.initBuilder(mockTx);\n      });\n    });\n  });\n\n  describe('Transaction Type Verification', function () {\n    it('should verify transaction type (returns false - not implemented)', function () {\n      const mockTx = { type: 'export' };\n      const result = ExportInPTxBuilder.verifyTxType(mockTx);\n      assert.strictEqual(result, false); // Not implemented yet\n    });\n\n    it('should handle different transaction objects', function () {\n      const testCases = [{}, null, undefined, { type: 'import' }, { data: 'test' }];\n\n      testCases.forEach((testCase, index) => {\n        const result = ExportInPTxBuilder.verifyTxType(testCase);\n        assert.strictEqual(result, false, `Test case ${index} should return false (not implemented)`);\n      });\n    });\n\n    it('should verify via instance method', function () {\n      const mockTx = { type: 'export' };\n      const result = builder.verifyTxType(mockTx);\n      assert.strictEqual(result, false); // Not implemented\n    });\n\n    it('should verify static and instance methods return same result', function () {\n      const mockTx = { type: 'export' };\n      const staticResult = ExportInPTxBuilder.verifyTxType(mockTx);\n      const instanceResult = builder.verifyTxType(mockTx);\n      assert.strictEqual(staticResult, instanceResult);\n    });\n  });\n\n  describe('Transaction Building', function () {\n    it('should throw error when building (not implemented)', function () {\n      builder.amount(1000000000000000000n);\n\n      assert.throws(() => {\n        // Access protected method for testing\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        (builder as any).buildFlareTransaction();\n      }, Error);\n    });\n\n    it('should throw specific error message', function () {\n      assert.throws(() => {\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        (builder as any).buildFlareTransaction();\n      }, /Flare P-chain export transaction build not implemented/);\n    });\n  });\n\n  describe('Exported Outputs', function () {\n    it('should return empty array for exported outputs', function () {\n      // Access protected method for testing\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      const result = (builder as any).exportedOutputs();\n\n      assert.ok(Array.isArray(result));\n      assert.strictEqual(result.length, 0);\n    });\n\n    it('should consistently return empty array', function () {\n      // Call multiple times to ensure consistency\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      const result1 = (builder as any).exportedOutputs();\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      const result2 = (builder as any).exportedOutputs();\n\n      assert.deepStrictEqual(result1, result2);\n    });\n  });\n\n  describe('Amount Validation', function () {\n    it('should validate positive amounts', function () {\n      const positiveAmounts = [1n, 1000n, 1000000000000000000n];\n\n      positiveAmounts.forEach((amount) => {\n        assert.doesNotThrow(() => {\n          builder.amount(amount);\n        }, `Should validate positive amount: ${amount}`);\n      });\n    });\n\n    it('should reject zero amount', function () {\n      assert.throws(() => {\n        builder.amount(0n);\n      }, /Amount must be positive/);\n    });\n\n    it('should validate large amounts', function () {\n      const largeAmounts = [\n        BigInt('18446744073709551615'), // Max uint64\n        BigInt('999999999999999999999999999999'), // Very large\n      ];\n\n      largeAmounts.forEach((amount) => {\n        assert.doesNotThrow(() => {\n          builder.amount(amount);\n        }, `Should validate large amount: ${amount}`);\n      });\n    });\n  });\n\n  describe('Integration Tests', function () {\n    it('should handle basic P-chain export setup', function () {\n      const amount = 5000000000000000000n; // 5 FLR\n\n      // Basic setup\n      builder.amount(amount);\n\n      // Should not throw during setup\n      assert.ok(true);\n    });\n\n    it('should handle amount conversion from different types', function () {\n      // Test conversion from string\n      builder.amount('1000000000000000000');\n\n      // Test conversion from number\n      builder.amount(1000000);\n\n      // Test direct bigint\n      builder.amount(2000000000000000000n);\n\n      // All conversions should work\n      assert.ok(true);\n    });\n\n    it('should maintain state across operations', function () {\n      // Set amount\n      builder.amount(1000000000000000000n);\n\n      // Initialize with transaction\n      const mockTx = { type: 'export' };\n      builder.initBuilder(mockTx);\n\n      // State should be maintained\n      assert.ok(true);\n    });\n\n    it('should handle sequential amount updates', function () {\n      // Update amount multiple times\n      builder.amount(1000n);\n      builder.amount(2000n);\n      builder.amount(3000n);\n\n      // Should handle updates without issues\n      assert.ok(true);\n    });\n  });\n\n  describe('Error Handling', function () {\n    it('should handle invalid amount types gracefully', function () {\n      const invalidAmounts = [null, undefined, {}, [], 'invalid'];\n\n      invalidAmounts.forEach((amount) => {\n        assert.throws(() => {\n          // eslint-disable-next-line @typescript-eslint/no-explicit-any\n          builder.amount(amount as any);\n        }, `Should throw for invalid amount: ${amount}`);\n      });\n    });\n\n    it('should handle edge case string amounts', function () {\n      const edgeCaseAmounts = ['', '  ', 'abc', '1.5', 'infinity', 'NaN'];\n\n      edgeCaseAmounts.forEach((amount) => {\n        assert.throws(() => {\n          builder.amount(amount);\n        }, `Should throw for edge case amount: ${amount}`);\n      });\n    });\n  });\n\n  describe('Inheritance Tests', function () {\n    it('should inherit from AtomicTransactionBuilder', function () {\n      // Test that builder has expected inherited functionality\n      assert.ok(builder);\n\n      // Should have initBuilder method\n      assert.ok(typeof builder.initBuilder === 'function');\n\n      // Should have verifyTxType method\n      assert.ok(typeof builder.verifyTxType === 'function');\n    });\n\n    it('should have access to inherited UTXO methods', function () {\n      // Should inherit utxos method from parent\n      assert.ok(typeof builder.utxos === 'function');\n    });\n  });\n\n  describe('Edge Cases', function () {\n    it('should handle rapid consecutive operations', function () {\n      // Rapid amount changes (start from 1 since 0 is not valid)\n      for (let i = 1; i <= 100; i++) {\n        builder.amount(BigInt(i * 1000));\n      }\n\n      // Should handle rapid operations\n      assert.ok(true);\n    });\n\n    it('should handle maximum bigint values', function () {\n      const maxValues = [\n        BigInt(Number.MAX_SAFE_INTEGER),\n        BigInt('18446744073709551615'), // Max uint64\n      ];\n\n      maxValues.forEach((value) => {\n        assert.doesNotThrow(() => {\n          builder.amount(value);\n        }, `Should handle max value: ${value}`);\n      });\n    });\n\n    it('should handle minimum valid values', function () {\n      const minValues = [1n]; // Removed 0n since it's not valid\n\n      minValues.forEach((value) => {\n        assert.doesNotThrow(() => {\n          builder.amount(value);\n        }, `Should handle min value: ${value}`);\n      });\n    });\n  });\n\n  describe('Future Implementation Readiness', function () {\n    it('should be ready for future buildFlareTransaction implementation', function () {\n      // Setup valid state\n      builder.amount(1000000000000000000n);\n\n      // Current implementation throws, but structure is in place\n      assert.throws(() => {\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        (builder as any).buildFlareTransaction();\n      }, /not implemented/);\n    });\n\n    it('should be ready for future verifyTxType implementation', function () {\n      // Current implementation returns false\n      const result = builder.verifyTxType({ type: 'export' });\n      assert.strictEqual(result, false);\n\n      // But method signature is ready for implementation\n      assert.ok(typeof builder.verifyTxType === 'function');\n    });\n\n    it('should be ready for future exportedOutputs implementation', function () {\n      // Current implementation returns empty array\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      const result = (builder as any).exportedOutputs();\n      assert.ok(Array.isArray(result));\n\n      // But method exists and is ready for implementation\n      assert.strictEqual(result.length, 0);\n    });\n  });\n});\n"]}
|
|
121
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"exportInPTxBuilder.js","sourceRoot":"","sources":["../../../../test/unit/lib/exportInPTxBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport 'should';\nimport {\n  EXPORT_IN_P as testData,\n  EXPORT_IN_P_TWO_UTXOS as twoUtxoTestData,\n  EXPORT_IN_P_NO_CHANGE as noChangeTestData,\n} from '../../resources/transactionData/exportInP';\nimport { TransactionBuilderFactory, DecodedUtxoObj } from '../../../src/lib';\nimport { coins } from '@bitgo-beta/statics';\nimport signFlowTest from './signFlowTestSuit';\n\ndescribe('Flrp Export In P Tx Builder', () => {\n  const factory = new TransactionBuilderFactory(coins.get('tflrp'));\n\n  describe('validate txBuilder fields', () => {\n    const txBuilder = factory.getExportInPBuilder();\n    it('should fail amount low than zero', () => {\n      assert.throws(\n        () => {\n          txBuilder.amount('-1');\n        },\n        (e: any) => e.message === 'Amount must be greater than 0'\n      );\n    });\n    it('should fail target chain id length incorrect', () => {\n      assert.throws(\n        () => {\n          txBuilder.externalChainId(Buffer.from(testData.INVALID_CHAIN_ID.slice(2)));\n        },\n        (e: any) => e.message === 'Chain id are 32 byte size'\n      );\n    });\n\n    it('should fail target chain id not a valid base58 string', () => {\n      assert.throws(\n        () => {\n          txBuilder.externalChainId(testData.INVALID_CHAIN_ID);\n        },\n        (e: any) => e.message === 'Non-base58 character'\n      );\n    });\n\n    it('should fail target chain id cb58 invalid checksum', () => {\n      assert.throws(\n        () => {\n          txBuilder.externalChainId(testData.VALID_C_CHAIN_ID.slice(2));\n        },\n        (e: any) => e.message === 'Invalid checksum'\n      );\n    });\n\n    it('should fail validate Utxos empty string', () => {\n      assert.throws(\n        () => {\n          txBuilder.validateUtxos([]);\n        },\n        (e: any) => e.message === 'UTXOs array cannot be empty'\n      );\n    });\n\n    it('should fail validate Utxos without amount field', () => {\n      assert.throws(\n        () => {\n          txBuilder.validateUtxos([{ outputID: '' } as any as DecodedUtxoObj]);\n        },\n        (e: any) => e.message === 'UTXO missing required field: amount'\n      );\n    });\n  });\n\n  signFlowTest({\n    transactionType: 'Export P2C with changeoutput',\n    newTxFactory: () => new TransactionBuilderFactory(coins.get('tflrp')),\n    newTxBuilder: () =>\n      new TransactionBuilderFactory(coins.get('tflrp'))\n        .getExportInPBuilder()\n        .threshold(testData.threshold)\n        .locktime(testData.locktime)\n        .fromPubKey(testData.pAddresses)\n        .amount(testData.amount)\n        .externalChainId(testData.sourceChainId)\n        .fee(testData.fee)\n        .utxos(testData.outputs),\n    unsignedTxHex: testData.unsignedHex,\n    halfSignedTxHex: testData.halfSigntxHex,\n    fullSignedTxHex: testData.fullSigntxHex,\n    privateKey: {\n      prv1: testData.privateKeys[0],\n      prv2: testData.privateKeys[1],\n    },\n    txHash: testData.txhash,\n  });\n\n  signFlowTest({\n    transactionType: 'Export P2C with 2 UTXOs',\n    newTxFactory: () => new TransactionBuilderFactory(coins.get('tflrp')),\n    newTxBuilder: () =>\n      new TransactionBuilderFactory(coins.get('tflrp'))\n        .getExportInPBuilder()\n        .threshold(twoUtxoTestData.threshold)\n        .locktime(twoUtxoTestData.locktime)\n        .fromPubKey(twoUtxoTestData.pAddresses)\n        .amount(twoUtxoTestData.amount)\n        .externalChainId(twoUtxoTestData.sourceChainId)\n        .fee(twoUtxoTestData.fee)\n        .utxos(twoUtxoTestData.outputs),\n    unsignedTxHex: twoUtxoTestData.unsignedHex,\n    halfSignedTxHex: twoUtxoTestData.halfSigntxHex,\n    fullSignedTxHex: twoUtxoTestData.fullSigntxHex,\n    privateKey: {\n      prv1: twoUtxoTestData.privateKeys[0],\n      prv2: twoUtxoTestData.privateKeys[1],\n    },\n    txHash: twoUtxoTestData.txhash,\n  });\n\n  signFlowTest({\n    transactionType: 'Export P2C with no change output',\n    newTxFactory: () => new TransactionBuilderFactory(coins.get('tflrp')),\n    newTxBuilder: () =>\n      new TransactionBuilderFactory(coins.get('tflrp'))\n        .getExportInPBuilder()\n        .threshold(noChangeTestData.threshold)\n        .locktime(noChangeTestData.locktime)\n        .fromPubKey(noChangeTestData.pAddresses)\n        .amount(noChangeTestData.amount)\n        .externalChainId(noChangeTestData.sourceChainId)\n        .fee(noChangeTestData.fee)\n        .utxos(noChangeTestData.outputs),\n    unsignedTxHex: noChangeTestData.unsignedHex,\n    halfSignedTxHex: noChangeTestData.halfSigntxHex,\n    fullSignedTxHex: noChangeTestData.fullSigntxHex,\n    privateKey: {\n      prv1: noChangeTestData.privateKeys[0],\n      prv2: noChangeTestData.privateKeys[1],\n    },\n    txHash: noChangeTestData.txhash,\n  });\n\n  it('Should full sign a export tx from unsigned raw tx', () => {\n    const txBuilder = new TransactionBuilderFactory(coins.get('tflrp')).from(testData.unsignedHex);\n    txBuilder.sign({ key: testData.privateKeys[0] });\n    txBuilder\n      .build()\n      .then(() => assert.fail('it can sign'))\n      .catch((err) => {\n        err.message.should.be.equal('Private key cannot sign the transaction');\n      });\n  });\n});\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
import 'should';
|
|
2
2
|
//# sourceMappingURL=importInCTxBuilder.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"importInCTxBuilder.d.ts","sourceRoot":"","sources":["../../../../test/unit/lib/importInCTxBuilder.ts"],"names":[],"mappings":""}
|
|
1
|
+
{"version":3,"file":"importInCTxBuilder.d.ts","sourceRoot":"","sources":["../../../../test/unit/lib/importInCTxBuilder.ts"],"names":[],"mappings":"AACA,OAAO,QAAQ,CAAC"}
|