@matrix-privacy/wallet 0.0.1
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 +73 -0
- package/.prettierrc.js +21 -0
- package/LICENSE +21 -0
- package/README.md +7 -0
- package/dist/__tests__/index.test.d.ts +1 -0
- package/dist/__tests__/index.test.js +13 -0
- package/dist/__tests__/index.test.js.map +1 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.js +20 -0
- package/dist/index.js.map +1 -0
- package/dist/services/artifacts/__tests__/artifact-downloader.test.d.ts +1 -0
- package/dist/services/artifacts/__tests__/artifact-downloader.test.js +172 -0
- package/dist/services/artifacts/__tests__/artifact-downloader.test.js.map +1 -0
- package/dist/services/artifacts/artifact-downloader.d.ts +13 -0
- package/dist/services/artifacts/artifact-downloader.js +142 -0
- package/dist/services/artifacts/artifact-downloader.js.map +1 -0
- package/dist/services/artifacts/artifact-hash.d.ts +3 -0
- package/dist/services/artifacts/artifact-hash.js +53 -0
- package/dist/services/artifacts/artifact-hash.js.map +1 -0
- package/dist/services/artifacts/artifact-store.d.ts +11 -0
- package/dist/services/artifacts/artifact-store.js +15 -0
- package/dist/services/artifacts/artifact-store.js.map +1 -0
- package/dist/services/artifacts/artifact-util.d.ts +7 -0
- package/dist/services/artifacts/artifact-util.js +64 -0
- package/dist/services/artifacts/artifact-util.js.map +1 -0
- package/dist/services/artifacts/index.d.ts +2 -0
- package/dist/services/artifacts/index.js +19 -0
- package/dist/services/artifacts/index.js.map +1 -0
- package/dist/services/artifacts/json/artifact-v2-hashes.json +467 -0
- package/dist/services/ethers/__tests__/ethers-util.test.d.ts +1 -0
- package/dist/services/ethers/__tests__/ethers-util.test.js +19 -0
- package/dist/services/ethers/__tests__/ethers-util.test.js.map +1 -0
- package/dist/services/ethers/ethers-util.d.ts +1 -0
- package/dist/services/ethers/ethers-util.js +9 -0
- package/dist/services/ethers/ethers-util.js.map +1 -0
- package/dist/services/ethers/index.d.ts +1 -0
- package/dist/services/ethers/index.js +18 -0
- package/dist/services/ethers/index.js.map +1 -0
- package/dist/services/index.d.ts +4 -0
- package/dist/services/index.js +21 -0
- package/dist/services/index.js.map +1 -0
- package/dist/services/matrix/core/__tests__/engine.test.d.ts +1 -0
- package/dist/services/matrix/core/__tests__/engine.test.js +30 -0
- package/dist/services/matrix/core/__tests__/engine.test.js.map +1 -0
- package/dist/services/matrix/core/__tests__/providers.test.d.ts +1 -0
- package/dist/services/matrix/core/__tests__/providers.test.js +54 -0
- package/dist/services/matrix/core/__tests__/providers.test.js.map +1 -0
- package/dist/services/matrix/core/artifacts.d.ts +10 -0
- package/dist/services/matrix/core/artifacts.js +70 -0
- package/dist/services/matrix/core/artifacts.js.map +1 -0
- package/dist/services/matrix/core/engine.d.ts +4 -0
- package/dist/services/matrix/core/engine.js +21 -0
- package/dist/services/matrix/core/engine.js.map +1 -0
- package/dist/services/matrix/core/index.d.ts +8 -0
- package/dist/services/matrix/core/index.js +25 -0
- package/dist/services/matrix/core/index.js.map +1 -0
- package/dist/services/matrix/core/init.d.ts +21 -0
- package/dist/services/matrix/core/init.js +79 -0
- package/dist/services/matrix/core/init.js.map +1 -0
- package/dist/services/matrix/core/load-provider.d.ts +9 -0
- package/dist/services/matrix/core/load-provider.js +100 -0
- package/dist/services/matrix/core/load-provider.js.map +1 -0
- package/dist/services/matrix/core/merkletree.d.ts +5 -0
- package/dist/services/matrix/core/merkletree.js +40 -0
- package/dist/services/matrix/core/merkletree.js.map +1 -0
- package/dist/services/matrix/core/prover.d.ts +3 -0
- package/dist/services/matrix/core/prover.js +14 -0
- package/dist/services/matrix/core/prover.js.map +1 -0
- package/dist/services/matrix/core/providers.d.ts +9 -0
- package/dist/services/matrix/core/providers.js +31 -0
- package/dist/services/matrix/core/providers.js.map +1 -0
- package/dist/services/matrix/core/shields.d.ts +11 -0
- package/dist/services/matrix/core/shields.js +24 -0
- package/dist/services/matrix/core/shields.js.map +1 -0
- package/dist/services/matrix/history/__tests__/transaction-history.test.d.ts +1 -0
- package/dist/services/matrix/history/__tests__/transaction-history.test.js +249 -0
- package/dist/services/matrix/history/__tests__/transaction-history.test.js.map +1 -0
- package/dist/services/matrix/history/transaction-history.d.ts +4 -0
- package/dist/services/matrix/history/transaction-history.js +182 -0
- package/dist/services/matrix/history/transaction-history.js.map +1 -0
- package/dist/services/matrix/index.d.ts +4 -0
- package/dist/services/matrix/index.js +21 -0
- package/dist/services/matrix/index.js.map +1 -0
- package/dist/services/matrix/process/extract-transaction-data.d.ts +3 -0
- package/dist/services/matrix/process/extract-transaction-data.js +19 -0
- package/dist/services/matrix/process/extract-transaction-data.js.map +1 -0
- package/dist/services/matrix/process/index.d.ts +1 -0
- package/dist/services/matrix/process/index.js +18 -0
- package/dist/services/matrix/process/index.js.map +1 -0
- package/dist/services/matrix/quick-sync/V3/__tests__/quick-sync-events-graph-v3.test.d.ts +1 -0
- package/dist/services/matrix/quick-sync/V3/__tests__/quick-sync-events-graph-v3.test.js +56 -0
- package/dist/services/matrix/quick-sync/V3/__tests__/quick-sync-events-graph-v3.test.js.map +1 -0
- package/dist/services/matrix/quick-sync/V3/graph-type-formatters-v3.d.ts +8 -0
- package/dist/services/matrix/quick-sync/V3/graph-type-formatters-v3.js +103 -0
- package/dist/services/matrix/quick-sync/V3/graph-type-formatters-v3.js.map +1 -0
- package/dist/services/matrix/quick-sync/V3/graphql/.graphclient/sources/mumbai/introspectionSchema.d.ts +2 -0
- package/dist/services/matrix/quick-sync/V3/graphql/.graphclient/sources/mumbai/introspectionSchema.js +19861 -0
- package/dist/services/matrix/quick-sync/V3/graphql/.graphclient/sources/mumbai/introspectionSchema.js.map +1 -0
- package/dist/services/matrix/quick-sync/V3/graphql/.graphclient/sources/mumbai/types.d.ts +1352 -0
- package/dist/services/matrix/quick-sync/V3/graphql/.graphclient/sources/mumbai/types.js +4 -0
- package/dist/services/matrix/quick-sync/V3/graphql/.graphclient/sources/mumbai/types.js.map +1 -0
- package/dist/services/matrix/quick-sync/V3/graphql/index.d.ts +1680 -0
- package/dist/services/matrix/quick-sync/V3/graphql/index.js +348 -0
- package/dist/services/matrix/quick-sync/V3/graphql/index.js.map +1 -0
- package/dist/services/matrix/quick-sync/V3/quick-sync-events-graph-v3.d.ts +2 -0
- package/dist/services/matrix/quick-sync/V3/quick-sync-events-graph-v3.js +99 -0
- package/dist/services/matrix/quick-sync/V3/quick-sync-events-graph-v3.js.map +1 -0
- package/dist/services/matrix/quick-sync/graph-query.d.ts +5 -0
- package/dist/services/matrix/quick-sync/graph-query.js +26 -0
- package/dist/services/matrix/quick-sync/graph-query.js.map +1 -0
- package/dist/services/matrix/quick-sync/quick-sync-events.d.ts +2 -0
- package/dist/services/matrix/quick-sync/quick-sync-events.js +9 -0
- package/dist/services/matrix/quick-sync/quick-sync-events.js.map +1 -0
- package/dist/services/matrix/quick-sync/shared-formatters.d.ts +8 -0
- package/dist/services/matrix/quick-sync/shared-formatters.js +36 -0
- package/dist/services/matrix/quick-sync/shared-formatters.js.map +1 -0
- package/dist/services/matrix/util/__tests__/bytes-util.test.d.ts +1 -0
- package/dist/services/matrix/util/__tests__/bytes-util.test.js +23 -0
- package/dist/services/matrix/util/__tests__/bytes-util.test.js.map +1 -0
- package/dist/services/matrix/util/__tests__/crypto-util.test.d.ts +1 -0
- package/dist/services/matrix/util/__tests__/crypto-util.test.js +62 -0
- package/dist/services/matrix/util/__tests__/crypto-util.test.js.map +1 -0
- package/dist/services/matrix/util/bytes.d.ts +5 -0
- package/dist/services/matrix/util/bytes.js +22 -0
- package/dist/services/matrix/util/bytes.js.map +1 -0
- package/dist/services/matrix/util/crypto.d.ts +14 -0
- package/dist/services/matrix/util/crypto.js +80 -0
- package/dist/services/matrix/util/crypto.js.map +1 -0
- package/dist/services/matrix/util/graph-util.d.ts +3 -0
- package/dist/services/matrix/util/graph-util.js +13 -0
- package/dist/services/matrix/util/graph-util.js.map +1 -0
- package/dist/services/matrix/util/index.d.ts +2 -0
- package/dist/services/matrix/util/index.js +19 -0
- package/dist/services/matrix/util/index.js.map +1 -0
- package/dist/services/matrix/util/runtime.d.ts +2 -0
- package/dist/services/matrix/util/runtime.js +8 -0
- package/dist/services/matrix/util/runtime.js.map +1 -0
- package/dist/services/matrix/wallets/__tests__/balances-live.test.d.ts +1 -0
- package/dist/services/matrix/wallets/__tests__/balances-live.test.js +48 -0
- package/dist/services/matrix/wallets/__tests__/balances-live.test.js.map +1 -0
- package/dist/services/matrix/wallets/__tests__/balances-update.test.d.ts +1 -0
- package/dist/services/matrix/wallets/__tests__/balances-update.test.js +85 -0
- package/dist/services/matrix/wallets/__tests__/balances-update.test.js.map +1 -0
- package/dist/services/matrix/wallets/__tests__/balances.test.d.ts +1 -0
- package/dist/services/matrix/wallets/__tests__/balances.test.js +59 -0
- package/dist/services/matrix/wallets/__tests__/balances.test.js.map +1 -0
- package/dist/services/matrix/wallets/__tests__/wallets.test.d.ts +1 -0
- package/dist/services/matrix/wallets/__tests__/wallets.test.js +80 -0
- package/dist/services/matrix/wallets/__tests__/wallets.test.js.map +1 -0
- package/dist/services/matrix/wallets/balance-update.d.ts +10 -0
- package/dist/services/matrix/wallets/balance-update.js +126 -0
- package/dist/services/matrix/wallets/balance-update.js.map +1 -0
- package/dist/services/matrix/wallets/balances.d.ts +3 -0
- package/dist/services/matrix/wallets/balances.js +32 -0
- package/dist/services/matrix/wallets/balances.js.map +1 -0
- package/dist/services/matrix/wallets/index.d.ts +4 -0
- package/dist/services/matrix/wallets/index.js +21 -0
- package/dist/services/matrix/wallets/index.js.map +1 -0
- package/dist/services/matrix/wallets/wallets.d.ts +22 -0
- package/dist/services/matrix/wallets/wallets.js +252 -0
- package/dist/services/matrix/wallets/wallets.js.map +1 -0
- package/dist/services/transactions/__tests__/json/formatted-relay-adapt-error-logs.json +216 -0
- package/dist/services/transactions/__tests__/proof-cache.test.d.ts +1 -0
- package/dist/services/transactions/__tests__/proof-cache.test.js +114 -0
- package/dist/services/transactions/__tests__/proof-cache.test.js.map +1 -0
- package/dist/services/transactions/__tests__/tx-cross-contract-calls.test.d.ts +1 -0
- package/dist/services/transactions/__tests__/tx-cross-contract-calls.test.js +376 -0
- package/dist/services/transactions/__tests__/tx-cross-contract-calls.test.js.map +1 -0
- package/dist/services/transactions/__tests__/tx-gas-details.test.d.ts +1 -0
- package/dist/services/transactions/__tests__/tx-gas-details.test.js +109 -0
- package/dist/services/transactions/__tests__/tx-gas-details.test.js.map +1 -0
- package/dist/services/transactions/__tests__/tx-notes.test.d.ts +1 -0
- package/dist/services/transactions/__tests__/tx-notes.test.js +193 -0
- package/dist/services/transactions/__tests__/tx-notes.test.js.map +1 -0
- package/dist/services/transactions/__tests__/tx-shield-base-token.test.d.ts +1 -0
- package/dist/services/transactions/__tests__/tx-shield-base-token.test.js +99 -0
- package/dist/services/transactions/__tests__/tx-shield-base-token.test.js.map +1 -0
- package/dist/services/transactions/__tests__/tx-shield.test.d.ts +1 -0
- package/dist/services/transactions/__tests__/tx-shield.test.js +146 -0
- package/dist/services/transactions/__tests__/tx-shield.test.js.map +1 -0
- package/dist/services/transactions/__tests__/tx-transfer.test.d.ts +1 -0
- package/dist/services/transactions/__tests__/tx-transfer.test.js +263 -0
- package/dist/services/transactions/__tests__/tx-transfer.test.js.map +1 -0
- package/dist/services/transactions/__tests__/tx-unshield.test.d.ts +1 -0
- package/dist/services/transactions/__tests__/tx-unshield.test.js +759 -0
- package/dist/services/transactions/__tests__/tx-unshield.test.js.map +1 -0
- package/dist/services/transactions/index.d.ts +13 -0
- package/dist/services/transactions/index.js +30 -0
- package/dist/services/transactions/index.js.map +1 -0
- package/dist/services/transactions/proof-cache.d.ts +27 -0
- package/dist/services/transactions/proof-cache.js +130 -0
- package/dist/services/transactions/proof-cache.js.map +1 -0
- package/dist/services/transactions/tx-cross-contract-calls.d.ts +12 -0
- package/dist/services/transactions/tx-cross-contract-calls.js +210 -0
- package/dist/services/transactions/tx-cross-contract-calls.js.map +1 -0
- package/dist/services/transactions/tx-gas-broadcaster-fee-estimator.d.ts +5 -0
- package/dist/services/transactions/tx-gas-broadcaster-fee-estimator.js +110 -0
- package/dist/services/transactions/tx-gas-broadcaster-fee-estimator.js.map +1 -0
- package/dist/services/transactions/tx-gas-details.d.ts +5 -0
- package/dist/services/transactions/tx-gas-details.js +101 -0
- package/dist/services/transactions/tx-gas-details.js.map +1 -0
- package/dist/services/transactions/tx-generator.d.ts +13 -0
- package/dist/services/transactions/tx-generator.js +168 -0
- package/dist/services/transactions/tx-generator.js.map +1 -0
- package/dist/services/transactions/tx-notes.d.ts +11 -0
- package/dist/services/transactions/tx-notes.js +153 -0
- package/dist/services/transactions/tx-notes.js.map +1 -0
- package/dist/services/transactions/tx-nullifiers.d.ts +2 -0
- package/dist/services/transactions/tx-nullifiers.js +17 -0
- package/dist/services/transactions/tx-nullifiers.js.map +1 -0
- package/dist/services/transactions/tx-proof-transfer.d.ts +3 -0
- package/dist/services/transactions/tx-proof-transfer.js +39 -0
- package/dist/services/transactions/tx-proof-transfer.js.map +1 -0
- package/dist/services/transactions/tx-proof-unshield.d.ts +5 -0
- package/dist/services/transactions/tx-proof-unshield.js +132 -0
- package/dist/services/transactions/tx-proof-unshield.js.map +1 -0
- package/dist/services/transactions/tx-shield-base-token.d.ts +3 -0
- package/dist/services/transactions/tx-shield-base-token.js +55 -0
- package/dist/services/transactions/tx-shield-base-token.js.map +1 -0
- package/dist/services/transactions/tx-shield.d.ts +6 -0
- package/dist/services/transactions/tx-shield.js +77 -0
- package/dist/services/transactions/tx-shield.js.map +1 -0
- package/dist/services/transactions/tx-transfer.d.ts +3 -0
- package/dist/services/transactions/tx-transfer.js +39 -0
- package/dist/services/transactions/tx-transfer.js.map +1 -0
- package/dist/services/transactions/tx-unshield.d.ts +11 -0
- package/dist/services/transactions/tx-unshield.js +224 -0
- package/dist/services/transactions/tx-unshield.js.map +1 -0
- package/dist/tests/local-e2e.d.ts +13 -0
- package/dist/tests/local-e2e.js +487 -0
- package/dist/tests/local-e2e.js.map +1 -0
- package/dist/tests/mocks.test.d.ts +40 -0
- package/dist/tests/mocks.test.js +171 -0
- package/dist/tests/mocks.test.js.map +1 -0
- package/dist/tests/setup.test.d.ts +7 -0
- package/dist/tests/setup.test.js +88 -0
- package/dist/tests/setup.test.js.map +1 -0
- package/dist/tests/stubs/engine-stubs.test.d.ts +7 -0
- package/dist/tests/stubs/engine-stubs.test.js +72 -0
- package/dist/tests/stubs/engine-stubs.test.js.map +1 -0
- package/dist/utils/__tests__/blocked-address.test.d.ts +1 -0
- package/dist/utils/__tests__/blocked-address.test.js +23 -0
- package/dist/utils/__tests__/blocked-address.test.js.map +1 -0
- package/dist/utils/__tests__/logger.test.d.ts +1 -0
- package/dist/utils/__tests__/logger.test.js +28 -0
- package/dist/utils/__tests__/logger.test.js.map +1 -0
- package/dist/utils/__tests__/utils.test.d.ts +1 -0
- package/dist/utils/__tests__/utils.test.js +21 -0
- package/dist/utils/__tests__/utils.test.js.map +1 -0
- package/dist/utils/blocked-address.d.ts +2 -0
- package/dist/utils/blocked-address.js +17 -0
- package/dist/utils/blocked-address.js.map +1 -0
- package/dist/utils/error.d.ts +1 -0
- package/dist/utils/error.js +20 -0
- package/dist/utils/error.js.map +1 -0
- package/dist/utils/gas-price.d.ts +6 -0
- package/dist/utils/gas-price.js +19 -0
- package/dist/utils/gas-price.js.map +1 -0
- package/dist/utils/index.d.ts +2 -0
- package/dist/utils/index.js +19 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/logger.d.ts +3 -0
- package/dist/utils/logger.js +21 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/utils.d.ts +4 -0
- package/dist/utils/utils.js +54 -0
- package/dist/utils/utils.js.map +1 -0
- package/package.json +94 -0
- package/postinstall.js +52 -0
- package/react-native-shims.js +42 -0
|
@@ -0,0 +1,263 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
const chai_1 = __importDefault(require("chai"));
|
|
30
|
+
const chai_as_promised_1 = __importDefault(require("chai-as-promised"));
|
|
31
|
+
const sinon_1 = __importDefault(require("sinon"));
|
|
32
|
+
const engine_1 = require("@matrix-privacy/engine");
|
|
33
|
+
const shared_models_1 = require("@matrix-privacy/shared-models");
|
|
34
|
+
const setup_test_1 = require("../../../tests/setup.test");
|
|
35
|
+
const mocks_test_1 = require("../../../tests/mocks.test");
|
|
36
|
+
const tx_transfer_1 = require("../tx-transfer");
|
|
37
|
+
const txGasDetailsModule = __importStar(require("../tx-gas-details"));
|
|
38
|
+
const tx_proof_transfer_1 = require("../tx-proof-transfer");
|
|
39
|
+
const wallets_1 = require("../../matrix/wallets/wallets");
|
|
40
|
+
const proof_cache_1 = require("../proof-cache");
|
|
41
|
+
const txNotes = __importStar(require("../tx-notes"));
|
|
42
|
+
let gasEstimateStub;
|
|
43
|
+
let railProveStub;
|
|
44
|
+
let railDummyProveStub;
|
|
45
|
+
let railTransactStub;
|
|
46
|
+
let setUnshieldSpy;
|
|
47
|
+
let erc20NoteSpy;
|
|
48
|
+
let nftNoteSpy;
|
|
49
|
+
let matrixWallet;
|
|
50
|
+
let broadcasterFeeERC20AmountRecipient;
|
|
51
|
+
chai_1.default.use(chai_as_promised_1.default);
|
|
52
|
+
const { expect } = chai_1.default;
|
|
53
|
+
const MOCK_TOKEN_AMOUNTS_DIFFERENT = [
|
|
54
|
+
{
|
|
55
|
+
tokenAddress: mocks_test_1.MOCK_TOKEN_ADDRESS,
|
|
56
|
+
amount: 100n,
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
tokenAddress: mocks_test_1.MOCK_TOKEN_ADDRESS_2,
|
|
60
|
+
amount: 300n,
|
|
61
|
+
},
|
|
62
|
+
];
|
|
63
|
+
const overallBatchMinGasPrice = BigInt('0x1000');
|
|
64
|
+
const gasDetails = {
|
|
65
|
+
evmGasType: shared_models_1.EVMGasType.Type1,
|
|
66
|
+
gasEstimate: 1000n,
|
|
67
|
+
gasPrice: overallBatchMinGasPrice,
|
|
68
|
+
};
|
|
69
|
+
const MOCK_TOKEN_AMOUNT_RECIPIENTS_INVALID = mocks_test_1.MOCK_TOKEN_AMOUNTS.map(erc20Amount => ({
|
|
70
|
+
...erc20Amount,
|
|
71
|
+
recipientAddress: mocks_test_1.MOCK_ETH_WALLET_ADDRESS,
|
|
72
|
+
}));
|
|
73
|
+
const MOCK_NFT_AMOUNT_RECIPIENTS_INVALID = mocks_test_1.MOCK_NFT_AMOUNT_RECIPIENTS.map(nftAmountRecipient => ({
|
|
74
|
+
...nftAmountRecipient,
|
|
75
|
+
recipientAddress: mocks_test_1.MOCK_ETH_WALLET_ADDRESS,
|
|
76
|
+
}));
|
|
77
|
+
const MOCK_TOKEN_AMOUNT_RECIPIENTS = mocks_test_1.MOCK_TOKEN_AMOUNTS.map(erc20Amount => ({
|
|
78
|
+
...erc20Amount,
|
|
79
|
+
recipientAddress: mocks_test_1.MOCK_MATRIX_WALLET_ADDRESS,
|
|
80
|
+
}));
|
|
81
|
+
const MOCK_TOKEN_AMOUNT_RECIPIENTS_DIFFERENT = MOCK_TOKEN_AMOUNTS_DIFFERENT.map(erc20Amount => ({
|
|
82
|
+
...erc20Amount,
|
|
83
|
+
recipientAddress: mocks_test_1.MOCK_ETH_WALLET_ADDRESS,
|
|
84
|
+
}));
|
|
85
|
+
const stubGasEstimateSuccess = () => {
|
|
86
|
+
gasEstimateStub = sinon_1.default.stub(txGasDetailsModule, 'getGasEstimate').resolves(BigInt('200'));
|
|
87
|
+
};
|
|
88
|
+
const stubGasEstimateFailure = () => {
|
|
89
|
+
gasEstimateStub = sinon_1.default.stub(txGasDetailsModule, 'getGasEstimate').rejects(new Error('test rejection - gas estimate'));
|
|
90
|
+
};
|
|
91
|
+
const spyOnERC20Note = () => {
|
|
92
|
+
erc20NoteSpy = sinon_1.default.spy(txNotes, 'erc20NoteFromERC20AmountRecipient');
|
|
93
|
+
};
|
|
94
|
+
const spyOnNFTNote = () => {
|
|
95
|
+
nftNoteSpy = sinon_1.default.spy(txNotes, 'nftNoteFromNFTAmountRecipient');
|
|
96
|
+
};
|
|
97
|
+
describe('tx-transfer', () => {
|
|
98
|
+
before(async function run() {
|
|
99
|
+
this.timeout(60000);
|
|
100
|
+
await (0, setup_test_1.initTestEngine)();
|
|
101
|
+
await (0, setup_test_1.initTestEngineNetworks)();
|
|
102
|
+
const matrixWalletInfo = await (0, wallets_1.createMatrixWallet)(mocks_test_1.MOCK_DB_ENCRYPTION_KEY, mocks_test_1.MOCK_MNEMONIC, undefined);
|
|
103
|
+
if (!(0, shared_models_1.isDefined)(matrixWalletInfo)) {
|
|
104
|
+
throw new Error('Expected matrixWalletInfo');
|
|
105
|
+
}
|
|
106
|
+
matrixWallet = (0, wallets_1.fullWalletForID)(matrixWalletInfo.id);
|
|
107
|
+
const broadcasterWalletInfo = await (0, wallets_1.createMatrixWallet)(mocks_test_1.MOCK_DB_ENCRYPTION_KEY, mocks_test_1.MOCK_MNEMONIC, undefined);
|
|
108
|
+
if (!(0, shared_models_1.isDefined)(broadcasterWalletInfo)) {
|
|
109
|
+
throw new Error('Expected broadcasterWalletInfo');
|
|
110
|
+
}
|
|
111
|
+
const broadcasterMatrixAddress = broadcasterWalletInfo.matrixAddress;
|
|
112
|
+
broadcasterFeeERC20AmountRecipient = {
|
|
113
|
+
...mocks_test_1.MOCK_TOKEN_FEE,
|
|
114
|
+
recipientAddress: broadcasterMatrixAddress,
|
|
115
|
+
};
|
|
116
|
+
railProveStub = sinon_1.default.stub(engine_1.TransactionBatch.prototype, 'generateTransactions').resolves({
|
|
117
|
+
provedTransactions: [
|
|
118
|
+
{
|
|
119
|
+
nullifiers: mocks_test_1.MOCK_NULLIFIERS,
|
|
120
|
+
},
|
|
121
|
+
],
|
|
122
|
+
});
|
|
123
|
+
railDummyProveStub = sinon_1.default.stub(engine_1.TransactionBatch.prototype, 'generateDummyTransactions').resolves([
|
|
124
|
+
{
|
|
125
|
+
commitments: mocks_test_1.MOCK_COMMITMENTS,
|
|
126
|
+
boundParams: mocks_test_1.MOCK_BOUND_PARAMS_V3,
|
|
127
|
+
nullifiers: mocks_test_1.MOCK_NULLIFIERS,
|
|
128
|
+
},
|
|
129
|
+
]);
|
|
130
|
+
railTransactStub = sinon_1.default.stub(engine_1.MatrixContracts, 'generateTransact').resolves({ data: '0x0123' });
|
|
131
|
+
});
|
|
132
|
+
afterEach(() => {
|
|
133
|
+
gasEstimateStub?.restore();
|
|
134
|
+
setUnshieldSpy?.restore();
|
|
135
|
+
erc20NoteSpy?.restore();
|
|
136
|
+
nftNoteSpy?.restore();
|
|
137
|
+
});
|
|
138
|
+
after(async () => {
|
|
139
|
+
railProveStub.restore();
|
|
140
|
+
railDummyProveStub.restore();
|
|
141
|
+
railTransactStub.restore();
|
|
142
|
+
await (0, setup_test_1.closeTestEngine)();
|
|
143
|
+
});
|
|
144
|
+
// TRANSFER ERC20 - GAS ESTIMATE
|
|
145
|
+
it('Should get gas estimates for valid erc20 transfer', async () => {
|
|
146
|
+
stubGasEstimateSuccess();
|
|
147
|
+
spyOnERC20Note();
|
|
148
|
+
const rsp = await (0, tx_transfer_1.gasEstimateForUnprovenTransfer)(shared_models_1.NetworkName.Hardhat, matrixWallet.id, mocks_test_1.MOCK_DB_ENCRYPTION_KEY, mocks_test_1.MOCK_MEMO, MOCK_TOKEN_AMOUNT_RECIPIENTS, [], // nftAmountRecipients
|
|
149
|
+
mocks_test_1.MOCK_TRANSACTION_GAS_DETAILS_SERIALIZED_TYPE_2, mocks_test_1.MOCK_FEE_TOKEN_DETAILS, false);
|
|
150
|
+
expect(erc20NoteSpy.called).to.be.true;
|
|
151
|
+
expect(erc20NoteSpy.args.length).to.equal(6); // Number of calls - 3 for each of 2 broadcaster fee iterations
|
|
152
|
+
expect(erc20NoteSpy.args[0][0].amount).to.equal(BigInt('0x00')); // original broadcaster fee
|
|
153
|
+
expect(erc20NoteSpy.args[1][0].amount).to.equal(BigInt('0x100')); // token1
|
|
154
|
+
expect(erc20NoteSpy.args[2][0].amount).to.equal(BigInt('0x200')); // token2
|
|
155
|
+
expect(erc20NoteSpy.args[3][0].amount).to.equal(BigInt('0x0275a61bf8737eb4')); // New estimated Broadcaster Fee
|
|
156
|
+
expect(erc20NoteSpy.args[4][0].amount).to.equal(BigInt('0x100')); // token1
|
|
157
|
+
expect(erc20NoteSpy.args[5][0].amount).to.equal(BigInt('0x200')); // token2
|
|
158
|
+
// Add 9000 for the dummy tx variance
|
|
159
|
+
expect(rsp.gasEstimate).to.equal(9000n + 200n);
|
|
160
|
+
}).timeout(10000);
|
|
161
|
+
it('Should get gas estimates for valid erc20 transfer: public wallet', async () => {
|
|
162
|
+
stubGasEstimateSuccess();
|
|
163
|
+
spyOnERC20Note();
|
|
164
|
+
const rsp = await (0, tx_transfer_1.gasEstimateForUnprovenTransfer)(shared_models_1.NetworkName.Hardhat, matrixWallet.id, mocks_test_1.MOCK_DB_ENCRYPTION_KEY, mocks_test_1.MOCK_MEMO, MOCK_TOKEN_AMOUNT_RECIPIENTS, [], // nftAmountRecipients
|
|
165
|
+
mocks_test_1.MOCK_TRANSACTION_GAS_DETAILS_SERIALIZED_TYPE_2, mocks_test_1.MOCK_FEE_TOKEN_DETAILS, true);
|
|
166
|
+
expect(erc20NoteSpy.called).to.be.true;
|
|
167
|
+
expect(erc20NoteSpy.args.length).to.equal(2); // Number of calls (without broadcaster fees)
|
|
168
|
+
expect(erc20NoteSpy.args[0][0].amount).to.equal(BigInt('0x100')); // token1
|
|
169
|
+
expect(erc20NoteSpy.args[1][0].amount).to.equal(BigInt('0x200')); // token2
|
|
170
|
+
// Add 9000 for the dummy tx variance
|
|
171
|
+
expect(rsp.gasEstimate).to.equal(9000n + 200n);
|
|
172
|
+
}).timeout(10000);
|
|
173
|
+
it('Should error on gas estimates for invalid erc20 transfer', async () => {
|
|
174
|
+
stubGasEstimateSuccess();
|
|
175
|
+
await expect((0, tx_transfer_1.gasEstimateForUnprovenTransfer)(shared_models_1.NetworkName.Hardhat, matrixWallet.id, mocks_test_1.MOCK_DB_ENCRYPTION_KEY, mocks_test_1.MOCK_MEMO, MOCK_TOKEN_AMOUNT_RECIPIENTS_INVALID, [], // nftAmountRecipients
|
|
176
|
+
mocks_test_1.MOCK_TRANSACTION_GAS_DETAILS_SERIALIZED_TYPE_2, mocks_test_1.MOCK_FEE_TOKEN_DETAILS, false)).rejectedWith('Invalid Matrix address.');
|
|
177
|
+
});
|
|
178
|
+
it('Should error on transfer gas estimate for ethers rejections', async () => {
|
|
179
|
+
stubGasEstimateFailure();
|
|
180
|
+
await expect((0, tx_transfer_1.gasEstimateForUnprovenTransfer)(shared_models_1.NetworkName.Hardhat, matrixWallet.id, mocks_test_1.MOCK_DB_ENCRYPTION_KEY, mocks_test_1.MOCK_MEMO, MOCK_TOKEN_AMOUNT_RECIPIENTS, [], // nftAmountRecipients
|
|
181
|
+
mocks_test_1.MOCK_TRANSACTION_GAS_DETAILS_SERIALIZED_TYPE_2, mocks_test_1.MOCK_FEE_TOKEN_DETAILS, false)).rejectedWith('test rejection - gas estimate');
|
|
182
|
+
});
|
|
183
|
+
// TRANSFER NFT - GAS ESTIMATE
|
|
184
|
+
it('Should get gas estimates for valid NFT transfer', async () => {
|
|
185
|
+
stubGasEstimateSuccess();
|
|
186
|
+
spyOnNFTNote();
|
|
187
|
+
const rsp = await (0, tx_transfer_1.gasEstimateForUnprovenTransfer)(shared_models_1.NetworkName.Hardhat, matrixWallet.id, mocks_test_1.MOCK_DB_ENCRYPTION_KEY, mocks_test_1.MOCK_MEMO, [], // erc20AmountRecipients
|
|
188
|
+
mocks_test_1.MOCK_NFT_AMOUNT_RECIPIENTS, // nftAmountRecipients
|
|
189
|
+
mocks_test_1.MOCK_TRANSACTION_GAS_DETAILS_SERIALIZED_TYPE_2, mocks_test_1.MOCK_FEE_TOKEN_DETAILS, false);
|
|
190
|
+
expect(nftNoteSpy.called).to.be.true;
|
|
191
|
+
expect(nftNoteSpy.args.length).to.equal(4); // Number of calls - 2 for each of 2 broadcaster fee iterations
|
|
192
|
+
expect(nftNoteSpy.args[0][0].tokenSubID).to.equal('0x01'); // nft1
|
|
193
|
+
expect(nftNoteSpy.args[1][0].tokenSubID).to.equal('0x02'); // nft2
|
|
194
|
+
expect(nftNoteSpy.args[2][0].tokenSubID).to.equal('0x01'); // nft1
|
|
195
|
+
expect(nftNoteSpy.args[3][0].tokenSubID).to.equal('0x02'); // nft2
|
|
196
|
+
// Add 9000 for the dummy tx variance
|
|
197
|
+
expect(rsp.gasEstimate).to.equal(9000n + 200n);
|
|
198
|
+
}).timeout(10000);
|
|
199
|
+
it('Should get gas estimates for valid NFT transfer: public wallet', async () => {
|
|
200
|
+
stubGasEstimateSuccess();
|
|
201
|
+
spyOnNFTNote();
|
|
202
|
+
const rsp = await (0, tx_transfer_1.gasEstimateForUnprovenTransfer)(shared_models_1.NetworkName.Hardhat, matrixWallet.id, mocks_test_1.MOCK_DB_ENCRYPTION_KEY, mocks_test_1.MOCK_MEMO, [], // erc20AmountRecipients
|
|
203
|
+
mocks_test_1.MOCK_NFT_AMOUNT_RECIPIENTS, mocks_test_1.MOCK_TRANSACTION_GAS_DETAILS_SERIALIZED_TYPE_2, mocks_test_1.MOCK_FEE_TOKEN_DETAILS, true);
|
|
204
|
+
expect(nftNoteSpy.called).to.be.true;
|
|
205
|
+
expect(nftNoteSpy.args.length).to.equal(2); // Number of calls (without broadcaster fees)
|
|
206
|
+
expect(nftNoteSpy.args[0][0].tokenSubID).to.equal('0x01'); // nft1
|
|
207
|
+
expect(nftNoteSpy.args[1][0].tokenSubID).to.equal('0x02'); // nft2
|
|
208
|
+
// Add 9000 for the dummy tx variance
|
|
209
|
+
expect(rsp.gasEstimate).to.equal(9000n + 200n);
|
|
210
|
+
}).timeout(10000);
|
|
211
|
+
it('Should error on gas estimates for invalid NFT transfer', async () => {
|
|
212
|
+
stubGasEstimateSuccess();
|
|
213
|
+
await expect((0, tx_transfer_1.gasEstimateForUnprovenTransfer)(shared_models_1.NetworkName.Hardhat, matrixWallet.id, mocks_test_1.MOCK_DB_ENCRYPTION_KEY, mocks_test_1.MOCK_MEMO, [], // erc20AmountRecipients
|
|
214
|
+
MOCK_NFT_AMOUNT_RECIPIENTS_INVALID, mocks_test_1.MOCK_TRANSACTION_GAS_DETAILS_SERIALIZED_TYPE_2, mocks_test_1.MOCK_FEE_TOKEN_DETAILS, false)).rejectedWith('Invalid Matrix address.');
|
|
215
|
+
});
|
|
216
|
+
// TRANSFER ERC20 - PROVE AND SEND
|
|
217
|
+
it('Should populate tx for valid transfer', async () => {
|
|
218
|
+
stubGasEstimateSuccess();
|
|
219
|
+
(0, proof_cache_1.setCachedProvedTransaction)(undefined);
|
|
220
|
+
spyOnERC20Note();
|
|
221
|
+
spyOnNFTNote();
|
|
222
|
+
await (0, tx_proof_transfer_1.generateTransferProof)(shared_models_1.NetworkName.Hardhat, matrixWallet.id, mocks_test_1.MOCK_DB_ENCRYPTION_KEY, true, // showSenderAddressToRecipient
|
|
223
|
+
mocks_test_1.MOCK_MEMO, MOCK_TOKEN_AMOUNT_RECIPIENTS, mocks_test_1.MOCK_NFT_AMOUNT_RECIPIENTS, broadcasterFeeERC20AmountRecipient, false, // sendWithPublicWallet
|
|
224
|
+
overallBatchMinGasPrice, () => { });
|
|
225
|
+
expect(erc20NoteSpy.called).to.be.true;
|
|
226
|
+
expect(erc20NoteSpy.args[0][0].amount).to.equal(mocks_test_1.MOCK_TOKEN_FEE.amount);
|
|
227
|
+
expect(nftNoteSpy.called).to.be.true;
|
|
228
|
+
expect(nftNoteSpy.args[0][0].nftAddress).to.equal(mocks_test_1.MOCK_NFT_AMOUNT_RECIPIENTS[0].nftAddress);
|
|
229
|
+
const populateResponse = await (0, tx_transfer_1.populateProvedTransfer)(shared_models_1.NetworkName.Hardhat, matrixWallet.id, true, // showSenderAddressToRecipient
|
|
230
|
+
mocks_test_1.MOCK_MEMO, MOCK_TOKEN_AMOUNT_RECIPIENTS, mocks_test_1.MOCK_NFT_AMOUNT_RECIPIENTS, broadcasterFeeERC20AmountRecipient, false, // sendWithPublicWallet
|
|
231
|
+
overallBatchMinGasPrice, gasDetails);
|
|
232
|
+
expect(populateResponse.nullifiers).to.deep.equal([
|
|
233
|
+
'0x0000000000000000000000000000000000000000000000000000000000000001',
|
|
234
|
+
'0x0000000000000000000000000000000000000000000000000000000000000002',
|
|
235
|
+
]);
|
|
236
|
+
const { transaction } = populateResponse;
|
|
237
|
+
expect(transaction.nonce).to.equal(undefined);
|
|
238
|
+
expect(transaction.gasPrice?.toString()).to.equal('4096');
|
|
239
|
+
expect(transaction.gasLimit).to.equal(1200n);
|
|
240
|
+
expect(transaction.value?.toString()).to.equal(undefined);
|
|
241
|
+
expect(transaction.data).to.equal('0x0123');
|
|
242
|
+
expect(transaction.to).to.equal(undefined);
|
|
243
|
+
expect(transaction.chainId).to.equal(undefined);
|
|
244
|
+
expect(transaction.type).to.equal(1);
|
|
245
|
+
});
|
|
246
|
+
it('Should error on populate transfer tx for unproved transaction', async () => {
|
|
247
|
+
stubGasEstimateSuccess();
|
|
248
|
+
(0, proof_cache_1.setCachedProvedTransaction)(undefined);
|
|
249
|
+
await expect((0, tx_transfer_1.populateProvedTransfer)(shared_models_1.NetworkName.Hardhat, matrixWallet.id, false, // showSenderAddressToRecipient
|
|
250
|
+
mocks_test_1.MOCK_MEMO, MOCK_TOKEN_AMOUNT_RECIPIENTS, mocks_test_1.MOCK_NFT_AMOUNT_RECIPIENTS, broadcasterFeeERC20AmountRecipient, false, // sendWithPublicWallet
|
|
251
|
+
overallBatchMinGasPrice, gasDetails)).rejectedWith('Invalid proof for this transaction');
|
|
252
|
+
});
|
|
253
|
+
it('Should error on populate transfer tx when params changed (invalid cached proof)', async () => {
|
|
254
|
+
stubGasEstimateSuccess();
|
|
255
|
+
await (0, tx_proof_transfer_1.generateTransferProof)(shared_models_1.NetworkName.Hardhat, matrixWallet.id, mocks_test_1.MOCK_DB_ENCRYPTION_KEY, true, // showSenderAddressToRecipient
|
|
256
|
+
mocks_test_1.MOCK_MEMO, MOCK_TOKEN_AMOUNT_RECIPIENTS, mocks_test_1.MOCK_NFT_AMOUNT_RECIPIENTS, broadcasterFeeERC20AmountRecipient, false, // sendWithPublicWallet
|
|
257
|
+
overallBatchMinGasPrice, () => { });
|
|
258
|
+
await expect((0, tx_transfer_1.populateProvedTransfer)(shared_models_1.NetworkName.Hardhat, matrixWallet.id, true, // showSenderAddressToRecipient
|
|
259
|
+
mocks_test_1.MOCK_MEMO, MOCK_TOKEN_AMOUNT_RECIPIENTS_DIFFERENT, mocks_test_1.MOCK_NFT_AMOUNT_RECIPIENTS, broadcasterFeeERC20AmountRecipient, false, // sendWithPublicWallet
|
|
260
|
+
overallBatchMinGasPrice, gasDetails)).rejectedWith('Invalid proof for this transaction');
|
|
261
|
+
});
|
|
262
|
+
});
|
|
263
|
+
//# sourceMappingURL=tx-transfer.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tx-transfer.test.js","sourceRoot":"","sources":["../../../../src/services/transactions/__tests__/tx-transfer.test.ts"],"names":[],"mappings":"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","sourcesContent":["import chai from 'chai';\nimport chaiAsPromised from 'chai-as-promised';\nimport Sinon, { SinonStub, SinonSpy } from 'sinon';\nimport {\n MatrixWallet,\n TransactionBatch,\n TransactionStructV3,\n MatrixContracts,\n} from '@matrix-privacy/engine';\nimport {\n MatrixERC20Amount,\n NetworkName,\n EVMGasType,\n MatrixERC20AmountRecipient,\n MatrixNFTAmountRecipient,\n TransactionGasDetails,\n isDefined,\n} from '@matrix-privacy/shared-models';\nimport {\n closeTestEngine,\n initTestEngine,\n initTestEngineNetworks,\n} from '../../../tests/setup.test';\nimport {\n MOCK_BOUND_PARAMS_V3,\n MOCK_COMMITMENTS,\n MOCK_DB_ENCRYPTION_KEY,\n MOCK_ETH_WALLET_ADDRESS,\n MOCK_FEE_TOKEN_DETAILS,\n MOCK_MEMO,\n MOCK_MNEMONIC,\n MOCK_NFT_AMOUNT_RECIPIENTS,\n MOCK_NULLIFIERS,\n MOCK_MATRIX_WALLET_ADDRESS,\n MOCK_TOKEN_ADDRESS,\n MOCK_TOKEN_ADDRESS_2,\n MOCK_TOKEN_AMOUNTS,\n MOCK_TOKEN_FEE,\n MOCK_TRANSACTION_GAS_DETAILS_SERIALIZED_TYPE_2,\n} from '../../../tests/mocks.test';\nimport {\n populateProvedTransfer,\n gasEstimateForUnprovenTransfer,\n} from '../tx-transfer';\nimport * as txGasDetailsModule from '../tx-gas-details';\nimport { generateTransferProof } from '../tx-proof-transfer';\nimport {\n createMatrixWallet,\n fullWalletForID,\n} from '../../matrix/wallets/wallets';\nimport { setCachedProvedTransaction } from '../proof-cache';\nimport * as txNotes from '../tx-notes';\nimport { ContractTransaction, FallbackProvider } from 'ethers';\n\nlet gasEstimateStub: SinonStub;\nlet railProveStub: SinonStub;\nlet railDummyProveStub: SinonStub;\nlet railTransactStub: SinonStub;\nlet setUnshieldSpy: SinonSpy;\nlet erc20NoteSpy: SinonSpy;\nlet nftNoteSpy: SinonSpy;\n\nlet matrixWallet: MatrixWallet;\nlet broadcasterFeeERC20AmountRecipient: MatrixERC20AmountRecipient;\n\nchai.use(chaiAsPromised);\nconst { expect } = chai;\n\nconst MOCK_TOKEN_AMOUNTS_DIFFERENT: MatrixERC20Amount[] = [\n {\n tokenAddress: MOCK_TOKEN_ADDRESS,\n amount: 100n,\n },\n {\n tokenAddress: MOCK_TOKEN_ADDRESS_2,\n amount: 300n,\n },\n];\n\nconst overallBatchMinGasPrice = BigInt('0x1000');\n\nconst gasDetails: TransactionGasDetails = {\n evmGasType: EVMGasType.Type1,\n gasEstimate: 1000n,\n gasPrice: overallBatchMinGasPrice,\n};\n\nconst MOCK_TOKEN_AMOUNT_RECIPIENTS_INVALID: MatrixERC20AmountRecipient[] =\n MOCK_TOKEN_AMOUNTS.map(erc20Amount => ({\n ...erc20Amount,\n recipientAddress: MOCK_ETH_WALLET_ADDRESS,\n }));\n\nconst MOCK_NFT_AMOUNT_RECIPIENTS_INVALID: MatrixNFTAmountRecipient[] =\n MOCK_NFT_AMOUNT_RECIPIENTS.map(nftAmountRecipient => ({\n ...nftAmountRecipient,\n recipientAddress: MOCK_ETH_WALLET_ADDRESS,\n }));\n\nconst MOCK_TOKEN_AMOUNT_RECIPIENTS: MatrixERC20AmountRecipient[] =\n MOCK_TOKEN_AMOUNTS.map(erc20Amount => ({\n ...erc20Amount,\n recipientAddress: MOCK_MATRIX_WALLET_ADDRESS,\n }));\n\nconst MOCK_TOKEN_AMOUNT_RECIPIENTS_DIFFERENT: MatrixERC20AmountRecipient[] =\n MOCK_TOKEN_AMOUNTS_DIFFERENT.map(erc20Amount => ({\n ...erc20Amount,\n recipientAddress: MOCK_ETH_WALLET_ADDRESS,\n }));\n\nconst stubGasEstimateSuccess = () => {\n gasEstimateStub = Sinon.stub(txGasDetailsModule, 'getGasEstimate').resolves(\n BigInt('200'),\n );\n};\n\nconst stubGasEstimateFailure = () => {\n gasEstimateStub = Sinon.stub(txGasDetailsModule, 'getGasEstimate').rejects(\n new Error('test rejection - gas estimate'),\n );\n};\n\nconst spyOnERC20Note = () => {\n erc20NoteSpy = Sinon.spy(txNotes, 'erc20NoteFromERC20AmountRecipient');\n};\n\nconst spyOnNFTNote = () => {\n nftNoteSpy = Sinon.spy(txNotes, 'nftNoteFromNFTAmountRecipient');\n};\n\ndescribe('tx-transfer', () => {\n before(async function run() {\n this.timeout(60_000);\n await initTestEngine();\n await initTestEngineNetworks();\n const matrixWalletInfo = await createMatrixWallet(\n MOCK_DB_ENCRYPTION_KEY,\n MOCK_MNEMONIC,\n undefined, // creationBlockNumbers\n );\n if (!isDefined(matrixWalletInfo)) {\n throw new Error('Expected matrixWalletInfo');\n }\n matrixWallet = fullWalletForID(matrixWalletInfo.id);\n\n const broadcasterWalletInfo = await createMatrixWallet(\n MOCK_DB_ENCRYPTION_KEY,\n MOCK_MNEMONIC,\n undefined, // creationBlockNumbers\n );\n if (!isDefined(broadcasterWalletInfo)) {\n throw new Error('Expected broadcasterWalletInfo');\n }\n\n const broadcasterMatrixAddress = broadcasterWalletInfo.matrixAddress;\n\n broadcasterFeeERC20AmountRecipient = {\n ...MOCK_TOKEN_FEE,\n recipientAddress: broadcasterMatrixAddress,\n };\n\n railProveStub = Sinon.stub(\n TransactionBatch.prototype,\n 'generateTransactions',\n ).resolves({\n provedTransactions: [\n {\n nullifiers: MOCK_NULLIFIERS,\n },\n ] as (TransactionStructV3)[],\n });\n railDummyProveStub = Sinon.stub(\n TransactionBatch.prototype,\n 'generateDummyTransactions',\n ).resolves([\n {\n commitments: MOCK_COMMITMENTS,\n boundParams: MOCK_BOUND_PARAMS_V3,\n nullifiers: MOCK_NULLIFIERS,\n },\n ] as (TransactionStructV3)[]);\n railTransactStub = Sinon.stub(\n MatrixContracts,\n 'generateTransact',\n ).resolves({ data: '0x0123' } as ContractTransaction);\n });\n afterEach(() => {\n gasEstimateStub?.restore();\n setUnshieldSpy?.restore();\n erc20NoteSpy?.restore();\n nftNoteSpy?.restore();\n });\n after(async () => {\n railProveStub.restore();\n railDummyProveStub.restore();\n railTransactStub.restore();\n await closeTestEngine();\n });\n\n // TRANSFER ERC20 - GAS ESTIMATE\n\n it('Should get gas estimates for valid erc20 transfer', async () => {\n stubGasEstimateSuccess();\n spyOnERC20Note();\n const rsp = await gasEstimateForUnprovenTransfer(\n NetworkName.Hardhat,\n matrixWallet.id,\n MOCK_DB_ENCRYPTION_KEY,\n MOCK_MEMO,\n MOCK_TOKEN_AMOUNT_RECIPIENTS,\n [], // nftAmountRecipients\n MOCK_TRANSACTION_GAS_DETAILS_SERIALIZED_TYPE_2,\n MOCK_FEE_TOKEN_DETAILS,\n false, // sendWithPublicWallet\n );\n expect(erc20NoteSpy.called).to.be.true;\n expect(erc20NoteSpy.args.length).to.equal(6); // Number of calls - 3 for each of 2 broadcaster fee iterations\n expect(erc20NoteSpy.args[0][0].amount).to.equal(BigInt('0x00')); // original broadcaster fee\n expect(erc20NoteSpy.args[1][0].amount).to.equal(BigInt('0x100')); // token1\n expect(erc20NoteSpy.args[2][0].amount).to.equal(BigInt('0x200')); // token2\n expect(erc20NoteSpy.args[3][0].amount).to.equal(\n BigInt('0x0275a61bf8737eb4'),\n ); // New estimated Broadcaster Fee\n expect(erc20NoteSpy.args[4][0].amount).to.equal(BigInt('0x100')); // token1\n expect(erc20NoteSpy.args[5][0].amount).to.equal(BigInt('0x200')); // token2\n // Add 9000 for the dummy tx variance\n expect(rsp.gasEstimate).to.equal(9000n + 200n);\n }).timeout(10_000);\n\n it('Should get gas estimates for valid erc20 transfer: public wallet', async () => {\n stubGasEstimateSuccess();\n spyOnERC20Note();\n const rsp = await gasEstimateForUnprovenTransfer(\n NetworkName.Hardhat,\n matrixWallet.id,\n MOCK_DB_ENCRYPTION_KEY,\n MOCK_MEMO,\n MOCK_TOKEN_AMOUNT_RECIPIENTS,\n [], // nftAmountRecipients\n MOCK_TRANSACTION_GAS_DETAILS_SERIALIZED_TYPE_2,\n MOCK_FEE_TOKEN_DETAILS,\n true, // sendWithPublicWallet\n );\n expect(erc20NoteSpy.called).to.be.true;\n expect(erc20NoteSpy.args.length).to.equal(2); // Number of calls (without broadcaster fees)\n expect(erc20NoteSpy.args[0][0].amount).to.equal(BigInt('0x100')); // token1\n expect(erc20NoteSpy.args[1][0].amount).to.equal(BigInt('0x200')); // token2\n // Add 9000 for the dummy tx variance\n expect(rsp.gasEstimate).to.equal(9000n + 200n);\n }).timeout(10_000);\n\n it('Should error on gas estimates for invalid erc20 transfer', async () => {\n stubGasEstimateSuccess();\n await expect(\n gasEstimateForUnprovenTransfer(\n NetworkName.Hardhat,\n matrixWallet.id,\n MOCK_DB_ENCRYPTION_KEY,\n MOCK_MEMO,\n MOCK_TOKEN_AMOUNT_RECIPIENTS_INVALID,\n [], // nftAmountRecipients\n MOCK_TRANSACTION_GAS_DETAILS_SERIALIZED_TYPE_2,\n MOCK_FEE_TOKEN_DETAILS,\n false, // sendWithPublicWallet\n ),\n ).rejectedWith('Invalid Matrix address.');\n });\n\n it('Should error on transfer gas estimate for ethers rejections', async () => {\n stubGasEstimateFailure();\n await expect(\n gasEstimateForUnprovenTransfer(\n NetworkName.Hardhat,\n matrixWallet.id,\n MOCK_DB_ENCRYPTION_KEY,\n MOCK_MEMO,\n MOCK_TOKEN_AMOUNT_RECIPIENTS,\n [], // nftAmountRecipients\n MOCK_TRANSACTION_GAS_DETAILS_SERIALIZED_TYPE_2,\n MOCK_FEE_TOKEN_DETAILS,\n false, // sendWithPublicWallet\n ),\n ).rejectedWith('test rejection - gas estimate');\n });\n\n // TRANSFER NFT - GAS ESTIMATE\n\n it('Should get gas estimates for valid NFT transfer', async () => {\n stubGasEstimateSuccess();\n spyOnNFTNote();\n const rsp = await gasEstimateForUnprovenTransfer(\n NetworkName.Hardhat,\n matrixWallet.id,\n MOCK_DB_ENCRYPTION_KEY,\n MOCK_MEMO,\n [], // erc20AmountRecipients\n MOCK_NFT_AMOUNT_RECIPIENTS, // nftAmountRecipients\n MOCK_TRANSACTION_GAS_DETAILS_SERIALIZED_TYPE_2,\n MOCK_FEE_TOKEN_DETAILS,\n false, // sendWithPublicWallet\n );\n expect(nftNoteSpy.called).to.be.true;\n expect(nftNoteSpy.args.length).to.equal(4); // Number of calls - 2 for each of 2 broadcaster fee iterations\n expect(nftNoteSpy.args[0][0].tokenSubID).to.equal('0x01'); // nft1\n expect(nftNoteSpy.args[1][0].tokenSubID).to.equal('0x02'); // nft2\n expect(nftNoteSpy.args[2][0].tokenSubID).to.equal('0x01'); // nft1\n expect(nftNoteSpy.args[3][0].tokenSubID).to.equal('0x02'); // nft2\n // Add 9000 for the dummy tx variance\n expect(rsp.gasEstimate).to.equal(9000n + 200n);\n }).timeout(10_000);\n\n it('Should get gas estimates for valid NFT transfer: public wallet', async () => {\n stubGasEstimateSuccess();\n spyOnNFTNote();\n const rsp = await gasEstimateForUnprovenTransfer(\n NetworkName.Hardhat,\n matrixWallet.id,\n MOCK_DB_ENCRYPTION_KEY,\n MOCK_MEMO,\n [], // erc20AmountRecipients\n MOCK_NFT_AMOUNT_RECIPIENTS,\n MOCK_TRANSACTION_GAS_DETAILS_SERIALIZED_TYPE_2,\n MOCK_FEE_TOKEN_DETAILS,\n true, // sendWithPublicWallet\n );\n expect(nftNoteSpy.called).to.be.true;\n expect(nftNoteSpy.args.length).to.equal(2); // Number of calls (without broadcaster fees)\n expect(nftNoteSpy.args[0][0].tokenSubID).to.equal('0x01'); // nft1\n expect(nftNoteSpy.args[1][0].tokenSubID).to.equal('0x02'); // nft2\n // Add 9000 for the dummy tx variance\n expect(rsp.gasEstimate).to.equal(9000n + 200n);\n }).timeout(10_000);\n\n it('Should error on gas estimates for invalid NFT transfer', async () => {\n stubGasEstimateSuccess();\n await expect(\n gasEstimateForUnprovenTransfer(\n NetworkName.Hardhat,\n matrixWallet.id,\n MOCK_DB_ENCRYPTION_KEY,\n MOCK_MEMO,\n [], // erc20AmountRecipients\n MOCK_NFT_AMOUNT_RECIPIENTS_INVALID,\n MOCK_TRANSACTION_GAS_DETAILS_SERIALIZED_TYPE_2,\n MOCK_FEE_TOKEN_DETAILS,\n false, // sendWithPublicWallet\n ),\n ).rejectedWith('Invalid Matrix address.');\n });\n\n // TRANSFER ERC20 - PROVE AND SEND\n\n it('Should populate tx for valid transfer', async () => {\n stubGasEstimateSuccess();\n setCachedProvedTransaction(undefined);\n spyOnERC20Note();\n spyOnNFTNote();\n await generateTransferProof(\n NetworkName.Hardhat,\n matrixWallet.id,\n MOCK_DB_ENCRYPTION_KEY,\n true, // showSenderAddressToRecipient\n MOCK_MEMO,\n MOCK_TOKEN_AMOUNT_RECIPIENTS,\n MOCK_NFT_AMOUNT_RECIPIENTS,\n broadcasterFeeERC20AmountRecipient,\n false, // sendWithPublicWallet\n overallBatchMinGasPrice,\n () => {}, // progressCallback\n );\n expect(erc20NoteSpy.called).to.be.true;\n expect(erc20NoteSpy.args[0][0].amount).to.equal(MOCK_TOKEN_FEE.amount);\n expect(nftNoteSpy.called).to.be.true;\n expect(nftNoteSpy.args[0][0].nftAddress).to.equal(\n MOCK_NFT_AMOUNT_RECIPIENTS[0].nftAddress,\n );\n const populateResponse = await populateProvedTransfer(\n NetworkName.Hardhat,\n matrixWallet.id,\n true, // showSenderAddressToRecipient\n MOCK_MEMO,\n MOCK_TOKEN_AMOUNT_RECIPIENTS,\n MOCK_NFT_AMOUNT_RECIPIENTS,\n broadcasterFeeERC20AmountRecipient,\n false, // sendWithPublicWallet\n overallBatchMinGasPrice,\n gasDetails,\n );\n expect(populateResponse.nullifiers).to.deep.equal([\n '0x0000000000000000000000000000000000000000000000000000000000000001',\n '0x0000000000000000000000000000000000000000000000000000000000000002',\n ]);\n\n const { transaction } = populateResponse;\n\n expect(transaction.nonce).to.equal(undefined);\n expect(transaction.gasPrice?.toString()).to.equal('4096');\n expect(transaction.gasLimit).to.equal(1200n);\n expect(transaction.value?.toString()).to.equal(undefined);\n expect(transaction.data).to.equal('0x0123');\n expect(transaction.to).to.equal(undefined);\n expect(transaction.chainId).to.equal(undefined);\n expect(transaction.type).to.equal(1);\n });\n\n it('Should error on populate transfer tx for unproved transaction', async () => {\n stubGasEstimateSuccess();\n setCachedProvedTransaction(undefined);\n await expect(\n populateProvedTransfer(\n NetworkName.Hardhat,\n matrixWallet.id,\n false, // showSenderAddressToRecipient\n MOCK_MEMO,\n MOCK_TOKEN_AMOUNT_RECIPIENTS,\n MOCK_NFT_AMOUNT_RECIPIENTS,\n broadcasterFeeERC20AmountRecipient,\n false, // sendWithPublicWallet\n overallBatchMinGasPrice,\n gasDetails,\n ),\n ).rejectedWith('Invalid proof for this transaction');\n });\n\n it('Should error on populate transfer tx when params changed (invalid cached proof)', async () => {\n stubGasEstimateSuccess();\n await generateTransferProof(\n NetworkName.Hardhat,\n matrixWallet.id,\n MOCK_DB_ENCRYPTION_KEY,\n true, // showSenderAddressToRecipient\n MOCK_MEMO,\n MOCK_TOKEN_AMOUNT_RECIPIENTS,\n MOCK_NFT_AMOUNT_RECIPIENTS,\n broadcasterFeeERC20AmountRecipient,\n false, // sendWithPublicWallet\n overallBatchMinGasPrice,\n () => {}, // progressCallback\n );\n await expect(\n populateProvedTransfer(\n NetworkName.Hardhat,\n matrixWallet.id,\n true, // showSenderAddressToRecipient\n MOCK_MEMO,\n MOCK_TOKEN_AMOUNT_RECIPIENTS_DIFFERENT,\n MOCK_NFT_AMOUNT_RECIPIENTS,\n broadcasterFeeERC20AmountRecipient,\n false, // sendWithPublicWallet\n overallBatchMinGasPrice,\n gasDetails,\n ),\n ).rejectedWith('Invalid proof for this transaction');\n });\n});\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|