@ledgerhq/coin-sui 0.16.0 → 0.16.1-nightly.0
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/.unimportedrc.json +2 -1
- package/CHANGELOG.md +9 -0
- package/lib/logic/estimateFees.d.ts +4 -1
- package/lib/logic/estimateFees.d.ts.map +1 -1
- package/lib/logic/estimateFees.js +2 -1
- package/lib/logic/estimateFees.js.map +1 -1
- package/lib/network/sdk.d.ts.map +1 -1
- package/lib/network/sdk.js +18 -13
- package/lib/network/sdk.js.map +1 -1
- package/lib/{bridge/bridge.integration.test.d.ts → test/bridge.dataset.d.ts} +1 -1
- package/lib/test/bridge.dataset.d.ts.map +1 -0
- package/lib/{bridge/bridge.integration.test.js → test/bridge.dataset.js} +2 -2
- package/lib/test/bridge.dataset.js.map +1 -0
- package/lib-es/logic/estimateFees.d.ts +4 -1
- package/lib-es/logic/estimateFees.d.ts.map +1 -1
- package/lib-es/logic/estimateFees.js +2 -1
- package/lib-es/logic/estimateFees.js.map +1 -1
- package/lib-es/network/sdk.d.ts.map +1 -1
- package/lib-es/network/sdk.js +18 -13
- package/lib-es/network/sdk.js.map +1 -1
- package/lib-es/{bridge/bridge.integration.test.d.ts → test/bridge.dataset.d.ts} +1 -1
- package/lib-es/test/bridge.dataset.d.ts.map +1 -0
- package/lib-es/{bridge/bridge.integration.test.js → test/bridge.dataset.js} +2 -2
- package/lib-es/test/bridge.dataset.js.map +1 -0
- package/package.json +5 -9
- package/src/api/index.integration.test.ts +44 -7
- package/src/logic/estimateFees.test.ts +22 -16
- package/src/logic/estimateFees.ts +6 -1
- package/src/network/sdk.test.ts +44 -4
- package/src/network/sdk.ts +21 -13
- package/src/{bridge/bridge.integration.test.ts → test/bridge.dataset.ts} +1 -1
- package/lib/api/index.integration.test.d.ts +0 -2
- package/lib/api/index.integration.test.d.ts.map +0 -1
- package/lib/api/index.integration.test.js +0 -173
- package/lib/api/index.integration.test.js.map +0 -1
- package/lib/api/index.test.d.ts +0 -2
- package/lib/api/index.test.d.ts.map +0 -1
- package/lib/api/index.test.js +0 -173
- package/lib/api/index.test.js.map +0 -1
- package/lib/bridge/bridge.integration.test.d.ts.map +0 -1
- package/lib/bridge/bridge.integration.test.js.map +0 -1
- package/lib/bridge/broadcast.test.d.ts +0 -2
- package/lib/bridge/broadcast.test.d.ts.map +0 -1
- package/lib/bridge/broadcast.test.js +0 -48
- package/lib/bridge/broadcast.test.js.map +0 -1
- package/lib/bridge/buildOptimisticOperation.test.d.ts +0 -2
- package/lib/bridge/buildOptimisticOperation.test.d.ts.map +0 -1
- package/lib/bridge/buildOptimisticOperation.test.js +0 -52
- package/lib/bridge/buildOptimisticOperation.test.js.map +0 -1
- package/lib/bridge/buildTransaction.integration.test.d.ts +0 -2
- package/lib/bridge/buildTransaction.integration.test.d.ts.map +0 -1
- package/lib/bridge/buildTransaction.integration.test.js +0 -72
- package/lib/bridge/buildTransaction.integration.test.js.map +0 -1
- package/lib/bridge/buildTransaction.test.d.ts +0 -2
- package/lib/bridge/buildTransaction.test.d.ts.map +0 -1
- package/lib/bridge/buildTransaction.test.js +0 -231
- package/lib/bridge/buildTransaction.test.js.map +0 -1
- package/lib/bridge/estimateMaxSpendable.test.d.ts +0 -2
- package/lib/bridge/estimateMaxSpendable.test.d.ts.map +0 -1
- package/lib/bridge/estimateMaxSpendable.test.js +0 -52
- package/lib/bridge/estimateMaxSpendable.test.js.map +0 -1
- package/lib/bridge/formatters.test.d.ts +0 -2
- package/lib/bridge/formatters.test.d.ts.map +0 -1
- package/lib/bridge/formatters.test.js +0 -18
- package/lib/bridge/formatters.test.js.map +0 -1
- package/lib/bridge/getFeesForTransaction.test.d.ts +0 -2
- package/lib/bridge/getFeesForTransaction.test.d.ts.map +0 -1
- package/lib/bridge/getFeesForTransaction.test.js +0 -35
- package/lib/bridge/getFeesForTransaction.test.js.map +0 -1
- package/lib/bridge/getTransactionStatus.test.d.ts +0 -2
- package/lib/bridge/getTransactionStatus.test.d.ts.map +0 -1
- package/lib/bridge/getTransactionStatus.test.js +0 -69
- package/lib/bridge/getTransactionStatus.test.js.map +0 -1
- package/lib/bridge/index.test.d.ts +0 -2
- package/lib/bridge/index.test.d.ts.map +0 -1
- package/lib/bridge/index.test.js +0 -265
- package/lib/bridge/index.test.js.map +0 -1
- package/lib/bridge/preload.test.d.ts +0 -2
- package/lib/bridge/preload.test.d.ts.map +0 -1
- package/lib/bridge/preload.test.js +0 -52
- package/lib/bridge/preload.test.js.map +0 -1
- package/lib/bridge/prepareTransaction.test.d.ts +0 -2
- package/lib/bridge/prepareTransaction.test.d.ts.map +0 -1
- package/lib/bridge/prepareTransaction.test.js +0 -97
- package/lib/bridge/prepareTransaction.test.js.map +0 -1
- package/lib/bridge/serialization.test.d.ts +0 -2
- package/lib/bridge/serialization.test.d.ts.map +0 -1
- package/lib/bridge/serialization.test.js +0 -131
- package/lib/bridge/serialization.test.js.map +0 -1
- package/lib/bridge/signOperation.integration.test.d.ts +0 -2
- package/lib/bridge/signOperation.integration.test.d.ts.map +0 -1
- package/lib/bridge/signOperation.integration.test.js +0 -80
- package/lib/bridge/signOperation.integration.test.js.map +0 -1
- package/lib/bridge/signOperation.test.d.ts +0 -2
- package/lib/bridge/signOperation.test.d.ts.map +0 -1
- package/lib/bridge/signOperation.test.js +0 -445
- package/lib/bridge/signOperation.test.js.map +0 -1
- package/lib/bridge/synchronisation.test.d.ts +0 -2
- package/lib/bridge/synchronisation.test.d.ts.map +0 -1
- package/lib/bridge/synchronisation.test.js +0 -505
- package/lib/bridge/synchronisation.test.js.map +0 -1
- package/lib/bridge/transaction.test.d.ts +0 -2
- package/lib/bridge/transaction.test.d.ts.map +0 -1
- package/lib/bridge/transaction.test.js +0 -68
- package/lib/bridge/transaction.test.js.map +0 -1
- package/lib/logic/broadcast.test.d.ts +0 -2
- package/lib/logic/broadcast.test.d.ts.map +0 -1
- package/lib/logic/broadcast.test.js +0 -62
- package/lib/logic/broadcast.test.js.map +0 -1
- package/lib/logic/combine.test.d.ts +0 -2
- package/lib/logic/combine.test.d.ts.map +0 -1
- package/lib/logic/combine.test.js +0 -37
- package/lib/logic/combine.test.js.map +0 -1
- package/lib/logic/craftTransaction.integration.test.d.ts +0 -2
- package/lib/logic/craftTransaction.integration.test.d.ts.map +0 -1
- package/lib/logic/craftTransaction.integration.test.js +0 -98
- package/lib/logic/craftTransaction.integration.test.js.map +0 -1
- package/lib/logic/craftTransaction.test.d.ts +0 -2
- package/lib/logic/craftTransaction.test.d.ts.map +0 -1
- package/lib/logic/craftTransaction.test.js +0 -127
- package/lib/logic/craftTransaction.test.js.map +0 -1
- package/lib/logic/estimateFees.integration.test.d.ts +0 -2
- package/lib/logic/estimateFees.integration.test.d.ts.map +0 -1
- package/lib/logic/estimateFees.integration.test.js +0 -82
- package/lib/logic/estimateFees.integration.test.js.map +0 -1
- package/lib/logic/estimateFees.test.d.ts +0 -2
- package/lib/logic/estimateFees.test.d.ts.map +0 -1
- package/lib/logic/estimateFees.test.js +0 -70
- package/lib/logic/estimateFees.test.js.map +0 -1
- package/lib/logic/getBalance.integration.test.d.ts +0 -2
- package/lib/logic/getBalance.integration.test.d.ts.map +0 -1
- package/lib/logic/getBalance.integration.test.js +0 -56
- package/lib/logic/getBalance.integration.test.js.map +0 -1
- package/lib/logic/getBalance.test.d.ts +0 -2
- package/lib/logic/getBalance.test.d.ts.map +0 -1
- package/lib/logic/getBalance.test.js +0 -64
- package/lib/logic/getBalance.test.js.map +0 -1
- package/lib/logic/lastBlock.test.d.ts +0 -2
- package/lib/logic/lastBlock.test.d.ts.map +0 -1
- package/lib/logic/lastBlock.test.js +0 -27
- package/lib/logic/lastBlock.test.js.map +0 -1
- package/lib/logic/listOperations.test.d.ts +0 -2
- package/lib/logic/listOperations.test.d.ts.map +0 -1
- package/lib/logic/listOperations.test.js +0 -79
- package/lib/logic/listOperations.test.js.map +0 -1
- package/lib/network/sdk.integration.test.d.ts +0 -2
- package/lib/network/sdk.integration.test.d.ts.map +0 -1
- package/lib/network/sdk.integration.test.js +0 -215
- package/lib/network/sdk.integration.test.js.map +0 -1
- package/lib/network/sdk.test.d.ts +0 -2
- package/lib/network/sdk.test.d.ts.map +0 -1
- package/lib/network/sdk.test.js +0 -1784
- package/lib/network/sdk.test.js.map +0 -1
- package/lib/signer/getAddress.test.d.ts +0 -2
- package/lib/signer/getAddress.test.d.ts.map +0 -1
- package/lib/signer/getAddress.test.js +0 -106
- package/lib/signer/getAddress.test.js.map +0 -1
- package/lib/test/config.test.d.ts +0 -2
- package/lib/test/config.test.d.ts.map +0 -1
- package/lib/test/config.test.js +0 -44
- package/lib/test/config.test.js.map +0 -1
- package/lib-es/api/index.integration.test.d.ts +0 -2
- package/lib-es/api/index.integration.test.d.ts.map +0 -1
- package/lib-es/api/index.integration.test.js +0 -171
- package/lib-es/api/index.integration.test.js.map +0 -1
- package/lib-es/api/index.test.d.ts +0 -2
- package/lib-es/api/index.test.d.ts.map +0 -1
- package/lib-es/api/index.test.js +0 -148
- package/lib-es/api/index.test.js.map +0 -1
- package/lib-es/bridge/bridge.integration.test.d.ts.map +0 -1
- package/lib-es/bridge/bridge.integration.test.js.map +0 -1
- package/lib-es/bridge/broadcast.test.d.ts +0 -2
- package/lib-es/bridge/broadcast.test.d.ts.map +0 -1
- package/lib-es/bridge/broadcast.test.js +0 -46
- package/lib-es/bridge/broadcast.test.js.map +0 -1
- package/lib-es/bridge/buildOptimisticOperation.test.d.ts +0 -2
- package/lib-es/bridge/buildOptimisticOperation.test.d.ts.map +0 -1
- package/lib-es/bridge/buildOptimisticOperation.test.js +0 -47
- package/lib-es/bridge/buildOptimisticOperation.test.js.map +0 -1
- package/lib-es/bridge/buildTransaction.integration.test.d.ts +0 -2
- package/lib-es/bridge/buildTransaction.integration.test.d.ts.map +0 -1
- package/lib-es/bridge/buildTransaction.integration.test.js +0 -67
- package/lib-es/bridge/buildTransaction.integration.test.js.map +0 -1
- package/lib-es/bridge/buildTransaction.test.d.ts +0 -2
- package/lib-es/bridge/buildTransaction.test.d.ts.map +0 -1
- package/lib-es/bridge/buildTransaction.test.js +0 -229
- package/lib-es/bridge/buildTransaction.test.js.map +0 -1
- package/lib-es/bridge/estimateMaxSpendable.test.d.ts +0 -2
- package/lib-es/bridge/estimateMaxSpendable.test.d.ts.map +0 -1
- package/lib-es/bridge/estimateMaxSpendable.test.js +0 -50
- package/lib-es/bridge/estimateMaxSpendable.test.js.map +0 -1
- package/lib-es/bridge/formatters.test.d.ts +0 -2
- package/lib-es/bridge/formatters.test.d.ts.map +0 -1
- package/lib-es/bridge/formatters.test.js +0 -16
- package/lib-es/bridge/formatters.test.js.map +0 -1
- package/lib-es/bridge/getFeesForTransaction.test.d.ts +0 -2
- package/lib-es/bridge/getFeesForTransaction.test.d.ts.map +0 -1
- package/lib-es/bridge/getFeesForTransaction.test.js +0 -30
- package/lib-es/bridge/getFeesForTransaction.test.js.map +0 -1
- package/lib-es/bridge/getTransactionStatus.test.d.ts +0 -2
- package/lib-es/bridge/getTransactionStatus.test.d.ts.map +0 -1
- package/lib-es/bridge/getTransactionStatus.test.js +0 -64
- package/lib-es/bridge/getTransactionStatus.test.js.map +0 -1
- package/lib-es/bridge/index.test.d.ts +0 -2
- package/lib-es/bridge/index.test.d.ts.map +0 -1
- package/lib-es/bridge/index.test.js +0 -260
- package/lib-es/bridge/index.test.js.map +0 -1
- package/lib-es/bridge/preload.test.d.ts +0 -2
- package/lib-es/bridge/preload.test.d.ts.map +0 -1
- package/lib-es/bridge/preload.test.js +0 -50
- package/lib-es/bridge/preload.test.js.map +0 -1
- package/lib-es/bridge/prepareTransaction.test.d.ts +0 -2
- package/lib-es/bridge/prepareTransaction.test.d.ts.map +0 -1
- package/lib-es/bridge/prepareTransaction.test.js +0 -92
- package/lib-es/bridge/prepareTransaction.test.js.map +0 -1
- package/lib-es/bridge/serialization.test.d.ts +0 -2
- package/lib-es/bridge/serialization.test.d.ts.map +0 -1
- package/lib-es/bridge/serialization.test.js +0 -126
- package/lib-es/bridge/serialization.test.js.map +0 -1
- package/lib-es/bridge/signOperation.integration.test.d.ts +0 -2
- package/lib-es/bridge/signOperation.integration.test.d.ts.map +0 -1
- package/lib-es/bridge/signOperation.integration.test.js +0 -75
- package/lib-es/bridge/signOperation.integration.test.js.map +0 -1
- package/lib-es/bridge/signOperation.test.d.ts +0 -2
- package/lib-es/bridge/signOperation.test.d.ts.map +0 -1
- package/lib-es/bridge/signOperation.test.js +0 -440
- package/lib-es/bridge/signOperation.test.js.map +0 -1
- package/lib-es/bridge/synchronisation.test.d.ts +0 -2
- package/lib-es/bridge/synchronisation.test.d.ts.map +0 -1
- package/lib-es/bridge/synchronisation.test.js +0 -477
- package/lib-es/bridge/synchronisation.test.js.map +0 -1
- package/lib-es/bridge/transaction.test.d.ts +0 -2
- package/lib-es/bridge/transaction.test.d.ts.map +0 -1
- package/lib-es/bridge/transaction.test.js +0 -66
- package/lib-es/bridge/transaction.test.js.map +0 -1
- package/lib-es/logic/broadcast.test.d.ts +0 -2
- package/lib-es/logic/broadcast.test.d.ts.map +0 -1
- package/lib-es/logic/broadcast.test.js +0 -57
- package/lib-es/logic/broadcast.test.js.map +0 -1
- package/lib-es/logic/combine.test.d.ts +0 -2
- package/lib-es/logic/combine.test.d.ts.map +0 -1
- package/lib-es/logic/combine.test.js +0 -35
- package/lib-es/logic/combine.test.js.map +0 -1
- package/lib-es/logic/craftTransaction.integration.test.d.ts +0 -2
- package/lib-es/logic/craftTransaction.integration.test.d.ts.map +0 -1
- package/lib-es/logic/craftTransaction.integration.test.js +0 -93
- package/lib-es/logic/craftTransaction.integration.test.js.map +0 -1
- package/lib-es/logic/craftTransaction.test.d.ts +0 -2
- package/lib-es/logic/craftTransaction.test.d.ts.map +0 -1
- package/lib-es/logic/craftTransaction.test.js +0 -122
- package/lib-es/logic/craftTransaction.test.js.map +0 -1
- package/lib-es/logic/estimateFees.integration.test.d.ts +0 -2
- package/lib-es/logic/estimateFees.integration.test.d.ts.map +0 -1
- package/lib-es/logic/estimateFees.integration.test.js +0 -77
- package/lib-es/logic/estimateFees.integration.test.js.map +0 -1
- package/lib-es/logic/estimateFees.test.d.ts +0 -2
- package/lib-es/logic/estimateFees.test.d.ts.map +0 -1
- package/lib-es/logic/estimateFees.test.js +0 -65
- package/lib-es/logic/estimateFees.test.js.map +0 -1
- package/lib-es/logic/getBalance.integration.test.d.ts +0 -2
- package/lib-es/logic/getBalance.integration.test.d.ts.map +0 -1
- package/lib-es/logic/getBalance.integration.test.js +0 -51
- package/lib-es/logic/getBalance.integration.test.js.map +0 -1
- package/lib-es/logic/getBalance.test.d.ts +0 -2
- package/lib-es/logic/getBalance.test.d.ts.map +0 -1
- package/lib-es/logic/getBalance.test.js +0 -62
- package/lib-es/logic/getBalance.test.js.map +0 -1
- package/lib-es/logic/lastBlock.test.d.ts +0 -2
- package/lib-es/logic/lastBlock.test.d.ts.map +0 -1
- package/lib-es/logic/lastBlock.test.js +0 -25
- package/lib-es/logic/lastBlock.test.js.map +0 -1
- package/lib-es/logic/listOperations.test.d.ts +0 -2
- package/lib-es/logic/listOperations.test.d.ts.map +0 -1
- package/lib-es/logic/listOperations.test.js +0 -77
- package/lib-es/logic/listOperations.test.js.map +0 -1
- package/lib-es/network/sdk.integration.test.d.ts +0 -2
- package/lib-es/network/sdk.integration.test.d.ts.map +0 -1
- package/lib-es/network/sdk.integration.test.js +0 -210
- package/lib-es/network/sdk.integration.test.js.map +0 -1
- package/lib-es/network/sdk.test.d.ts +0 -2
- package/lib-es/network/sdk.test.d.ts.map +0 -1
- package/lib-es/network/sdk.test.js +0 -1756
- package/lib-es/network/sdk.test.js.map +0 -1
- package/lib-es/signer/getAddress.test.d.ts +0 -2
- package/lib-es/signer/getAddress.test.d.ts.map +0 -1
- package/lib-es/signer/getAddress.test.js +0 -101
- package/lib-es/signer/getAddress.test.js.map +0 -1
- package/lib-es/test/config.test.d.ts +0 -2
- package/lib-es/test/config.test.d.ts.map +0 -1
- package/lib-es/test/config.test.js +0 -39
- package/lib-es/test/config.test.js.map +0 -1
|
@@ -1,62 +0,0 @@
|
|
|
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 broadcast_1 = require("./broadcast");
|
|
7
|
-
const network_1 = __importDefault(require("../network"));
|
|
8
|
-
// Mock the suiAPI
|
|
9
|
-
jest.mock("../network", () => ({
|
|
10
|
-
__esModule: true,
|
|
11
|
-
default: {
|
|
12
|
-
executeTransactionBlock: jest.fn().mockResolvedValue({ digest: "test-digest" }),
|
|
13
|
-
},
|
|
14
|
-
}));
|
|
15
|
-
describe("broadcast", () => {
|
|
16
|
-
beforeEach(() => {
|
|
17
|
-
jest.clearAllMocks();
|
|
18
|
-
});
|
|
19
|
-
describe("with string input", () => {
|
|
20
|
-
it("should correctly extract transaction and signature and broadcast", async () => {
|
|
21
|
-
// Mock transaction string with 4-byte length prefix
|
|
22
|
-
// Example: "0010" (length 16 in hex) + "1234567890" (raw tx) + "abcdef" (signature)
|
|
23
|
-
const mockTransaction = "000a1234567890abcdef";
|
|
24
|
-
const result = await (0, broadcast_1.broadcast)(mockTransaction);
|
|
25
|
-
expect(result).toBe("test-digest");
|
|
26
|
-
expect(network_1.default.executeTransactionBlock).toHaveBeenCalledWith({
|
|
27
|
-
transactionBlock: "1234567890",
|
|
28
|
-
signature: "abcdef",
|
|
29
|
-
options: {
|
|
30
|
-
showEffects: true,
|
|
31
|
-
},
|
|
32
|
-
});
|
|
33
|
-
});
|
|
34
|
-
it("should not call executeTransactionBlock if format is not hex", async () => {
|
|
35
|
-
const mockTransaction = "000g1234567890abcdef";
|
|
36
|
-
const result = await (0, broadcast_1.broadcast)(mockTransaction);
|
|
37
|
-
expect(result).toBe("");
|
|
38
|
-
expect(network_1.default.executeTransactionBlock).toHaveBeenCalledTimes(0);
|
|
39
|
-
});
|
|
40
|
-
it("should not call executeTransactionBlock if format is incorrect", async () => {
|
|
41
|
-
const mockTransaction = "000a1";
|
|
42
|
-
const result = await (0, broadcast_1.broadcast)(mockTransaction);
|
|
43
|
-
expect(result).toBe("");
|
|
44
|
-
expect(network_1.default.executeTransactionBlock).toHaveBeenCalledTimes(0);
|
|
45
|
-
});
|
|
46
|
-
});
|
|
47
|
-
describe("with ExecuteTransactionBlockParams input", () => {
|
|
48
|
-
it("should directly use provided params", async () => {
|
|
49
|
-
const mockParams = {
|
|
50
|
-
transactionBlock: "test-block",
|
|
51
|
-
signature: "test-signature",
|
|
52
|
-
options: {
|
|
53
|
-
showEffects: true,
|
|
54
|
-
},
|
|
55
|
-
};
|
|
56
|
-
const result = await (0, broadcast_1.broadcast)(mockParams);
|
|
57
|
-
expect(result).toBe("test-digest");
|
|
58
|
-
expect(network_1.default.executeTransactionBlock).toHaveBeenCalledWith(mockParams);
|
|
59
|
-
});
|
|
60
|
-
});
|
|
61
|
-
});
|
|
62
|
-
//# sourceMappingURL=broadcast.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"broadcast.test.js","sourceRoot":"","sources":["../../src/logic/broadcast.test.ts"],"names":[],"mappings":";;;;;AAAA,2CAAwC;AACxC,yDAAgC;AAEhC,kBAAkB;AAClB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,GAAG,EAAE,CAAC,CAAC;IAC7B,UAAU,EAAE,IAAI;IAChB,OAAO,EAAE;QACP,uBAAuB,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,EAAE,MAAM,EAAE,aAAa,EAAE,CAAC;KAChF;CACF,CAAC,CAAC,CAAC;AAEJ,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,UAAU,CAAC,GAAG,EAAE;QACd,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;QACjC,EAAE,CAAC,kEAAkE,EAAE,KAAK,IAAI,EAAE;YAChF,oDAAoD;YACpD,oFAAoF;YACpF,MAAM,eAAe,GAAG,sBAAsB,CAAC;YAE/C,MAAM,MAAM,GAAG,MAAM,IAAA,qBAAS,EAAC,eAAe,CAAC,CAAC;YAEhD,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YACnC,MAAM,CAAC,iBAAM,CAAC,uBAAuB,CAAC,CAAC,oBAAoB,CAAC;gBAC1D,gBAAgB,EAAE,YAAY;gBAC9B,SAAS,EAAE,QAAQ;gBACnB,OAAO,EAAE;oBACP,WAAW,EAAE,IAAI;iBAClB;aACF,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,8DAA8D,EAAE,KAAK,IAAI,EAAE;YAC5E,MAAM,eAAe,GAAG,sBAAsB,CAAC;YAE/C,MAAM,MAAM,GAAG,MAAM,IAAA,qBAAS,EAAC,eAAe,CAAC,CAAC;YAEhD,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACxB,MAAM,CAAC,iBAAM,CAAC,uBAAuB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAClE,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,gEAAgE,EAAE,KAAK,IAAI,EAAE;YAC9E,MAAM,eAAe,GAAG,OAAO,CAAC;YAEhC,MAAM,MAAM,GAAG,MAAM,IAAA,qBAAS,EAAC,eAAe,CAAC,CAAC;YAEhD,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACxB,MAAM,CAAC,iBAAM,CAAC,uBAAuB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAClE,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,0CAA0C,EAAE,GAAG,EAAE;QACxD,EAAE,CAAC,qCAAqC,EAAE,KAAK,IAAI,EAAE;YACnD,MAAM,UAAU,GAAG;gBACjB,gBAAgB,EAAE,YAAY;gBAC9B,SAAS,EAAE,gBAAgB;gBAC3B,OAAO,EAAE;oBACP,WAAW,EAAE,IAAI;iBAClB;aACF,CAAC;YAEF,MAAM,MAAM,GAAG,MAAM,IAAA,qBAAS,EAAC,UAAU,CAAC,CAAC;YAE3C,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YACnC,MAAM,CAAC,iBAAM,CAAC,uBAAuB,CAAC,CAAC,oBAAoB,CAAC,UAAU,CAAC,CAAC;QAC1E,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"combine.test.d.ts","sourceRoot":"","sources":["../../src/logic/combine.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const combine_1 = require("./combine");
|
|
4
|
-
describe("combine", () => {
|
|
5
|
-
test("should correctly combine transaction and signature", () => {
|
|
6
|
-
const tx = "abcdef1234567890";
|
|
7
|
-
const signature = "signature123";
|
|
8
|
-
const result = (0, combine_1.combine)(tx, signature);
|
|
9
|
-
// Expected format: length (4 hex chars) + tx + signature
|
|
10
|
-
expect(result).toBe("0010abcdef1234567890signature123");
|
|
11
|
-
});
|
|
12
|
-
test("should handle empty transaction", () => {
|
|
13
|
-
const tx = "";
|
|
14
|
-
const signature = "signature123";
|
|
15
|
-
const result = (0, combine_1.combine)(tx, signature);
|
|
16
|
-
expect(result).toBe("0000signature123");
|
|
17
|
-
});
|
|
18
|
-
test("should handle empty signature", () => {
|
|
19
|
-
const tx = "abcdef1234567890";
|
|
20
|
-
const signature = "";
|
|
21
|
-
const result = (0, combine_1.combine)(tx, signature);
|
|
22
|
-
expect(result).toBe("0010abcdef1234567890");
|
|
23
|
-
});
|
|
24
|
-
test("should pad transaction length with zeros", () => {
|
|
25
|
-
const tx = "a"; // length 1
|
|
26
|
-
const signature = "sig";
|
|
27
|
-
const result = (0, combine_1.combine)(tx, signature);
|
|
28
|
-
expect(result).toBe("0001asig");
|
|
29
|
-
});
|
|
30
|
-
test("should handle longer transactions", () => {
|
|
31
|
-
const tx = "a".repeat(256); // length 256 (0x100)
|
|
32
|
-
const signature = "sig";
|
|
33
|
-
const result = (0, combine_1.combine)(tx, signature);
|
|
34
|
-
expect(result).toBe("0100" + "a".repeat(256) + "sig");
|
|
35
|
-
});
|
|
36
|
-
});
|
|
37
|
-
//# sourceMappingURL=combine.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"combine.test.js","sourceRoot":"","sources":["../../src/logic/combine.test.ts"],"names":[],"mappings":";;AAAA,uCAAoC;AAEpC,QAAQ,CAAC,SAAS,EAAE,GAAG,EAAE;IACvB,IAAI,CAAC,oDAAoD,EAAE,GAAG,EAAE;QAC9D,MAAM,EAAE,GAAG,kBAAkB,CAAC;QAC9B,MAAM,SAAS,GAAG,cAAc,CAAC;QACjC,MAAM,MAAM,GAAG,IAAA,iBAAO,EAAC,EAAE,EAAE,SAAS,CAAC,CAAC;QACtC,yDAAyD;QACzD,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,kCAAkC,CAAC,CAAC;IAC1D,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,iCAAiC,EAAE,GAAG,EAAE;QAC3C,MAAM,EAAE,GAAG,EAAE,CAAC;QACd,MAAM,SAAS,GAAG,cAAc,CAAC;QACjC,MAAM,MAAM,GAAG,IAAA,iBAAO,EAAC,EAAE,EAAE,SAAS,CAAC,CAAC;QACtC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,+BAA+B,EAAE,GAAG,EAAE;QACzC,MAAM,EAAE,GAAG,kBAAkB,CAAC;QAC9B,MAAM,SAAS,GAAG,EAAE,CAAC;QACrB,MAAM,MAAM,GAAG,IAAA,iBAAO,EAAC,EAAE,EAAE,SAAS,CAAC,CAAC;QACtC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,0CAA0C,EAAE,GAAG,EAAE;QACpD,MAAM,EAAE,GAAG,GAAG,CAAC,CAAC,WAAW;QAC3B,MAAM,SAAS,GAAG,KAAK,CAAC;QACxB,MAAM,MAAM,GAAG,IAAA,iBAAO,EAAC,EAAE,EAAE,SAAS,CAAC,CAAC;QACtC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,mCAAmC,EAAE,GAAG,EAAE;QAC7C,MAAM,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,qBAAqB;QACjD,MAAM,SAAS,GAAG,KAAK,CAAC;QACxB,MAAM,MAAM,GAAG,IAAA,iBAAO,EAAC,EAAE,EAAE,SAAS,CAAC,CAAC;QACtC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC;IACxD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"craftTransaction.integration.test.d.ts","sourceRoot":"","sources":["../../src/logic/craftTransaction.integration.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,98 +0,0 @@
|
|
|
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 client_1 = require("@mysten/sui/client");
|
|
7
|
-
const config_1 = __importDefault(require("../config"));
|
|
8
|
-
const testUtils_1 = require("../test/testUtils");
|
|
9
|
-
const craftTransaction_1 = require("./craftTransaction");
|
|
10
|
-
const SENDER = "0x33444cf803c690db96527cec67e3c9ab512596f4ba2d4eace43f0b4f716e0164";
|
|
11
|
-
const RECIPIENT = "0x33444cf803c690db96527cec67e3c9ab512596f4ba2d4eace43f0b4f716e0164";
|
|
12
|
-
describe("craftTransaction", () => {
|
|
13
|
-
beforeAll(() => {
|
|
14
|
-
config_1.default.setCoinConfig(() => ({
|
|
15
|
-
status: {
|
|
16
|
-
type: "active",
|
|
17
|
-
},
|
|
18
|
-
node: {
|
|
19
|
-
url: (0, client_1.getFullnodeUrl)("mainnet"),
|
|
20
|
-
},
|
|
21
|
-
}));
|
|
22
|
-
});
|
|
23
|
-
it("should craft a native SUI send transaction", async () => {
|
|
24
|
-
const transactionIntent = {
|
|
25
|
-
intentType: "transaction",
|
|
26
|
-
sender: SENDER,
|
|
27
|
-
recipient: RECIPIENT,
|
|
28
|
-
amount: BigInt(1000),
|
|
29
|
-
type: "send",
|
|
30
|
-
asset: { type: "native" },
|
|
31
|
-
};
|
|
32
|
-
const result = await (0, craftTransaction_1.craftTransaction)(transactionIntent);
|
|
33
|
-
expect(result).toBeDefined();
|
|
34
|
-
expect(result.unsigned).toBeInstanceOf(Uint8Array);
|
|
35
|
-
expect(result.objects).toBeUndefined();
|
|
36
|
-
const resultCoinTypes = await (0, testUtils_1.extractCoinTypeFromUnsignedTx)(result.unsigned);
|
|
37
|
-
expect(resultCoinTypes).toEqual(expect.arrayContaining([expect.stringContaining("sui")]));
|
|
38
|
-
}, 15000);
|
|
39
|
-
it("should craft a token send transaction", async () => {
|
|
40
|
-
const coinType = "0x375f70cf2ae4c00bf37117d0c85a2c71545e6ee05c4a5c7d282cd66a4504b068::usdt::USDT";
|
|
41
|
-
const transactionIntent = {
|
|
42
|
-
intentType: "transaction",
|
|
43
|
-
sender: SENDER,
|
|
44
|
-
recipient: RECIPIENT,
|
|
45
|
-
amount: BigInt(1000),
|
|
46
|
-
type: "send",
|
|
47
|
-
asset: {
|
|
48
|
-
type: "token",
|
|
49
|
-
assetReference: coinType,
|
|
50
|
-
},
|
|
51
|
-
};
|
|
52
|
-
const result = await (0, craftTransaction_1.craftTransaction)(transactionIntent);
|
|
53
|
-
expect(result).toBeDefined();
|
|
54
|
-
expect(result.unsigned).toBeInstanceOf(Uint8Array);
|
|
55
|
-
expect(result.objects).toBeUndefined();
|
|
56
|
-
const resultCoinTypes = await (0, testUtils_1.extractCoinTypeFromUnsignedTx)(result.unsigned);
|
|
57
|
-
expect(resultCoinTypes).toEqual(expect.arrayContaining([expect.stringContaining("usdt")]));
|
|
58
|
-
}, 15000);
|
|
59
|
-
it("should craft a native SUI send transaction, returning serialized objects when requested", async () => {
|
|
60
|
-
const transactionIntent = {
|
|
61
|
-
intentType: "transaction",
|
|
62
|
-
sender: SENDER,
|
|
63
|
-
recipient: RECIPIENT,
|
|
64
|
-
amount: BigInt(1000),
|
|
65
|
-
type: "send",
|
|
66
|
-
asset: { type: "native" },
|
|
67
|
-
};
|
|
68
|
-
const result = await (0, craftTransaction_1.craftTransaction)(transactionIntent, true);
|
|
69
|
-
expect(result).toBeDefined();
|
|
70
|
-
expect(result.unsigned).toBeInstanceOf(Uint8Array);
|
|
71
|
-
expect(result.objects).toBeDefined();
|
|
72
|
-
expect(result.objects?.length).toBeGreaterThan(0);
|
|
73
|
-
const resultCoinTypes = await (0, testUtils_1.extractCoinTypeFromUnsignedTx)(result.unsigned);
|
|
74
|
-
expect(resultCoinTypes).toEqual(expect.arrayContaining([expect.stringContaining("sui")]));
|
|
75
|
-
}, 15000);
|
|
76
|
-
it("should craft a token send transaction, returning serialized objects when requested", async () => {
|
|
77
|
-
const coinType = "0x375f70cf2ae4c00bf37117d0c85a2c71545e6ee05c4a5c7d282cd66a4504b068::usdt::USDT";
|
|
78
|
-
const transactionIntent = {
|
|
79
|
-
intentType: "transaction",
|
|
80
|
-
sender: SENDER,
|
|
81
|
-
recipient: RECIPIENT,
|
|
82
|
-
amount: BigInt(1000),
|
|
83
|
-
type: "send",
|
|
84
|
-
asset: {
|
|
85
|
-
type: "token",
|
|
86
|
-
assetReference: coinType,
|
|
87
|
-
},
|
|
88
|
-
};
|
|
89
|
-
const result = await (0, craftTransaction_1.craftTransaction)(transactionIntent, true);
|
|
90
|
-
expect(result).toBeDefined();
|
|
91
|
-
expect(result.unsigned).toBeInstanceOf(Uint8Array);
|
|
92
|
-
expect(result.objects).toBeDefined();
|
|
93
|
-
expect(result.objects?.length).toBeGreaterThan(0);
|
|
94
|
-
const resultCoinTypes = await (0, testUtils_1.extractCoinTypeFromUnsignedTx)(result.unsigned);
|
|
95
|
-
expect(resultCoinTypes).toEqual(expect.arrayContaining([expect.stringContaining("usdt")]));
|
|
96
|
-
}, 15000);
|
|
97
|
-
});
|
|
98
|
-
//# sourceMappingURL=craftTransaction.integration.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"craftTransaction.integration.test.js","sourceRoot":"","sources":["../../src/logic/craftTransaction.integration.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"craftTransaction.test.d.ts","sourceRoot":"","sources":["../../src/logic/craftTransaction.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,127 +0,0 @@
|
|
|
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 craftTransaction_1 = require("../logic/craftTransaction");
|
|
7
|
-
const network_1 = __importDefault(require("../network"));
|
|
8
|
-
const bignumber_js_1 = require("bignumber.js");
|
|
9
|
-
jest.mock("../network");
|
|
10
|
-
describe("craftTransaction", () => {
|
|
11
|
-
const mockUnsignedTx = new Uint8Array([1, 2, 3]);
|
|
12
|
-
const mockCreateTransaction = network_1.default.createTransaction;
|
|
13
|
-
beforeEach(() => {
|
|
14
|
-
jest.clearAllMocks();
|
|
15
|
-
mockCreateTransaction.mockResolvedValue({ unsigned: mockUnsignedTx });
|
|
16
|
-
});
|
|
17
|
-
it("should create a transaction with correct parameters", async () => {
|
|
18
|
-
const sender = "0x123";
|
|
19
|
-
const amount = BigInt("1000000000");
|
|
20
|
-
const recipient = "0x456";
|
|
21
|
-
const type = "send";
|
|
22
|
-
const intentType = "transaction";
|
|
23
|
-
const result = await (0, craftTransaction_1.craftTransaction)({
|
|
24
|
-
intentType,
|
|
25
|
-
sender,
|
|
26
|
-
amount,
|
|
27
|
-
recipient,
|
|
28
|
-
type,
|
|
29
|
-
asset: { type: "native" },
|
|
30
|
-
});
|
|
31
|
-
expect(mockCreateTransaction).toHaveBeenCalledWith(sender, {
|
|
32
|
-
intentType,
|
|
33
|
-
amount: new bignumber_js_1.BigNumber(amount.toString()),
|
|
34
|
-
recipient,
|
|
35
|
-
mode: type,
|
|
36
|
-
coinType: "0x2::sui::SUI",
|
|
37
|
-
}, false);
|
|
38
|
-
expect(result).toEqual({ unsigned: mockUnsignedTx });
|
|
39
|
-
});
|
|
40
|
-
it("should handle different transaction types", async () => {
|
|
41
|
-
const sender = "0x123";
|
|
42
|
-
const amount = BigInt("500000000");
|
|
43
|
-
const recipient = "0x456";
|
|
44
|
-
const type = "send";
|
|
45
|
-
const intentType = "transaction";
|
|
46
|
-
const result = await (0, craftTransaction_1.craftTransaction)({
|
|
47
|
-
intentType,
|
|
48
|
-
sender,
|
|
49
|
-
amount,
|
|
50
|
-
recipient,
|
|
51
|
-
type,
|
|
52
|
-
asset: { type: "native" },
|
|
53
|
-
});
|
|
54
|
-
expect(mockCreateTransaction).toHaveBeenCalledWith(sender, {
|
|
55
|
-
intentType,
|
|
56
|
-
amount: new bignumber_js_1.BigNumber(amount.toString()),
|
|
57
|
-
recipient,
|
|
58
|
-
mode: type,
|
|
59
|
-
coinType: "0x2::sui::SUI",
|
|
60
|
-
}, false);
|
|
61
|
-
expect(result).toEqual({ unsigned: mockUnsignedTx });
|
|
62
|
-
});
|
|
63
|
-
it("should handle zero amount transactions", async () => {
|
|
64
|
-
const sender = "0x123";
|
|
65
|
-
const amount = BigInt("0");
|
|
66
|
-
const recipient = "0x456";
|
|
67
|
-
const type = "send";
|
|
68
|
-
const intentType = "transaction";
|
|
69
|
-
const result = await (0, craftTransaction_1.craftTransaction)({
|
|
70
|
-
intentType,
|
|
71
|
-
sender,
|
|
72
|
-
amount,
|
|
73
|
-
recipient,
|
|
74
|
-
type,
|
|
75
|
-
asset: { type: "native" },
|
|
76
|
-
});
|
|
77
|
-
expect(mockCreateTransaction).toHaveBeenCalledWith(sender, {
|
|
78
|
-
intentType,
|
|
79
|
-
amount: new bignumber_js_1.BigNumber(amount.toString()),
|
|
80
|
-
recipient,
|
|
81
|
-
mode: type,
|
|
82
|
-
coinType: "0x2::sui::SUI",
|
|
83
|
-
}, false);
|
|
84
|
-
expect(result).toEqual({ unsigned: mockUnsignedTx });
|
|
85
|
-
});
|
|
86
|
-
it("should handle large amount transactions", async () => {
|
|
87
|
-
const sender = "0x123";
|
|
88
|
-
const amount = BigInt("1000000000000000000"); // 1 SUI (assuming 9 decimals)
|
|
89
|
-
const recipient = "0x456";
|
|
90
|
-
const type = "send";
|
|
91
|
-
const intentType = "transaction";
|
|
92
|
-
const result = await (0, craftTransaction_1.craftTransaction)({
|
|
93
|
-
intentType,
|
|
94
|
-
sender,
|
|
95
|
-
amount,
|
|
96
|
-
recipient,
|
|
97
|
-
type,
|
|
98
|
-
asset: { type: "native" },
|
|
99
|
-
});
|
|
100
|
-
expect(mockCreateTransaction).toHaveBeenCalledWith(sender, {
|
|
101
|
-
intentType,
|
|
102
|
-
amount: new bignumber_js_1.BigNumber(amount.toString()),
|
|
103
|
-
recipient,
|
|
104
|
-
mode: type,
|
|
105
|
-
coinType: "0x2::sui::SUI",
|
|
106
|
-
}, false);
|
|
107
|
-
expect(result).toEqual({ unsigned: mockUnsignedTx });
|
|
108
|
-
});
|
|
109
|
-
it("should handle error cases from createTransaction", async () => {
|
|
110
|
-
const error = new Error("Network error");
|
|
111
|
-
mockCreateTransaction.mockRejectedValue(error);
|
|
112
|
-
const sender = "0x123";
|
|
113
|
-
const amount = BigInt("1000000000");
|
|
114
|
-
const recipient = "0x456";
|
|
115
|
-
const type = "send";
|
|
116
|
-
const intentType = "transaction";
|
|
117
|
-
await expect((0, craftTransaction_1.craftTransaction)({
|
|
118
|
-
intentType,
|
|
119
|
-
sender,
|
|
120
|
-
amount,
|
|
121
|
-
recipient,
|
|
122
|
-
type,
|
|
123
|
-
asset: { type: "native" },
|
|
124
|
-
})).rejects.toThrow("Network error");
|
|
125
|
-
});
|
|
126
|
-
});
|
|
127
|
-
//# sourceMappingURL=craftTransaction.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"craftTransaction.test.js","sourceRoot":"","sources":["../../src/logic/craftTransaction.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"estimateFees.integration.test.d.ts","sourceRoot":"","sources":["../../src/logic/estimateFees.integration.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,82 +0,0 @@
|
|
|
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 client_1 = require("@mysten/sui/client");
|
|
7
|
-
const config_1 = __importDefault(require("../config"));
|
|
8
|
-
const estimateFees_1 = require("./estimateFees");
|
|
9
|
-
const SENDER = "0xad79719ac7edb44f6e253f1f771e8291e281a6aaf1e4789b52bf85336f525e8e";
|
|
10
|
-
const RECIPIENT = "0x33444cf803c690db96527cec67e3c9ab512596f4ba2d4eace43f0b4f716e0164";
|
|
11
|
-
describe("estimateFees", () => {
|
|
12
|
-
beforeAll(() => {
|
|
13
|
-
config_1.default.setCoinConfig(() => ({
|
|
14
|
-
status: {
|
|
15
|
-
type: "active",
|
|
16
|
-
},
|
|
17
|
-
node: {
|
|
18
|
-
url: (0, client_1.getFullnodeUrl)("mainnet"),
|
|
19
|
-
},
|
|
20
|
-
}));
|
|
21
|
-
});
|
|
22
|
-
it("should estimate fees for native SUI transaction", async () => {
|
|
23
|
-
const transactionIntent = {
|
|
24
|
-
intentType: "transaction",
|
|
25
|
-
sender: SENDER,
|
|
26
|
-
recipient: RECIPIENT,
|
|
27
|
-
amount: BigInt(1000),
|
|
28
|
-
type: "send",
|
|
29
|
-
asset: { type: "native" },
|
|
30
|
-
};
|
|
31
|
-
const estimatedFees = await (0, estimateFees_1.estimateFees)(transactionIntent);
|
|
32
|
-
expect(typeof estimatedFees).toBe("bigint");
|
|
33
|
-
expect(estimatedFees).toBeGreaterThan(1000n);
|
|
34
|
-
expect(estimatedFees).toBeLessThan(10000000n);
|
|
35
|
-
}, 25000);
|
|
36
|
-
it("should estimate fees for token transaction", async () => {
|
|
37
|
-
const coinType = "0x375f70cf2ae4c00bf37117d0c85a2c71545e6ee05c4a5c7d282cd66a4504b068::usdt::USDT";
|
|
38
|
-
const transactionIntent = {
|
|
39
|
-
intentType: "transaction",
|
|
40
|
-
sender: SENDER,
|
|
41
|
-
recipient: RECIPIENT,
|
|
42
|
-
amount: BigInt(1000),
|
|
43
|
-
type: "send",
|
|
44
|
-
asset: {
|
|
45
|
-
type: "token",
|
|
46
|
-
assetReference: coinType,
|
|
47
|
-
},
|
|
48
|
-
};
|
|
49
|
-
const estimatedFees = await (0, estimateFees_1.estimateFees)(transactionIntent);
|
|
50
|
-
expect(typeof estimatedFees).toBe("bigint");
|
|
51
|
-
expect(estimatedFees).toBeGreaterThan(1000n);
|
|
52
|
-
expect(estimatedFees).toBeLessThan(10000000n);
|
|
53
|
-
}, 25000);
|
|
54
|
-
it("should handle concurrent fee estimations", async () => {
|
|
55
|
-
const transactionIntent = {
|
|
56
|
-
intentType: "transaction",
|
|
57
|
-
sender: SENDER,
|
|
58
|
-
recipient: RECIPIENT,
|
|
59
|
-
amount: BigInt(1000),
|
|
60
|
-
type: "send",
|
|
61
|
-
asset: { type: "native" },
|
|
62
|
-
};
|
|
63
|
-
// Run multiple concurrent estimations
|
|
64
|
-
const promises = Array(5)
|
|
65
|
-
.fill(0)
|
|
66
|
-
.map(() => (0, estimateFees_1.estimateFees)(transactionIntent));
|
|
67
|
-
const results = await Promise.all(promises);
|
|
68
|
-
// All results should be valid
|
|
69
|
-
results.forEach(fees => {
|
|
70
|
-
expect(typeof fees).toBe("bigint");
|
|
71
|
-
expect(fees).toBeGreaterThan(1000n);
|
|
72
|
-
expect(fees).toBeLessThan(10000000n);
|
|
73
|
-
});
|
|
74
|
-
// Results should be similar (may have slight variations)
|
|
75
|
-
const values = results.map(r => Number(r));
|
|
76
|
-
const minValue = Math.min(...values);
|
|
77
|
-
const maxValue = Math.max(...values);
|
|
78
|
-
// Should not vary by more than 50% under concurrent load
|
|
79
|
-
expect((maxValue - minValue) / minValue).toBeLessThan(0.5);
|
|
80
|
-
}, 25000);
|
|
81
|
-
});
|
|
82
|
-
//# sourceMappingURL=estimateFees.integration.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"estimateFees.integration.test.js","sourceRoot":"","sources":["../../src/logic/estimateFees.integration.test.ts"],"names":[],"mappings":";;;;;AACA,+CAAoD;AACpD,uDAAmC;AACnC,iDAA8C;AAE9C,MAAM,MAAM,GAAG,oEAAoE,CAAC;AACpF,MAAM,SAAS,GAAG,oEAAoE,CAAC;AAEvF,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,SAAS,CAAC,GAAG,EAAE;QACb,gBAAU,CAAC,aAAa,CAAC,GAAG,EAAE,CAAC,CAAC;YAC9B,MAAM,EAAE;gBACN,IAAI,EAAE,QAAQ;aACf;YACD,IAAI,EAAE;gBACJ,GAAG,EAAE,IAAA,uBAAc,EAAC,SAAS,CAAC;aAC/B;SACF,CAAC,CAAC,CAAC;IACN,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iDAAiD,EAAE,KAAK,IAAI,EAAE;QAC/D,MAAM,iBAAiB,GAAsB;YAC3C,UAAU,EAAE,aAAa;YACzB,MAAM,EAAE,MAAM;YACd,SAAS,EAAE,SAAS;YACpB,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC;YACpB,IAAI,EAAE,MAAM;YACZ,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;SAC1B,CAAC;QAEF,MAAM,aAAa,GAAG,MAAM,IAAA,2BAAY,EAAC,iBAAiB,CAAC,CAAC;QAE5D,MAAM,CAAC,OAAO,aAAa,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC5C,MAAM,CAAC,aAAa,CAAC,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;QAC7C,MAAM,CAAC,aAAa,CAAC,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;IAChD,CAAC,EAAE,KAAK,CAAC,CAAC;IAEV,EAAE,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;QAC1D,MAAM,QAAQ,GACZ,gFAAgF,CAAC;QAEnF,MAAM,iBAAiB,GAAsB;YAC3C,UAAU,EAAE,aAAa;YACzB,MAAM,EAAE,MAAM;YACd,SAAS,EAAE,SAAS;YACpB,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC;YACpB,IAAI,EAAE,MAAM;YACZ,KAAK,EAAE;gBACL,IAAI,EAAE,OAAO;gBACb,cAAc,EAAE,QAAQ;aACzB;SACF,CAAC;QAEF,MAAM,aAAa,GAAG,MAAM,IAAA,2BAAY,EAAC,iBAAiB,CAAC,CAAC;QAE5D,MAAM,CAAC,OAAO,aAAa,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC5C,MAAM,CAAC,aAAa,CAAC,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;QAC7C,MAAM,CAAC,aAAa,CAAC,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;IAChD,CAAC,EAAE,KAAK,CAAC,CAAC;IAEV,EAAE,CAAC,0CAA0C,EAAE,KAAK,IAAI,EAAE;QACxD,MAAM,iBAAiB,GAAsB;YAC3C,UAAU,EAAE,aAAa;YACzB,MAAM,EAAE,MAAM;YACd,SAAS,EAAE,SAAS;YACpB,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC;YACpB,IAAI,EAAE,MAAM;YACZ,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;SAC1B,CAAC;QAEF,sCAAsC;QACtC,MAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,CAAC;aACtB,IAAI,CAAC,CAAC,CAAC;aACP,GAAG,CAAC,GAAG,EAAE,CAAC,IAAA,2BAAY,EAAC,iBAAiB,CAAC,CAAC,CAAC;QAC9C,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAE5C,8BAA8B;QAC9B,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACrB,MAAM,CAAC,OAAO,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACnC,MAAM,CAAC,IAAI,CAAC,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;YACpC,MAAM,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;QAEH,yDAAyD;QACzD,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3C,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC;QACrC,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC;QAErC,yDAAyD;QACzD,MAAM,CAAC,CAAC,QAAQ,GAAG,QAAQ,CAAC,GAAG,QAAQ,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;IAC7D,CAAC,EAAE,KAAK,CAAC,CAAC;AACZ,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"estimateFees.test.d.ts","sourceRoot":"","sources":["../../src/logic/estimateFees.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,70 +0,0 @@
|
|
|
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 estimateFees_1 = require("./estimateFees");
|
|
7
|
-
const network_1 = __importDefault(require("../network"));
|
|
8
|
-
const bignumber_js_1 = require("bignumber.js");
|
|
9
|
-
// Mock the suiAPI module
|
|
10
|
-
jest.mock("../network", () => ({
|
|
11
|
-
__esModule: true,
|
|
12
|
-
default: {
|
|
13
|
-
paymentInfo: jest.fn(),
|
|
14
|
-
},
|
|
15
|
-
}));
|
|
16
|
-
describe("estimateFees", () => {
|
|
17
|
-
beforeEach(() => {
|
|
18
|
-
jest.clearAllMocks();
|
|
19
|
-
});
|
|
20
|
-
it("should return the correct gas budget as bigint", async () => {
|
|
21
|
-
// Mock the paymentInfo response
|
|
22
|
-
const mockGasBudget = "1000000";
|
|
23
|
-
network_1.default.paymentInfo.mockResolvedValue({
|
|
24
|
-
gasBudget: mockGasBudget,
|
|
25
|
-
});
|
|
26
|
-
const transactionIntent = {
|
|
27
|
-
intentType: "transaction",
|
|
28
|
-
sender: "0x123",
|
|
29
|
-
recipient: "0x456",
|
|
30
|
-
amount: BigInt("1000000000"),
|
|
31
|
-
type: "send",
|
|
32
|
-
asset: { type: "native" },
|
|
33
|
-
};
|
|
34
|
-
const result = await (0, estimateFees_1.estimateFees)(transactionIntent);
|
|
35
|
-
expect(network_1.default.paymentInfo).toHaveBeenCalledWith(transactionIntent.sender, {
|
|
36
|
-
recipient: transactionIntent.recipient,
|
|
37
|
-
amount: (0, bignumber_js_1.BigNumber)(transactionIntent.amount.toString()),
|
|
38
|
-
coinType: "0x2::sui::SUI",
|
|
39
|
-
errors: {},
|
|
40
|
-
family: "sui",
|
|
41
|
-
mode: "send",
|
|
42
|
-
});
|
|
43
|
-
expect(result).toBe(BigInt(mockGasBudget));
|
|
44
|
-
});
|
|
45
|
-
it("should handle zero amount transactions", async () => {
|
|
46
|
-
const mockGasBudget = "500000";
|
|
47
|
-
network_1.default.paymentInfo.mockResolvedValue({
|
|
48
|
-
gasBudget: mockGasBudget,
|
|
49
|
-
});
|
|
50
|
-
const transactionIntent = {
|
|
51
|
-
intentType: "transaction",
|
|
52
|
-
sender: "0x123",
|
|
53
|
-
recipient: "0x456",
|
|
54
|
-
amount: BigInt("0"),
|
|
55
|
-
type: "send",
|
|
56
|
-
asset: { type: "native" },
|
|
57
|
-
};
|
|
58
|
-
const result = await (0, estimateFees_1.estimateFees)(transactionIntent);
|
|
59
|
-
expect(network_1.default.paymentInfo).toHaveBeenCalledWith(transactionIntent.sender, {
|
|
60
|
-
recipient: transactionIntent.recipient,
|
|
61
|
-
amount: (0, bignumber_js_1.BigNumber)("0"),
|
|
62
|
-
coinType: "0x2::sui::SUI",
|
|
63
|
-
errors: {},
|
|
64
|
-
family: "sui",
|
|
65
|
-
mode: "send",
|
|
66
|
-
});
|
|
67
|
-
expect(result).toBe(BigInt(mockGasBudget));
|
|
68
|
-
});
|
|
69
|
-
});
|
|
70
|
-
//# sourceMappingURL=estimateFees.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"estimateFees.test.js","sourceRoot":"","sources":["../../src/logic/estimateFees.test.ts"],"names":[],"mappings":";;;;;AAAA,iDAA8C;AAC9C,yDAAgC;AAChC,+CAAyC;AAEzC,yBAAyB;AACzB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,GAAG,EAAE,CAAC,CAAC;IAC7B,UAAU,EAAE,IAAI;IAChB,OAAO,EAAE;QACP,WAAW,EAAE,IAAI,CAAC,EAAE,EAAE;KACvB;CACF,CAAC,CAAC,CAAC;AAEJ,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,UAAU,CAAC,GAAG,EAAE;QACd,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gDAAgD,EAAE,KAAK,IAAI,EAAE;QAC9D,gCAAgC;QAChC,MAAM,aAAa,GAAG,SAAS,CAAC;QAC/B,iBAAM,CAAC,WAAyB,CAAC,iBAAiB,CAAC;YAClD,SAAS,EAAE,aAAa;SACzB,CAAC,CAAC;QAEH,MAAM,iBAAiB,GAAG;YACxB,UAAU,EAAE,aAAsB;YAClC,MAAM,EAAE,OAAO;YACf,SAAS,EAAE,OAAO;YAClB,MAAM,EAAE,MAAM,CAAC,YAAY,CAAC;YAC5B,IAAI,EAAE,MAAM;YACZ,KAAK,EAAE,EAAE,IAAI,EAAE,QAAiB,EAAE;SACnC,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,IAAA,2BAAY,EAAC,iBAAiB,CAAC,CAAC;QAErD,MAAM,CAAC,iBAAM,CAAC,WAAW,CAAC,CAAC,oBAAoB,CAAC,iBAAiB,CAAC,MAAM,EAAE;YACxE,SAAS,EAAE,iBAAiB,CAAC,SAAS;YACtC,MAAM,EAAE,IAAA,wBAAS,EAAC,iBAAiB,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;YACtD,QAAQ,EAAE,eAAe;YACzB,MAAM,EAAE,EAAE;YACV,MAAM,EAAE,KAAK;YACb,IAAI,EAAE,MAAM;SACb,CAAC,CAAC;QACH,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wCAAwC,EAAE,KAAK,IAAI,EAAE;QACtD,MAAM,aAAa,GAAG,QAAQ,CAAC;QAC9B,iBAAM,CAAC,WAAyB,CAAC,iBAAiB,CAAC;YAClD,SAAS,EAAE,aAAa;SACzB,CAAC,CAAC;QAEH,MAAM,iBAAiB,GAAG;YACxB,UAAU,EAAE,aAAsB;YAClC,MAAM,EAAE,OAAO;YACf,SAAS,EAAE,OAAO;YAClB,MAAM,EAAE,MAAM,CAAC,GAAG,CAAC;YACnB,IAAI,EAAE,MAAM;YACZ,KAAK,EAAE,EAAE,IAAI,EAAE,QAAiB,EAAE;SACnC,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,IAAA,2BAAY,EAAC,iBAAiB,CAAC,CAAC;QAErD,MAAM,CAAC,iBAAM,CAAC,WAAW,CAAC,CAAC,oBAAoB,CAAC,iBAAiB,CAAC,MAAM,EAAE;YACxE,SAAS,EAAE,iBAAiB,CAAC,SAAS;YACtC,MAAM,EAAE,IAAA,wBAAS,EAAC,GAAG,CAAC;YACtB,QAAQ,EAAE,eAAe;YACzB,MAAM,EAAE,EAAE;YACV,MAAM,EAAE,KAAK;YACb,IAAI,EAAE,MAAM;SACb,CAAC,CAAC;QACH,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"getBalance.integration.test.d.ts","sourceRoot":"","sources":["../../src/logic/getBalance.integration.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,56 +0,0 @@
|
|
|
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 client_1 = require("@mysten/sui/client");
|
|
7
|
-
const config_1 = __importDefault(require("../config"));
|
|
8
|
-
const getBalance_1 = require("./getBalance");
|
|
9
|
-
const SENDER = "0x33444cf803c690db96527cec67e3c9ab512596f4ba2d4eace43f0b4f716e0164";
|
|
10
|
-
describe("getBalance", () => {
|
|
11
|
-
beforeAll(() => {
|
|
12
|
-
config_1.default.setCoinConfig(() => ({
|
|
13
|
-
status: {
|
|
14
|
-
type: "active",
|
|
15
|
-
},
|
|
16
|
-
node: {
|
|
17
|
-
url: (0, client_1.getFullnodeUrl)("testnet"),
|
|
18
|
-
},
|
|
19
|
-
}));
|
|
20
|
-
});
|
|
21
|
-
it("should fetch native SUI balance", async () => {
|
|
22
|
-
const balances = await (0, getBalance_1.getBalance)(SENDER);
|
|
23
|
-
expect(balances.length).toBeGreaterThanOrEqual(1);
|
|
24
|
-
expect(balances[0]).toMatchObject({
|
|
25
|
-
asset: { type: "native" },
|
|
26
|
-
});
|
|
27
|
-
expect(typeof balances[0].value).toBe("bigint");
|
|
28
|
-
expect(balances[0].value).toBeGreaterThanOrEqual(0n);
|
|
29
|
-
}, 10000);
|
|
30
|
-
it("should fetch token balances", async () => {
|
|
31
|
-
const balances = await (0, getBalance_1.getBalance)(SENDER);
|
|
32
|
-
expect(balances.length).toBeGreaterThanOrEqual(1);
|
|
33
|
-
const tokenBalances = balances.filter(balance => balance.asset.type === "token");
|
|
34
|
-
tokenBalances.forEach(balance => {
|
|
35
|
-
expect(balance.asset.type).toBe("token");
|
|
36
|
-
if (balance.asset.type === "token") {
|
|
37
|
-
expect(balance.asset.assetReference).toMatch(/^0x[a-fA-F0-9]+::[a-zA-Z0-9_]+::[a-zA-Z0-9_]+$/);
|
|
38
|
-
}
|
|
39
|
-
expect(typeof balance.value).toBe("bigint");
|
|
40
|
-
expect(balance.value).toBeGreaterThanOrEqual(0n);
|
|
41
|
-
});
|
|
42
|
-
}, 15000);
|
|
43
|
-
it("should properly parse token asset reference", async () => {
|
|
44
|
-
const balances = await (0, getBalance_1.getBalance)(SENDER);
|
|
45
|
-
const usdTokens = balances.filter(balance => balance.asset.type === "token" &&
|
|
46
|
-
balance.asset.assetReference?.toLowerCase().includes("usd"));
|
|
47
|
-
usdTokens.forEach(balance => {
|
|
48
|
-
expect(balance.asset.type).toBe("token");
|
|
49
|
-
if (balance.asset.type === "token") {
|
|
50
|
-
expect(balance.asset.assetReference).toBeTruthy();
|
|
51
|
-
}
|
|
52
|
-
expect(typeof balance.value).toBe("bigint");
|
|
53
|
-
});
|
|
54
|
-
}, 15000);
|
|
55
|
-
});
|
|
56
|
-
//# sourceMappingURL=getBalance.integration.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"getBalance.integration.test.js","sourceRoot":"","sources":["../../src/logic/getBalance.integration.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"getBalance.test.d.ts","sourceRoot":"","sources":["../../src/logic/getBalance.test.ts"],"names":[],"mappings":""}
|