@ledgerhq/coin-ton 0.3.12-next.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/.eslintrc.js +20 -0
- package/.turbo/turbo-build.log +4 -0
- package/.unimportedrc.json +19 -0
- package/CHANGELOG.md +15 -0
- package/LICENSE.txt +21 -0
- package/jest.config.js +12 -0
- package/lib/__tests__/fixtures/api.fixtures.d.ts +4 -0
- package/lib/__tests__/fixtures/api.fixtures.d.ts.map +1 -0
- package/lib/__tests__/fixtures/api.fixtures.js +33 -0
- package/lib/__tests__/fixtures/api.fixtures.js.map +1 -0
- package/lib/__tests__/fixtures/common.fixtures.d.ts +29 -0
- package/lib/__tests__/fixtures/common.fixtures.d.ts.map +1 -0
- package/lib/__tests__/fixtures/common.fixtures.js +124 -0
- package/lib/__tests__/fixtures/common.fixtures.js.map +1 -0
- package/lib/__tests__/integration/bridge.integration.test.d.ts +14 -0
- package/lib/__tests__/integration/bridge.integration.test.d.ts.map +1 -0
- package/lib/__tests__/integration/bridge.integration.test.js +136 -0
- package/lib/__tests__/integration/bridge.integration.test.js.map +1 -0
- package/lib/__tests__/unit/api.unit.test.d.ts +2 -0
- package/lib/__tests__/unit/api.unit.test.d.ts.map +1 -0
- package/lib/__tests__/unit/api.unit.test.js +77 -0
- package/lib/__tests__/unit/api.unit.test.js.map +1 -0
- package/lib/__tests__/unit/broadcast.unit.test.d.ts +2 -0
- package/lib/__tests__/unit/broadcast.unit.test.d.ts.map +1 -0
- package/lib/__tests__/unit/broadcast.unit.test.js +40 -0
- package/lib/__tests__/unit/broadcast.unit.test.js.map +1 -0
- package/lib/__tests__/unit/createTransaction.unit.test.d.ts +2 -0
- package/lib/__tests__/unit/createTransaction.unit.test.d.ts.map +1 -0
- package/lib/__tests__/unit/createTransaction.unit.test.js +34 -0
- package/lib/__tests__/unit/createTransaction.unit.test.js.map +1 -0
- package/lib/__tests__/unit/deviceTransactionConfig.unit.test.d.ts +2 -0
- package/lib/__tests__/unit/deviceTransactionConfig.unit.test.d.ts.map +1 -0
- package/lib/__tests__/unit/deviceTransactionConfig.unit.test.js +74 -0
- package/lib/__tests__/unit/deviceTransactionConfig.unit.test.js.map +1 -0
- package/lib/__tests__/unit/estimateMaxSpendable.unit.test.d.ts +2 -0
- package/lib/__tests__/unit/estimateMaxSpendable.unit.test.d.ts.map +1 -0
- package/lib/__tests__/unit/estimateMaxSpendable.unit.test.js +31 -0
- package/lib/__tests__/unit/estimateMaxSpendable.unit.test.js.map +1 -0
- package/lib/__tests__/unit/getTransactionStatus.unit.test.d.ts +2 -0
- package/lib/__tests__/unit/getTransactionStatus.unit.test.d.ts.map +1 -0
- package/lib/__tests__/unit/getTransactionStatus.unit.test.js +96 -0
- package/lib/__tests__/unit/getTransactionStatus.unit.test.js.map +1 -0
- package/lib/__tests__/unit/hw-getAddress.unit.test.d.ts +2 -0
- package/lib/__tests__/unit/hw-getAddress.unit.test.d.ts.map +1 -0
- package/lib/__tests__/unit/hw-getAddress.unit.test.js +67 -0
- package/lib/__tests__/unit/hw-getAddress.unit.test.js.map +1 -0
- package/lib/__tests__/unit/prepareTransaction.unit.test.d.ts +2 -0
- package/lib/__tests__/unit/prepareTransaction.unit.test.d.ts.map +1 -0
- package/lib/__tests__/unit/prepareTransaction.unit.test.js +42 -0
- package/lib/__tests__/unit/prepareTransaction.unit.test.js.map +1 -0
- package/lib/__tests__/unit/signOperation.unit.test.d.ts +2 -0
- package/lib/__tests__/unit/signOperation.unit.test.d.ts.map +1 -0
- package/lib/__tests__/unit/signOperation.unit.test.js +83 -0
- package/lib/__tests__/unit/signOperation.unit.test.js.map +1 -0
- package/lib/__tests__/unit/txn.unit.test.d.ts +2 -0
- package/lib/__tests__/unit/txn.unit.test.d.ts.map +1 -0
- package/lib/__tests__/unit/txn.unit.test.js +116 -0
- package/lib/__tests__/unit/txn.unit.test.js.map +1 -0
- package/lib/__tests__/unit/utils.unit.test.d.ts +2 -0
- package/lib/__tests__/unit/utils.unit.test.d.ts.map +1 -0
- package/lib/__tests__/unit/utils.unit.test.js +97 -0
- package/lib/__tests__/unit/utils.unit.test.js.map +1 -0
- package/lib/bridge/bridgeHelpers/api.d.ts +10 -0
- package/lib/bridge/bridgeHelpers/api.d.ts.map +1 -0
- package/lib/bridge/bridgeHelpers/api.js +104 -0
- package/lib/bridge/bridgeHelpers/api.js.map +1 -0
- package/lib/bridge/bridgeHelpers/api.types.d.ts +164 -0
- package/lib/bridge/bridgeHelpers/api.types.d.ts.map +1 -0
- package/lib/bridge/bridgeHelpers/api.types.js +3 -0
- package/lib/bridge/bridgeHelpers/api.types.js.map +1 -0
- package/lib/bridge/bridgeHelpers/txn.d.ts +5 -0
- package/lib/bridge/bridgeHelpers/txn.d.ts.map +1 -0
- package/lib/bridge/bridgeHelpers/txn.js +166 -0
- package/lib/bridge/bridgeHelpers/txn.js.map +1 -0
- package/lib/bridge/js.d.ts +12 -0
- package/lib/bridge/js.d.ts.map +1 -0
- package/lib/bridge/js.js +65 -0
- package/lib/bridge/js.js.map +1 -0
- package/lib/broadcast.d.ts +5 -0
- package/lib/broadcast.d.ts.map +1 -0
- package/lib/broadcast.js +19 -0
- package/lib/broadcast.js.map +1 -0
- package/lib/cli-transaction.d.ts +12 -0
- package/lib/cli-transaction.d.ts.map +1 -0
- package/lib/cli-transaction.js +21 -0
- package/lib/cli-transaction.js.map +1 -0
- package/lib/config.d.ts +9 -0
- package/lib/config.d.ts.map +1 -0
- package/lib/config.js +16 -0
- package/lib/config.js.map +1 -0
- package/lib/createTransaction.d.ts +5 -0
- package/lib/createTransaction.d.ts.map +1 -0
- package/lib/createTransaction.js +16 -0
- package/lib/createTransaction.js.map +1 -0
- package/lib/deviceTransactionConfig.d.ts +11 -0
- package/lib/deviceTransactionConfig.d.ts.map +1 -0
- package/lib/deviceTransactionConfig.js +37 -0
- package/lib/deviceTransactionConfig.js.map +1 -0
- package/lib/errors.d.ts +4 -0
- package/lib/errors.d.ts.map +1 -0
- package/lib/errors.js +9 -0
- package/lib/errors.js.map +1 -0
- package/lib/estimateMaxSpendable.d.ts +5 -0
- package/lib/estimateMaxSpendable.d.ts.map +1 -0
- package/lib/estimateMaxSpendable.js +32 -0
- package/lib/estimateMaxSpendable.js.map +1 -0
- package/lib/getTransactionStatus.d.ts +5 -0
- package/lib/getTransactionStatus.d.ts.map +1 -0
- package/lib/getTransactionStatus.js +97 -0
- package/lib/getTransactionStatus.js.map +1 -0
- package/lib/hw-getAddress.d.ts +6 -0
- package/lib/hw-getAddress.d.ts.map +1 -0
- package/lib/hw-getAddress.js +31 -0
- package/lib/hw-getAddress.js.map +1 -0
- package/lib/hw-signMessage.d.ts +12 -0
- package/lib/hw-signMessage.d.ts.map +1 -0
- package/lib/hw-signMessage.js +33 -0
- package/lib/hw-signMessage.js.map +1 -0
- package/lib/prepareTransaction.d.ts +5 -0
- package/lib/prepareTransaction.d.ts.map +1 -0
- package/lib/prepareTransaction.js +29 -0
- package/lib/prepareTransaction.js.map +1 -0
- package/lib/signOperation.d.ts +11 -0
- package/lib/signOperation.d.ts.map +1 -0
- package/lib/signOperation.js +96 -0
- package/lib/signOperation.js.map +1 -0
- package/lib/signer.d.ts +27 -0
- package/lib/signer.d.ts.map +1 -0
- package/lib/signer.js +3 -0
- package/lib/signer.js.map +1 -0
- package/lib/specs.d.ts +8 -0
- package/lib/specs.d.ts.map +1 -0
- package/lib/specs.js +106 -0
- package/lib/specs.js.map +1 -0
- package/lib/speculos-deviceActions.d.ts +4 -0
- package/lib/speculos-deviceActions.d.ts.map +1 -0
- package/lib/speculos-deviceActions.js +34 -0
- package/lib/speculos-deviceActions.js.map +1 -0
- package/lib/synchronisation.d.ts +5 -0
- package/lib/synchronisation.d.ts.map +1 -0
- package/lib/synchronisation.js +95 -0
- package/lib/synchronisation.js.map +1 -0
- package/lib/transaction.d.ts +14 -0
- package/lib/transaction.d.ts.map +1 -0
- package/lib/transaction.js +41 -0
- package/lib/transaction.js.map +1 -0
- package/lib/types.d.ts +65 -0
- package/lib/types.d.ts.map +1 -0
- package/lib/types.js +3 -0
- package/lib/types.js.map +1 -0
- package/lib/utils.d.ts +11 -0
- package/lib/utils.d.ts.map +1 -0
- package/lib/utils.js +125 -0
- package/lib/utils.js.map +1 -0
- package/lib-es/__tests__/fixtures/api.fixtures.d.ts +4 -0
- package/lib-es/__tests__/fixtures/api.fixtures.d.ts.map +1 -0
- package/lib-es/__tests__/fixtures/api.fixtures.js +30 -0
- package/lib-es/__tests__/fixtures/api.fixtures.js.map +1 -0
- package/lib-es/__tests__/fixtures/common.fixtures.d.ts +29 -0
- package/lib-es/__tests__/fixtures/common.fixtures.d.ts.map +1 -0
- package/lib-es/__tests__/fixtures/common.fixtures.js +118 -0
- package/lib-es/__tests__/fixtures/common.fixtures.js.map +1 -0
- package/lib-es/__tests__/integration/bridge.integration.test.d.ts +14 -0
- package/lib-es/__tests__/integration/bridge.integration.test.d.ts.map +1 -0
- package/lib-es/__tests__/integration/bridge.integration.test.js +130 -0
- package/lib-es/__tests__/integration/bridge.integration.test.js.map +1 -0
- package/lib-es/__tests__/unit/api.unit.test.d.ts +2 -0
- package/lib-es/__tests__/unit/api.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/unit/api.unit.test.js +52 -0
- package/lib-es/__tests__/unit/api.unit.test.js.map +1 -0
- package/lib-es/__tests__/unit/broadcast.unit.test.d.ts +2 -0
- package/lib-es/__tests__/unit/broadcast.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/unit/broadcast.unit.test.js +35 -0
- package/lib-es/__tests__/unit/broadcast.unit.test.js.map +1 -0
- package/lib-es/__tests__/unit/createTransaction.unit.test.d.ts +2 -0
- package/lib-es/__tests__/unit/createTransaction.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/unit/createTransaction.unit.test.js +29 -0
- package/lib-es/__tests__/unit/createTransaction.unit.test.js.map +1 -0
- package/lib-es/__tests__/unit/deviceTransactionConfig.unit.test.d.ts +2 -0
- package/lib-es/__tests__/unit/deviceTransactionConfig.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/unit/deviceTransactionConfig.unit.test.js +69 -0
- package/lib-es/__tests__/unit/deviceTransactionConfig.unit.test.js.map +1 -0
- package/lib-es/__tests__/unit/estimateMaxSpendable.unit.test.d.ts +2 -0
- package/lib-es/__tests__/unit/estimateMaxSpendable.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/unit/estimateMaxSpendable.unit.test.js +26 -0
- package/lib-es/__tests__/unit/estimateMaxSpendable.unit.test.js.map +1 -0
- package/lib-es/__tests__/unit/getTransactionStatus.unit.test.d.ts +2 -0
- package/lib-es/__tests__/unit/getTransactionStatus.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/unit/getTransactionStatus.unit.test.js +91 -0
- package/lib-es/__tests__/unit/getTransactionStatus.unit.test.js.map +1 -0
- package/lib-es/__tests__/unit/hw-getAddress.unit.test.d.ts +2 -0
- package/lib-es/__tests__/unit/hw-getAddress.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/unit/hw-getAddress.unit.test.js +62 -0
- package/lib-es/__tests__/unit/hw-getAddress.unit.test.js.map +1 -0
- package/lib-es/__tests__/unit/prepareTransaction.unit.test.d.ts +2 -0
- package/lib-es/__tests__/unit/prepareTransaction.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/unit/prepareTransaction.unit.test.js +37 -0
- package/lib-es/__tests__/unit/prepareTransaction.unit.test.js.map +1 -0
- package/lib-es/__tests__/unit/signOperation.unit.test.d.ts +2 -0
- package/lib-es/__tests__/unit/signOperation.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/unit/signOperation.unit.test.js +78 -0
- package/lib-es/__tests__/unit/signOperation.unit.test.js.map +1 -0
- package/lib-es/__tests__/unit/txn.unit.test.d.ts +2 -0
- package/lib-es/__tests__/unit/txn.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/unit/txn.unit.test.js +111 -0
- package/lib-es/__tests__/unit/txn.unit.test.js.map +1 -0
- package/lib-es/__tests__/unit/utils.unit.test.d.ts +2 -0
- package/lib-es/__tests__/unit/utils.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/unit/utils.unit.test.js +95 -0
- package/lib-es/__tests__/unit/utils.unit.test.js.map +1 -0
- package/lib-es/bridge/bridgeHelpers/api.d.ts +10 -0
- package/lib-es/bridge/bridgeHelpers/api.d.ts.map +1 -0
- package/lib-es/bridge/bridgeHelpers/api.js +93 -0
- package/lib-es/bridge/bridgeHelpers/api.js.map +1 -0
- package/lib-es/bridge/bridgeHelpers/api.types.d.ts +164 -0
- package/lib-es/bridge/bridgeHelpers/api.types.d.ts.map +1 -0
- package/lib-es/bridge/bridgeHelpers/api.types.js +2 -0
- package/lib-es/bridge/bridgeHelpers/api.types.js.map +1 -0
- package/lib-es/bridge/bridgeHelpers/txn.d.ts +5 -0
- package/lib-es/bridge/bridgeHelpers/txn.d.ts.map +1 -0
- package/lib-es/bridge/bridgeHelpers/txn.js +158 -0
- package/lib-es/bridge/bridgeHelpers/txn.js.map +1 -0
- package/lib-es/bridge/js.d.ts +12 -0
- package/lib-es/bridge/js.d.ts.map +1 -0
- package/lib-es/bridge/js.js +56 -0
- package/lib-es/bridge/js.js.map +1 -0
- package/lib-es/broadcast.d.ts +5 -0
- package/lib-es/broadcast.d.ts.map +1 -0
- package/lib-es/broadcast.js +17 -0
- package/lib-es/broadcast.js.map +1 -0
- package/lib-es/cli-transaction.d.ts +12 -0
- package/lib-es/cli-transaction.d.ts.map +1 -0
- package/lib-es/cli-transaction.js +15 -0
- package/lib-es/cli-transaction.js.map +1 -0
- package/lib-es/config.d.ts +9 -0
- package/lib-es/config.d.ts.map +1 -0
- package/lib-es/config.js +11 -0
- package/lib-es/config.js.map +1 -0
- package/lib-es/createTransaction.d.ts +5 -0
- package/lib-es/createTransaction.d.ts.map +1 -0
- package/lib-es/createTransaction.js +14 -0
- package/lib-es/createTransaction.js.map +1 -0
- package/lib-es/deviceTransactionConfig.d.ts +11 -0
- package/lib-es/deviceTransactionConfig.d.ts.map +1 -0
- package/lib-es/deviceTransactionConfig.js +35 -0
- package/lib-es/deviceTransactionConfig.js.map +1 -0
- package/lib-es/errors.d.ts +4 -0
- package/lib-es/errors.d.ts.map +1 -0
- package/lib-es/errors.js +6 -0
- package/lib-es/errors.js.map +1 -0
- package/lib-es/estimateMaxSpendable.d.ts +5 -0
- package/lib-es/estimateMaxSpendable.d.ts.map +1 -0
- package/lib-es/estimateMaxSpendable.js +30 -0
- package/lib-es/estimateMaxSpendable.js.map +1 -0
- package/lib-es/getTransactionStatus.d.ts +5 -0
- package/lib-es/getTransactionStatus.d.ts.map +1 -0
- package/lib-es/getTransactionStatus.js +93 -0
- package/lib-es/getTransactionStatus.js.map +1 -0
- package/lib-es/hw-getAddress.d.ts +6 -0
- package/lib-es/hw-getAddress.d.ts.map +1 -0
- package/lib-es/hw-getAddress.js +29 -0
- package/lib-es/hw-getAddress.js.map +1 -0
- package/lib-es/hw-signMessage.d.ts +12 -0
- package/lib-es/hw-signMessage.d.ts.map +1 -0
- package/lib-es/hw-signMessage.js +29 -0
- package/lib-es/hw-signMessage.js.map +1 -0
- package/lib-es/prepareTransaction.d.ts +5 -0
- package/lib-es/prepareTransaction.d.ts.map +1 -0
- package/lib-es/prepareTransaction.js +27 -0
- package/lib-es/prepareTransaction.js.map +1 -0
- package/lib-es/signOperation.d.ts +11 -0
- package/lib-es/signOperation.d.ts.map +1 -0
- package/lib-es/signOperation.js +91 -0
- package/lib-es/signOperation.js.map +1 -0
- package/lib-es/signer.d.ts +27 -0
- package/lib-es/signer.d.ts.map +1 -0
- package/lib-es/signer.js +2 -0
- package/lib-es/signer.js.map +1 -0
- package/lib-es/specs.d.ts +8 -0
- package/lib-es/specs.d.ts.map +1 -0
- package/lib-es/specs.js +99 -0
- package/lib-es/specs.js.map +1 -0
- package/lib-es/speculos-deviceActions.d.ts +4 -0
- package/lib-es/speculos-deviceActions.d.ts.map +1 -0
- package/lib-es/speculos-deviceActions.js +31 -0
- package/lib-es/speculos-deviceActions.js.map +1 -0
- package/lib-es/synchronisation.d.ts +5 -0
- package/lib-es/synchronisation.d.ts.map +1 -0
- package/lib-es/synchronisation.js +88 -0
- package/lib-es/synchronisation.js.map +1 -0
- package/lib-es/transaction.d.ts +14 -0
- package/lib-es/transaction.d.ts.map +1 -0
- package/lib-es/transaction.js +33 -0
- package/lib-es/transaction.js.map +1 -0
- package/lib-es/types.d.ts +65 -0
- package/lib-es/types.d.ts.map +1 -0
- package/lib-es/types.js +2 -0
- package/lib-es/types.js.map +1 -0
- package/lib-es/utils.d.ts +11 -0
- package/lib-es/utils.d.ts.map +1 -0
- package/lib-es/utils.js +112 -0
- package/lib-es/utils.js.map +1 -0
- package/package.json +86 -0
- package/src/__tests__/fixtures/api.fixtures.ts +39 -0
- package/src/__tests__/fixtures/common.fixtures.ts +139 -0
- package/src/__tests__/integration/bridge.integration.test.ts +135 -0
- package/src/__tests__/unit/api.unit.test.ts +60 -0
- package/src/__tests__/unit/broadcast.unit.test.ts +36 -0
- package/src/__tests__/unit/createTransaction.unit.test.ts +20 -0
- package/src/__tests__/unit/deviceTransactionConfig.unit.test.ts +69 -0
- package/src/__tests__/unit/estimateMaxSpendable.unit.test.ts +19 -0
- package/src/__tests__/unit/getTransactionStatus.unit.test.ts +119 -0
- package/src/__tests__/unit/hw-getAddress.unit.test.ts +58 -0
- package/src/__tests__/unit/prepareTransaction.unit.test.ts +52 -0
- package/src/__tests__/unit/signOperation.unit.test.ts +90 -0
- package/src/__tests__/unit/txn.unit.test.ts +121 -0
- package/src/__tests__/unit/utils.unit.test.ts +126 -0
- package/src/bridge/bridgeHelpers/api.ts +104 -0
- package/src/bridge/bridgeHelpers/api.types.ts +178 -0
- package/src/bridge/bridgeHelpers/txn.ts +166 -0
- package/src/bridge/js.ts +65 -0
- package/src/broadcast.ts +13 -0
- package/src/cli-transaction.ts +30 -0
- package/src/config.ts +21 -0
- package/src/createTransaction.ts +17 -0
- package/src/deviceTransactionConfig.ts +48 -0
- package/src/errors.ts +6 -0
- package/src/estimateMaxSpendable.ts +40 -0
- package/src/getTransactionStatus.ts +130 -0
- package/src/hw-getAddress.ts +28 -0
- package/src/hw-signMessage.ts +31 -0
- package/src/prepareTransaction.ts +27 -0
- package/src/signOperation.ts +115 -0
- package/src/signer.ts +32 -0
- package/src/specs.ts +122 -0
- package/src/speculos-deviceActions.ts +38 -0
- package/src/synchronisation.ts +91 -0
- package/src/transaction.ts +61 -0
- package/src/types.ts +82 -0
- package/src/utils.ts +120 -0
- package/tsconfig.json +12 -0
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
16
|
+
const createTransaction_1 = __importDefault(require("../../createTransaction"));
|
|
17
|
+
const common_fixtures_1 = require("../fixtures/common.fixtures");
|
|
18
|
+
describe("createTransaction", () => {
|
|
19
|
+
it("should create a valid transaction", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
20
|
+
const res = (0, createTransaction_1.default)(common_fixtures_1.account);
|
|
21
|
+
expect(res).toEqual({
|
|
22
|
+
family: "ton",
|
|
23
|
+
amount: new bignumber_js_1.default(0),
|
|
24
|
+
fees: new bignumber_js_1.default(0),
|
|
25
|
+
recipient: "",
|
|
26
|
+
useAllAmount: false,
|
|
27
|
+
comment: {
|
|
28
|
+
isEncrypted: false,
|
|
29
|
+
text: "",
|
|
30
|
+
},
|
|
31
|
+
});
|
|
32
|
+
}));
|
|
33
|
+
});
|
|
34
|
+
//# sourceMappingURL=createTransaction.unit.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createTransaction.unit.test.js","sourceRoot":"","sources":["../../../src/__tests__/unit/createTransaction.unit.test.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAAA,gEAAqC;AACrC,gFAAwD;AACxD,iEAAsD;AAEtD,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;IACjC,EAAE,CAAC,mCAAmC,EAAE,GAAS,EAAE;QACjD,MAAM,GAAG,GAAG,IAAA,2BAAiB,EAAC,yBAAO,CAAC,CAAC;QACvC,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC;YAClB,MAAM,EAAE,KAAK;YACb,MAAM,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC;YACxB,IAAI,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC;YACtB,SAAS,EAAE,EAAE;YACb,YAAY,EAAE,KAAK;YACnB,OAAO,EAAE;gBACP,WAAW,EAAE,KAAK;gBAClB,IAAI,EAAE,EAAE;aACT;SACF,CAAC,CAAC;IACL,CAAC,CAAA,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deviceTransactionConfig.unit.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/unit/deviceTransactionConfig.unit.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
16
|
+
const deviceTransactionConfig_1 = __importDefault(require("../../deviceTransactionConfig"));
|
|
17
|
+
const common_fixtures_1 = require("../fixtures/common.fixtures");
|
|
18
|
+
const status = {
|
|
19
|
+
errors: {},
|
|
20
|
+
warnings: {},
|
|
21
|
+
estimatedFees: new bignumber_js_1.default(0),
|
|
22
|
+
amount: new bignumber_js_1.default(0),
|
|
23
|
+
totalSpent: new bignumber_js_1.default(0),
|
|
24
|
+
};
|
|
25
|
+
describe("deviceTransactionConfig", () => {
|
|
26
|
+
describe("TON transaction", () => {
|
|
27
|
+
it("should return the fields for a transaction when there is a valid comment", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
28
|
+
const transaction = Object.assign(Object.assign({}, common_fixtures_1.transaction), { comment: { isEncrypted: false, text: "validComment" } });
|
|
29
|
+
const res = yield (0, deviceTransactionConfig_1.default)({
|
|
30
|
+
account: common_fixtures_1.account,
|
|
31
|
+
parentAccount: undefined,
|
|
32
|
+
transaction,
|
|
33
|
+
status,
|
|
34
|
+
});
|
|
35
|
+
expect(res).toEqual([
|
|
36
|
+
{
|
|
37
|
+
type: "address",
|
|
38
|
+
label: "To",
|
|
39
|
+
address: transaction.recipient,
|
|
40
|
+
},
|
|
41
|
+
{
|
|
42
|
+
type: "amount",
|
|
43
|
+
label: "Amount",
|
|
44
|
+
},
|
|
45
|
+
{ type: "fees", label: "Fee" },
|
|
46
|
+
{ type: "text", label: "Comment", value: "validComment" },
|
|
47
|
+
]);
|
|
48
|
+
}));
|
|
49
|
+
it("should return the fields for a transaction when useAllAmount is true and there is a valid comment", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
50
|
+
const transaction = Object.assign(Object.assign({}, common_fixtures_1.transaction), { useAllAmount: true, comment: { isEncrypted: false, text: "validComment" } });
|
|
51
|
+
const res = yield (0, deviceTransactionConfig_1.default)({
|
|
52
|
+
account: common_fixtures_1.account,
|
|
53
|
+
parentAccount: undefined,
|
|
54
|
+
transaction,
|
|
55
|
+
status,
|
|
56
|
+
});
|
|
57
|
+
expect(res).toEqual([
|
|
58
|
+
{
|
|
59
|
+
type: "address",
|
|
60
|
+
label: "To",
|
|
61
|
+
address: transaction.recipient,
|
|
62
|
+
},
|
|
63
|
+
{
|
|
64
|
+
type: "text",
|
|
65
|
+
label: "Amount",
|
|
66
|
+
value: "ALL YOUR TONs",
|
|
67
|
+
},
|
|
68
|
+
{ type: "fees", label: "Fee" },
|
|
69
|
+
{ type: "text", label: "Comment", value: "validComment" },
|
|
70
|
+
]);
|
|
71
|
+
}));
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
//# sourceMappingURL=deviceTransactionConfig.unit.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deviceTransactionConfig.unit.test.js","sourceRoot":"","sources":["../../../src/__tests__/unit/deviceTransactionConfig.unit.test.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAAA,gEAAqC;AACrC,4FAAuE;AACvE,iEAAsF;AAEtF,MAAM,MAAM,GAAG;IACb,MAAM,EAAE,EAAE;IACV,QAAQ,EAAE,EAAE;IACZ,aAAa,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC;IAC/B,MAAM,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC;IACxB,UAAU,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC;CAC7B,CAAC;AAEF,QAAQ,CAAC,yBAAyB,EAAE,GAAG,EAAE;IACvC,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;QAC/B,EAAE,CAAC,0EAA0E,EAAE,GAAS,EAAE;YACxF,MAAM,WAAW,mCACZ,6BAAe,KAClB,OAAO,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,IAAI,EAAE,cAAc,EAAE,GACtD,CAAC;YACF,MAAM,GAAG,GAAG,MAAM,IAAA,iCAA0B,EAAC;gBAC3C,OAAO,EAAE,yBAAO;gBAChB,aAAa,EAAE,SAAS;gBACxB,WAAW;gBACX,MAAM;aACP,CAAC,CAAC;YACH,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC;gBAClB;oBACE,IAAI,EAAE,SAAS;oBACf,KAAK,EAAE,IAAI;oBACX,OAAO,EAAE,WAAW,CAAC,SAAS;iBAC/B;gBACD;oBACE,IAAI,EAAE,QAAQ;oBACd,KAAK,EAAE,QAAQ;iBAChB;gBACD,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE;gBAC9B,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,cAAc,EAAE;aAC1D,CAAC,CAAC;QACL,CAAC,CAAA,CAAC,CAAC;QAEH,EAAE,CAAC,mGAAmG,EAAE,GAAS,EAAE;YACjH,MAAM,WAAW,mCACZ,6BAAe,KAClB,YAAY,EAAE,IAAI,EAClB,OAAO,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,IAAI,EAAE,cAAc,EAAE,GACtD,CAAC;YACF,MAAM,GAAG,GAAG,MAAM,IAAA,iCAA0B,EAAC;gBAC3C,OAAO,EAAE,yBAAO;gBAChB,aAAa,EAAE,SAAS;gBACxB,WAAW;gBACX,MAAM;aACP,CAAC,CAAC;YACH,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC;gBAClB;oBACE,IAAI,EAAE,SAAS;oBACf,KAAK,EAAE,IAAI;oBACX,OAAO,EAAE,WAAW,CAAC,SAAS;iBAC/B;gBACD;oBACE,IAAI,EAAE,MAAM;oBACZ,KAAK,EAAE,QAAQ;oBACf,KAAK,EAAE,eAAe;iBACvB;gBACD,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE;gBAC9B,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,cAAc,EAAE;aAC1D,CAAC,CAAC;QACL,CAAC,CAAA,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"estimateMaxSpendable.unit.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/unit/estimateMaxSpendable.unit.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
const api_1 = require("../../bridge/bridgeHelpers/api");
|
|
16
|
+
const estimateMaxSpendable_1 = __importDefault(require("../../estimateMaxSpendable"));
|
|
17
|
+
const common_fixtures_1 = require("../fixtures/common.fixtures");
|
|
18
|
+
jest.mock("../../bridge/bridgeHelpers/api");
|
|
19
|
+
describe("estimateMaxSpendable", () => {
|
|
20
|
+
beforeAll(() => {
|
|
21
|
+
const fetchAccountInfoMock = jest.mocked(api_1.fetchAccountInfo);
|
|
22
|
+
fetchAccountInfoMock.mockReturnValue(Promise.resolve(common_fixtures_1.accountInfo));
|
|
23
|
+
const fetchEstimateFeeMock = jest.mocked(api_1.estimateFee);
|
|
24
|
+
fetchEstimateFeeMock.mockReturnValue(Promise.resolve(common_fixtures_1.fees));
|
|
25
|
+
});
|
|
26
|
+
it("should return the max spendable for a TON transaction", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
27
|
+
const res = yield (0, estimateMaxSpendable_1.default)({ account: common_fixtures_1.account, transaction: common_fixtures_1.transaction });
|
|
28
|
+
expect(res).toEqual(common_fixtures_1.account.balance.minus(common_fixtures_1.totalFees));
|
|
29
|
+
}));
|
|
30
|
+
});
|
|
31
|
+
//# sourceMappingURL=estimateMaxSpendable.unit.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"estimateMaxSpendable.unit.test.js","sourceRoot":"","sources":["../../../src/__tests__/unit/estimateMaxSpendable.unit.test.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAAA,wDAA+E;AAC/E,sFAA8D;AAC9D,iEAAiG;AAEjG,IAAI,CAAC,IAAI,CAAC,gCAAgC,CAAC,CAAC;AAE5C,QAAQ,CAAC,sBAAsB,EAAE,GAAG,EAAE;IACpC,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,oBAAoB,GAAG,IAAI,CAAC,MAAM,CAAC,sBAAgB,CAAC,CAAC;QAC3D,oBAAoB,CAAC,eAAe,CAAC,OAAO,CAAC,OAAO,CAAC,6BAAW,CAAC,CAAC,CAAC;QACnE,MAAM,oBAAoB,GAAG,IAAI,CAAC,MAAM,CAAC,iBAAW,CAAC,CAAC;QACtD,oBAAoB,CAAC,eAAe,CAAC,OAAO,CAAC,OAAO,CAAC,sBAAI,CAAC,CAAC,CAAC;IAC9D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uDAAuD,EAAE,GAAS,EAAE;QACrE,MAAM,GAAG,GAAG,MAAM,IAAA,8BAAoB,EAAC,EAAE,OAAO,EAAP,yBAAO,EAAE,WAAW,EAAX,6BAAW,EAAE,CAAC,CAAC;QACjE,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,yBAAO,CAAC,OAAO,CAAC,KAAK,CAAC,2BAAS,CAAC,CAAC,CAAC;IACxD,CAAC,CAAA,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getTransactionStatus.unit.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/unit/getTransactionStatus.unit.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
const errors_1 = require("@ledgerhq/errors");
|
|
16
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
17
|
+
const errors_2 = require("../../errors");
|
|
18
|
+
const getTransactionStatus_1 = __importDefault(require("../../getTransactionStatus"));
|
|
19
|
+
const common_fixtures_1 = require("../fixtures/common.fixtures");
|
|
20
|
+
describe("getTransactionStatus", () => {
|
|
21
|
+
describe("Recipient", () => {
|
|
22
|
+
it("should detect the missing recipient and have an error", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
23
|
+
const transaction = Object.assign(Object.assign({}, common_fixtures_1.transaction), { recipient: "" });
|
|
24
|
+
const res = yield (0, getTransactionStatus_1.default)(common_fixtures_1.account, transaction);
|
|
25
|
+
expect(res.errors).toEqual(expect.objectContaining({
|
|
26
|
+
recipient: new errors_1.RecipientRequired(),
|
|
27
|
+
}));
|
|
28
|
+
}));
|
|
29
|
+
it("should detect the incorrect recipient and have an error", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
30
|
+
const transaction = Object.assign(Object.assign({}, common_fixtures_1.transaction), { recipient: "isInvalid" });
|
|
31
|
+
const res = yield (0, getTransactionStatus_1.default)(common_fixtures_1.account, transaction);
|
|
32
|
+
expect(res.errors).toEqual(expect.objectContaining({
|
|
33
|
+
recipient: new errors_1.InvalidAddress("", {
|
|
34
|
+
currencyName: common_fixtures_1.account.currency.name,
|
|
35
|
+
}),
|
|
36
|
+
}));
|
|
37
|
+
}));
|
|
38
|
+
it("should detect the recipient and the sender are the same and have an error", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
39
|
+
const transaction = Object.assign(Object.assign({}, common_fixtures_1.transaction), { recipient: "UQDzd8aeBOU-jqYw_ZSuZjceI5p-F4b7HMprAsUJAtRPbMol" });
|
|
40
|
+
const res = yield (0, getTransactionStatus_1.default)(common_fixtures_1.account, transaction);
|
|
41
|
+
expect(res.errors).toEqual(expect.objectContaining({
|
|
42
|
+
recipient: new errors_1.InvalidAddressBecauseDestinationIsAlsoSource("", {
|
|
43
|
+
currencyName: common_fixtures_1.account.currency.name,
|
|
44
|
+
}),
|
|
45
|
+
}));
|
|
46
|
+
}));
|
|
47
|
+
});
|
|
48
|
+
describe("Sender", () => {
|
|
49
|
+
it("should detect the sender is not correct and have an error", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
50
|
+
const tempAccount = Object.assign(Object.assign({}, common_fixtures_1.account), { freshAddress: "isInvalid" });
|
|
51
|
+
const res = yield (0, getTransactionStatus_1.default)(tempAccount, common_fixtures_1.transaction);
|
|
52
|
+
expect(res.errors).toEqual(expect.objectContaining({
|
|
53
|
+
sender: new errors_1.InvalidAddress(),
|
|
54
|
+
}));
|
|
55
|
+
}));
|
|
56
|
+
});
|
|
57
|
+
describe("Amount", () => {
|
|
58
|
+
it("should detect the amount is missing and have an error", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
59
|
+
const transaction = Object.assign(Object.assign({}, common_fixtures_1.transaction), { amount: new bignumber_js_1.default(0) });
|
|
60
|
+
const res = yield (0, getTransactionStatus_1.default)(common_fixtures_1.account, transaction);
|
|
61
|
+
expect(res.errors).toEqual(expect.objectContaining({
|
|
62
|
+
amount: new errors_1.AmountRequired(),
|
|
63
|
+
}));
|
|
64
|
+
}));
|
|
65
|
+
it("should detect the amount is greater than the spendable amount and have an error", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
66
|
+
const transaction = Object.assign(Object.assign({}, common_fixtures_1.transaction), { amount: (0, bignumber_js_1.default)(1000000002), fees: new bignumber_js_1.default("20") });
|
|
67
|
+
const res = yield (0, getTransactionStatus_1.default)(common_fixtures_1.account, transaction);
|
|
68
|
+
expect(res.errors).toEqual(expect.objectContaining({
|
|
69
|
+
amount: new errors_1.NotEnoughBalance(),
|
|
70
|
+
}));
|
|
71
|
+
}));
|
|
72
|
+
describe("Comment", () => {
|
|
73
|
+
it("should detect the comment is not valid and have an error", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
74
|
+
const transaction = Object.assign(Object.assign({}, common_fixtures_1.transaction), { comment: { isEncrypted: false, text: "comment\nInvalid" } });
|
|
75
|
+
const res = yield (0, getTransactionStatus_1.default)(common_fixtures_1.account, transaction);
|
|
76
|
+
expect(res.errors).toEqual(expect.objectContaining({
|
|
77
|
+
transaction: new errors_2.TonCommentInvalid(),
|
|
78
|
+
}));
|
|
79
|
+
}));
|
|
80
|
+
});
|
|
81
|
+
describe("Successful transaction", () => {
|
|
82
|
+
it("should not have errors", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
83
|
+
const successfulResult = {
|
|
84
|
+
amount: common_fixtures_1.transaction.amount,
|
|
85
|
+
errors: {},
|
|
86
|
+
warnings: {},
|
|
87
|
+
estimatedFees: common_fixtures_1.transaction.fees,
|
|
88
|
+
totalSpent: common_fixtures_1.transaction.amount.plus(common_fixtures_1.transaction.fees),
|
|
89
|
+
};
|
|
90
|
+
const res = yield (0, getTransactionStatus_1.default)(common_fixtures_1.account, common_fixtures_1.transaction);
|
|
91
|
+
expect(res).toEqual(successfulResult);
|
|
92
|
+
}));
|
|
93
|
+
});
|
|
94
|
+
});
|
|
95
|
+
});
|
|
96
|
+
//# sourceMappingURL=getTransactionStatus.unit.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getTransactionStatus.unit.test.js","sourceRoot":"","sources":["../../../src/__tests__/unit/getTransactionStatus.unit.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hw-getAddress.unit.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/unit/hw-getAddress.unit.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
const cryptoassets_1 = require("@ledgerhq/cryptoassets");
|
|
16
|
+
const hw_getAddress_1 = __importDefault(require("../../hw-getAddress"));
|
|
17
|
+
const utils_1 = require("../../utils");
|
|
18
|
+
const address = "0xc3f95102d5c8f2c83e49ce3acfb905edfb7f37de";
|
|
19
|
+
const publicKey = "mockedPublicKey";
|
|
20
|
+
const spyGetAddress = jest.fn().mockImplementation(() => __awaiter(void 0, void 0, void 0, function* () {
|
|
21
|
+
return Promise.resolve({
|
|
22
|
+
publicKey,
|
|
23
|
+
address: address.toLowerCase(),
|
|
24
|
+
});
|
|
25
|
+
}));
|
|
26
|
+
const spyValidateAddress = jest.fn().mockImplementation(() => __awaiter(void 0, void 0, void 0, function* () {
|
|
27
|
+
return Promise.resolve({
|
|
28
|
+
publicKey,
|
|
29
|
+
address: address.toLowerCase(),
|
|
30
|
+
});
|
|
31
|
+
}));
|
|
32
|
+
const mockSignerFactory = (_, fn) => fn({
|
|
33
|
+
getAddress: spyGetAddress,
|
|
34
|
+
validateAddress: spyValidateAddress,
|
|
35
|
+
signTransaction: jest.fn(),
|
|
36
|
+
});
|
|
37
|
+
describe("hw-getAddress", () => {
|
|
38
|
+
it("should return an encoded address and a public key when verifiy is false", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
39
|
+
const getAddress = (0, hw_getAddress_1.default)(mockSignerFactory);
|
|
40
|
+
const response = yield getAddress("deviceId", {
|
|
41
|
+
path: "44'/607'/0'/0'/0'/0'",
|
|
42
|
+
verify: false,
|
|
43
|
+
currency: (0, cryptoassets_1.getCryptoCurrencyById)("ton"),
|
|
44
|
+
derivationMode: "ton",
|
|
45
|
+
});
|
|
46
|
+
expect(response.address).toBe(address);
|
|
47
|
+
expect(response.publicKey).toBe(publicKey);
|
|
48
|
+
expect(spyGetAddress).toHaveBeenCalledWith((0, utils_1.getLedgerTonPath)("44'/607'/0'/0'/0'/0'"), {
|
|
49
|
+
bounceable: false,
|
|
50
|
+
});
|
|
51
|
+
}));
|
|
52
|
+
it("should return an encoded address and a public key when verifiy is true", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
53
|
+
const getAddress = (0, hw_getAddress_1.default)(mockSignerFactory);
|
|
54
|
+
const response = yield getAddress("deviceId", {
|
|
55
|
+
path: "44'/607'/0'/0'/0'/0'",
|
|
56
|
+
verify: true,
|
|
57
|
+
currency: (0, cryptoassets_1.getCryptoCurrencyById)("ton"),
|
|
58
|
+
derivationMode: "ton",
|
|
59
|
+
});
|
|
60
|
+
expect(response.address).toBe(address);
|
|
61
|
+
expect(response.publicKey).toBe(publicKey);
|
|
62
|
+
expect(spyValidateAddress).toHaveBeenCalledWith((0, utils_1.getLedgerTonPath)("44'/607'/0'/0'/0'/0'"), {
|
|
63
|
+
bounceable: false,
|
|
64
|
+
});
|
|
65
|
+
}));
|
|
66
|
+
});
|
|
67
|
+
//# sourceMappingURL=hw-getAddress.unit.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hw-getAddress.unit.test.js","sourceRoot":"","sources":["../../../src/__tests__/unit/hw-getAddress.unit.test.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAAA,yDAA+D;AAC/D,wEAA2C;AAE3C,uCAA+C;AAE/C,MAAM,OAAO,GAAG,4CAA4C,CAAC;AAC7D,MAAM,SAAS,GAAG,iBAAiB,CAAC;AACpC,MAAM,aAAa,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,GAAS,EAAE;IAC5D,OAAA,OAAO,CAAC,OAAO,CAAC;QACd,SAAS;QACT,OAAO,EAAE,OAAO,CAAC,WAAW,EAAE;KAC/B,CAAC,CAAA;EAAA,CACH,CAAC;AACF,MAAM,kBAAkB,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,GAAS,EAAE;IACjE,OAAA,OAAO,CAAC,OAAO,CAAC;QACd,SAAS;QACT,OAAO,EAAE,OAAO,CAAC,WAAW,EAAE;KAC/B,CAAC,CAAA;EAAA,CACH,CAAC;AAEF,MAAM,iBAAiB,GAAG,CAAI,CAAS,EAAE,EAAqC,EAAc,EAAE,CAC5F,EAAE,CAAC;IACD,UAAU,EAAE,aAAa;IACzB,eAAe,EAAE,kBAAkB;IACnC,eAAe,EAAE,IAAI,CAAC,EAAE,EAAE;CAC3B,CAAC,CAAC;AAEL,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;IAC7B,EAAE,CAAC,yEAAyE,EAAE,GAAS,EAAE;QACvF,MAAM,UAAU,GAAG,IAAA,uBAAQ,EAAC,iBAAiB,CAAC,CAAC;QAC/C,MAAM,QAAQ,GAAG,MAAM,UAAU,CAAC,UAAU,EAAE;YAC5C,IAAI,EAAE,sBAAsB;YAC5B,MAAM,EAAE,KAAK;YACb,QAAQ,EAAE,IAAA,oCAAqB,EAAC,KAAK,CAAC;YACtC,cAAc,EAAE,KAAK;SACtB,CAAC,CAAC;QACH,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACvC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC3C,MAAM,CAAC,aAAa,CAAC,CAAC,oBAAoB,CAAC,IAAA,wBAAgB,EAAC,sBAAsB,CAAC,EAAE;YACnF,UAAU,EAAE,KAAK;SAClB,CAAC,CAAC;IACL,CAAC,CAAA,CAAC,CAAC;IAEH,EAAE,CAAC,wEAAwE,EAAE,GAAS,EAAE;QACtF,MAAM,UAAU,GAAG,IAAA,uBAAQ,EAAC,iBAAiB,CAAC,CAAC;QAC/C,MAAM,QAAQ,GAAG,MAAM,UAAU,CAAC,UAAU,EAAE;YAC5C,IAAI,EAAE,sBAAsB;YAC5B,MAAM,EAAE,IAAI;YACZ,QAAQ,EAAE,IAAA,oCAAqB,EAAC,KAAK,CAAC;YACtC,cAAc,EAAE,KAAK;SACtB,CAAC,CAAC;QACH,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACvC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC3C,MAAM,CAAC,kBAAkB,CAAC,CAAC,oBAAoB,CAAC,IAAA,wBAAgB,EAAC,sBAAsB,CAAC,EAAE;YACxF,UAAU,EAAE,KAAK;SAClB,CAAC,CAAC;IACL,CAAC,CAAA,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prepareTransaction.unit.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/unit/prepareTransaction.unit.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
const api_1 = require("../../bridge/bridgeHelpers/api");
|
|
16
|
+
const prepareTransaction_1 = __importDefault(require("../../prepareTransaction"));
|
|
17
|
+
const common_fixtures_1 = require("../fixtures/common.fixtures");
|
|
18
|
+
jest.mock("../../bridge/bridgeHelpers/api");
|
|
19
|
+
describe("prepareTransaction", () => {
|
|
20
|
+
beforeAll(() => {
|
|
21
|
+
const fetchAccountInfoMock = jest.mocked(api_1.fetchAccountInfo);
|
|
22
|
+
fetchAccountInfoMock.mockReturnValue(Promise.resolve(common_fixtures_1.accountInfo));
|
|
23
|
+
const fetchEstimateFeeMock = jest.mocked(api_1.estimateFee);
|
|
24
|
+
fetchEstimateFeeMock.mockReturnValue(Promise.resolve(common_fixtures_1.fees));
|
|
25
|
+
});
|
|
26
|
+
describe("Ton Transaction", () => {
|
|
27
|
+
it("should return the transaction with the updated amount and fees", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
28
|
+
const transaction = yield (0, prepareTransaction_1.default)(common_fixtures_1.account, common_fixtures_1.transaction);
|
|
29
|
+
expect(transaction).toEqual(Object.assign(Object.assign({}, common_fixtures_1.transaction), { fees: common_fixtures_1.totalFees }));
|
|
30
|
+
}));
|
|
31
|
+
it("should preserve the reference when no change is detected on the transaction", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
32
|
+
const transaction = yield (0, prepareTransaction_1.default)(common_fixtures_1.account, Object.assign({}, common_fixtures_1.transaction));
|
|
33
|
+
const transaction2 = yield (0, prepareTransaction_1.default)(common_fixtures_1.account, transaction);
|
|
34
|
+
expect(transaction).toBe(transaction2);
|
|
35
|
+
}));
|
|
36
|
+
it("should create a coin transaction using the spendableBalance in the account", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
37
|
+
const transaction = yield (0, prepareTransaction_1.default)(common_fixtures_1.account, Object.assign(Object.assign({}, common_fixtures_1.transaction), { useAllAmount: true }));
|
|
38
|
+
expect(transaction).toEqual(Object.assign(Object.assign({}, common_fixtures_1.transaction), { useAllAmount: true, fees: common_fixtures_1.totalFees, amount: common_fixtures_1.account.spendableBalance.minus(common_fixtures_1.totalFees) }));
|
|
39
|
+
}));
|
|
40
|
+
});
|
|
41
|
+
});
|
|
42
|
+
//# sourceMappingURL=prepareTransaction.unit.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prepareTransaction.unit.test.js","sourceRoot":"","sources":["../../../src/__tests__/unit/prepareTransaction.unit.test.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAAA,wDAA+E;AAC/E,kFAA0D;AAC1D,iEAMqC;AAErC,IAAI,CAAC,IAAI,CAAC,gCAAgC,CAAC,CAAC;AAE5C,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAClC,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,oBAAoB,GAAG,IAAI,CAAC,MAAM,CAAC,sBAAgB,CAAC,CAAC;QAC3D,oBAAoB,CAAC,eAAe,CAAC,OAAO,CAAC,OAAO,CAAC,6BAAW,CAAC,CAAC,CAAC;QACnE,MAAM,oBAAoB,GAAG,IAAI,CAAC,MAAM,CAAC,iBAAW,CAAC,CAAC;QACtD,oBAAoB,CAAC,eAAe,CAAC,OAAO,CAAC,OAAO,CAAC,sBAAI,CAAC,CAAC,CAAC;IAC9D,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;QAC/B,EAAE,CAAC,gEAAgE,EAAE,GAAS,EAAE;YAC9E,MAAM,WAAW,GAAG,MAAM,IAAA,4BAAkB,EAAC,yBAAO,EAAE,6BAAe,CAAC,CAAC;YAEvE,MAAM,CAAC,WAAW,CAAC,CAAC,OAAO,iCACtB,6BAAe,KAClB,IAAI,EAAE,2BAAS,IACf,CAAC;QACL,CAAC,CAAA,CAAC,CAAC;QAEH,EAAE,CAAC,6EAA6E,EAAE,GAAS,EAAE;YAC3F,MAAM,WAAW,GAAG,MAAM,IAAA,4BAAkB,EAAC,yBAAO,oBAAO,6BAAe,EAAG,CAAC;YAC9E,MAAM,YAAY,GAAG,MAAM,IAAA,4BAAkB,EAAC,yBAAO,EAAE,WAAW,CAAC,CAAC;YAEpE,MAAM,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACzC,CAAC,CAAA,CAAC,CAAC;QAEH,EAAE,CAAC,4EAA4E,EAAE,GAAS,EAAE;YAC1F,MAAM,WAAW,GAAG,MAAM,IAAA,4BAAkB,EAAC,yBAAO,kCAC/C,6BAAe,KAClB,YAAY,EAAE,IAAI,IAClB,CAAC;YAEH,MAAM,CAAC,WAAW,CAAC,CAAC,OAAO,iCACtB,6BAAe,KAClB,YAAY,EAAE,IAAI,EAClB,IAAI,EAAE,2BAAS,EACf,MAAM,EAAE,yBAAO,CAAC,gBAAgB,CAAC,KAAK,CAAC,2BAAS,CAAC,IACjD,CAAC;QACL,CAAC,CAAA,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signOperation.unit.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/unit/signOperation.unit.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
const core_1 = require("@ton/core");
|
|
16
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
17
|
+
const api_1 = require("../../bridge/bridgeHelpers/api");
|
|
18
|
+
const signOperation_1 = require("../../signOperation");
|
|
19
|
+
const common_fixtures_1 = require("../fixtures/common.fixtures");
|
|
20
|
+
jest.mock("../../bridge/bridgeHelpers/api");
|
|
21
|
+
const spySignTransaction = jest.fn().mockImplementation(() => __awaiter(void 0, void 0, void 0, function* () {
|
|
22
|
+
return Promise.resolve((0, core_1.beginCell)()
|
|
23
|
+
.store((0, core_1.storeMessage)({
|
|
24
|
+
info: {
|
|
25
|
+
type: "external-in",
|
|
26
|
+
dest: core_1.Address.parse("EQDzd8aeBOU-jqYw_ZSuZjceI5p-F4b7HMprAsUJAtRPbJfg"),
|
|
27
|
+
importFee: BigInt(0),
|
|
28
|
+
},
|
|
29
|
+
body: new core_1.Cell(),
|
|
30
|
+
}))
|
|
31
|
+
.endCell());
|
|
32
|
+
}));
|
|
33
|
+
const mockSignerContext = (_, fn) => {
|
|
34
|
+
return fn({
|
|
35
|
+
signTransaction: spySignTransaction,
|
|
36
|
+
getAddress: jest.fn(),
|
|
37
|
+
validateAddress: jest.fn(),
|
|
38
|
+
});
|
|
39
|
+
};
|
|
40
|
+
describe("signOperation", () => {
|
|
41
|
+
beforeAll(() => {
|
|
42
|
+
const fetchAccountInfoMock = jest.mocked(api_1.fetchAccountInfo);
|
|
43
|
+
fetchAccountInfoMock.mockReturnValue(Promise.resolve(common_fixtures_1.accountInfo));
|
|
44
|
+
});
|
|
45
|
+
it("should return an optimistic operation and a signed hash returned by the app bindings", done => {
|
|
46
|
+
const signOperation = (0, signOperation_1.buildSignOperation)(mockSignerContext);
|
|
47
|
+
const signOpObservable = signOperation({
|
|
48
|
+
account: common_fixtures_1.account,
|
|
49
|
+
transaction: Object.assign(Object.assign({}, common_fixtures_1.transaction), { fees: common_fixtures_1.totalFees }),
|
|
50
|
+
deviceId: "",
|
|
51
|
+
});
|
|
52
|
+
signOpObservable.subscribe(obs => {
|
|
53
|
+
if (obs.type === "signed") {
|
|
54
|
+
const { signedOperation: { signature, operation }, } = obs;
|
|
55
|
+
const { amount } = common_fixtures_1.transaction;
|
|
56
|
+
expect(operation).toEqual({
|
|
57
|
+
id: "",
|
|
58
|
+
hash: "",
|
|
59
|
+
type: "OUT",
|
|
60
|
+
value: new bignumber_js_1.default(amount).plus(common_fixtures_1.totalFees),
|
|
61
|
+
fee: common_fixtures_1.totalFees,
|
|
62
|
+
blockHash: null,
|
|
63
|
+
blockHeight: null,
|
|
64
|
+
senders: [common_fixtures_1.account.freshAddress],
|
|
65
|
+
recipients: [common_fixtures_1.transaction.recipient],
|
|
66
|
+
accountId: common_fixtures_1.account.id,
|
|
67
|
+
date: expect.any(Date),
|
|
68
|
+
extra: {
|
|
69
|
+
comment: {
|
|
70
|
+
isEncrypted: false,
|
|
71
|
+
text: "",
|
|
72
|
+
},
|
|
73
|
+
explorerHash: "",
|
|
74
|
+
lt: "",
|
|
75
|
+
},
|
|
76
|
+
});
|
|
77
|
+
expect(signature).toBe("te6cckEBAQEASAAAi4gB5u+NPAnKfR1MYfspXMxuPEc0/C8N9jmU1gWKEgWontgEQA83fGngTlPo6mMP2UrmY3HiOafheG+xzKawLFCQLUT2wCDSMh+F");
|
|
78
|
+
done();
|
|
79
|
+
}
|
|
80
|
+
});
|
|
81
|
+
});
|
|
82
|
+
});
|
|
83
|
+
//# sourceMappingURL=signOperation.unit.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signOperation.unit.test.js","sourceRoot":"","sources":["../../../src/__tests__/unit/signOperation.unit.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"txn.unit.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/unit/txn.unit.test.ts"],"names":[],"mappings":""}
|