@btc-vision/bitcoin 7.0.0-alpha.0 → 7.0.0-alpha.2
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/browser/address.d.ts +6 -2
- package/browser/address.d.ts.map +1 -1
- package/browser/block.d.ts.map +1 -1
- package/browser/branded.d.ts +3 -14
- package/browser/branded.d.ts.map +1 -1
- package/browser/crypto.d.ts +1 -1
- package/browser/ecc/context.d.ts +4 -4
- package/browser/ecc/context.d.ts.map +1 -1
- package/browser/ecc/types.d.ts +1 -1
- package/browser/ecc/types.d.ts.map +1 -1
- package/browser/index.d.ts +3 -2
- package/browser/index.d.ts.map +1 -1
- package/browser/index.js +3579 -3539
- package/browser/io/BinaryReader.d.ts +15 -15
- package/browser/io/BinaryReader.d.ts.map +1 -1
- package/browser/io/BinaryWriter.d.ts +17 -17
- package/browser/io/BinaryWriter.d.ts.map +1 -1
- package/browser/io/MemoryPool.d.ts +20 -20
- package/browser/io/MemoryPool.d.ts.map +1 -1
- package/browser/opcodes.d.ts +11 -0
- package/browser/opcodes.d.ts.map +1 -1
- package/browser/payments/bip341.d.ts +1 -1
- package/browser/payments/bip341.d.ts.map +1 -1
- package/browser/payments/embed.d.ts +1 -1
- package/browser/payments/embed.d.ts.map +1 -1
- package/browser/payments/p2ms.d.ts.map +1 -1
- package/browser/payments/p2op.d.ts +1 -1
- package/browser/payments/p2op.d.ts.map +1 -1
- package/browser/payments/p2pk.d.ts +1 -1
- package/browser/payments/p2pk.d.ts.map +1 -1
- package/browser/payments/p2pkh.d.ts +1 -1
- package/browser/payments/p2pkh.d.ts.map +1 -1
- package/browser/payments/p2sh.d.ts.map +1 -1
- package/browser/payments/p2tr.d.ts +2 -2
- package/browser/payments/p2tr.d.ts.map +1 -1
- package/browser/payments/p2wpkh.d.ts +1 -1
- package/browser/payments/p2wpkh.d.ts.map +1 -1
- package/browser/payments/p2wsh.d.ts.map +1 -1
- package/browser/payments/types.d.ts +1 -1
- package/browser/payments/types.d.ts.map +1 -1
- package/browser/psbt/PsbtCache.d.ts +54 -0
- package/browser/psbt/PsbtCache.d.ts.map +1 -0
- package/browser/psbt/PsbtFinalizer.d.ts +21 -0
- package/browser/psbt/PsbtFinalizer.d.ts.map +1 -0
- package/browser/psbt/PsbtSigner.d.ts +32 -0
- package/browser/psbt/PsbtSigner.d.ts.map +1 -0
- package/browser/psbt/PsbtTransaction.d.ts +25 -0
- package/browser/psbt/PsbtTransaction.d.ts.map +1 -0
- package/browser/psbt/bip371.d.ts.map +1 -1
- package/browser/psbt/types.d.ts +14 -14
- package/browser/psbt/types.d.ts.map +1 -1
- package/browser/psbt/validation.d.ts +1 -1
- package/browser/psbt/validation.d.ts.map +1 -1
- package/browser/psbt.d.ts +27 -39
- package/browser/psbt.d.ts.map +1 -1
- package/browser/script.d.ts.map +1 -1
- package/browser/transaction.d.ts +4 -4
- package/browser/transaction.d.ts.map +1 -1
- package/browser/types.d.ts +4 -2
- package/browser/types.d.ts.map +1 -1
- package/browser/workers/WorkerSigningPool.d.ts +17 -17
- package/browser/workers/WorkerSigningPool.d.ts.map +1 -1
- package/browser/workers/WorkerSigningPool.node.d.ts +12 -12
- package/browser/workers/WorkerSigningPool.node.d.ts.map +1 -1
- package/browser/workers/index.d.ts +3 -50
- package/browser/workers/index.d.ts.map +1 -1
- package/browser/workers/index.node.d.ts +24 -0
- package/browser/workers/index.node.d.ts.map +1 -0
- package/browser/workers/psbt-parallel.d.ts +1 -1
- package/browser/workers/psbt-parallel.d.ts.map +1 -1
- package/browser/workers/types.d.ts.map +1 -1
- package/build/address.d.ts +6 -2
- package/build/address.d.ts.map +1 -1
- package/build/address.js +32 -19
- package/build/address.js.map +1 -1
- package/build/block.d.ts.map +1 -1
- package/build/block.js +2 -4
- package/build/block.js.map +1 -1
- package/build/branded.d.ts +3 -14
- package/build/branded.d.ts.map +1 -1
- package/build/branded.js +0 -5
- package/build/branded.js.map +1 -1
- package/build/crypto.d.ts +1 -1
- package/build/ecc/context.d.ts +4 -4
- package/build/ecc/context.d.ts.map +1 -1
- package/build/ecc/context.js +75 -52
- package/build/ecc/context.js.map +1 -1
- package/build/ecc/types.d.ts +1 -1
- package/build/ecc/types.d.ts.map +1 -1
- package/build/index.d.ts +3 -2
- package/build/index.d.ts.map +1 -1
- package/build/index.js +3 -3
- package/build/index.js.map +1 -1
- package/build/io/BinaryReader.d.ts +15 -15
- package/build/io/BinaryReader.d.ts.map +1 -1
- package/build/io/BinaryReader.js +17 -17
- package/build/io/BinaryReader.js.map +1 -1
- package/build/io/BinaryWriter.d.ts +17 -17
- package/build/io/BinaryWriter.d.ts.map +1 -1
- package/build/io/BinaryWriter.js +39 -39
- package/build/io/BinaryWriter.js.map +1 -1
- package/build/io/MemoryPool.d.ts +20 -20
- package/build/io/MemoryPool.d.ts.map +1 -1
- package/build/io/MemoryPool.js +28 -28
- package/build/io/MemoryPool.js.map +1 -1
- package/build/opcodes.d.ts +11 -0
- package/build/opcodes.d.ts.map +1 -1
- package/build/opcodes.js +19 -4
- package/build/opcodes.js.map +1 -1
- package/build/payments/bip341.d.ts +1 -2
- package/build/payments/bip341.d.ts.map +1 -1
- package/build/payments/bip341.js +1 -2
- package/build/payments/bip341.js.map +1 -1
- package/build/payments/embed.d.ts +1 -1
- package/build/payments/embed.d.ts.map +1 -1
- package/build/payments/embed.js +14 -14
- package/build/payments/embed.js.map +1 -1
- package/build/payments/p2ms.d.ts.map +1 -1
- package/build/payments/p2ms.js +21 -21
- package/build/payments/p2ms.js.map +1 -1
- package/build/payments/p2op.d.ts +1 -1
- package/build/payments/p2op.d.ts.map +1 -1
- package/build/payments/p2op.js +18 -18
- package/build/payments/p2op.js.map +1 -1
- package/build/payments/p2pk.d.ts +1 -1
- package/build/payments/p2pk.d.ts.map +1 -1
- package/build/payments/p2pk.js +17 -17
- package/build/payments/p2pk.js.map +1 -1
- package/build/payments/p2pkh.d.ts +1 -1
- package/build/payments/p2pkh.d.ts.map +1 -1
- package/build/payments/p2pkh.js +20 -20
- package/build/payments/p2pkh.js.map +1 -1
- package/build/payments/p2sh.d.ts.map +1 -1
- package/build/payments/p2sh.js +22 -20
- package/build/payments/p2sh.js.map +1 -1
- package/build/payments/p2tr.d.ts +2 -2
- package/build/payments/p2tr.d.ts.map +1 -1
- package/build/payments/p2tr.js +23 -23
- package/build/payments/p2tr.js.map +1 -1
- package/build/payments/p2wpkh.d.ts +1 -1
- package/build/payments/p2wpkh.d.ts.map +1 -1
- package/build/payments/p2wpkh.js +20 -20
- package/build/payments/p2wpkh.js.map +1 -1
- package/build/payments/p2wsh.d.ts.map +1 -1
- package/build/payments/p2wsh.js +22 -22
- package/build/payments/p2wsh.js.map +1 -1
- package/build/payments/types.d.ts +1 -1
- package/build/payments/types.d.ts.map +1 -1
- package/build/psbt/PsbtCache.d.ts +54 -0
- package/build/psbt/PsbtCache.d.ts.map +1 -0
- package/build/psbt/PsbtCache.js +249 -0
- package/build/psbt/PsbtCache.js.map +1 -0
- package/build/psbt/PsbtFinalizer.d.ts +21 -0
- package/build/psbt/PsbtFinalizer.d.ts.map +1 -0
- package/build/psbt/PsbtFinalizer.js +157 -0
- package/build/psbt/PsbtFinalizer.js.map +1 -0
- package/build/psbt/PsbtSigner.d.ts +32 -0
- package/build/psbt/PsbtSigner.d.ts.map +1 -0
- package/build/psbt/PsbtSigner.js +192 -0
- package/build/psbt/PsbtSigner.js.map +1 -0
- package/build/psbt/PsbtTransaction.d.ts +25 -0
- package/build/psbt/PsbtTransaction.d.ts.map +1 -0
- package/build/psbt/PsbtTransaction.js +61 -0
- package/build/psbt/PsbtTransaction.js.map +1 -0
- package/build/psbt/bip371.d.ts.map +1 -1
- package/build/psbt/bip371.js +6 -2
- package/build/psbt/bip371.js.map +1 -1
- package/build/psbt/psbtutils.js +1 -1
- package/build/psbt/psbtutils.js.map +1 -1
- package/build/psbt/types.d.ts +14 -14
- package/build/psbt/types.d.ts.map +1 -1
- package/build/psbt/validation.d.ts +1 -1
- package/build/psbt/validation.d.ts.map +1 -1
- package/build/psbt/validation.js +1 -1
- package/build/psbt/validation.js.map +1 -1
- package/build/psbt.d.ts +27 -39
- package/build/psbt.d.ts.map +1 -1
- package/build/psbt.js +142 -755
- package/build/psbt.js.map +1 -1
- package/build/script.d.ts.map +1 -1
- package/build/script.js +4 -4
- package/build/script.js.map +1 -1
- package/build/transaction.d.ts +4 -4
- package/build/transaction.d.ts.map +1 -1
- package/build/transaction.js +6 -5
- package/build/transaction.js.map +1 -1
- package/build/tsconfig.build.tsbuildinfo +1 -1
- package/build/types.d.ts +4 -2
- package/build/types.d.ts.map +1 -1
- package/build/types.js +12 -9
- package/build/types.js.map +1 -1
- package/build/workers/WorkerSigningPool.d.ts +17 -17
- package/build/workers/WorkerSigningPool.d.ts.map +1 -1
- package/build/workers/WorkerSigningPool.js +25 -25
- package/build/workers/WorkerSigningPool.js.map +1 -1
- package/build/workers/WorkerSigningPool.node.d.ts +12 -12
- package/build/workers/WorkerSigningPool.node.d.ts.map +1 -1
- package/build/workers/WorkerSigningPool.node.js +23 -23
- package/build/workers/WorkerSigningPool.node.js.map +1 -1
- package/build/workers/index.d.ts +3 -3
- package/build/workers/index.d.ts.map +1 -1
- package/build/workers/index.js +0 -3
- package/build/workers/index.js.map +1 -1
- package/build/workers/index.node.d.ts +24 -0
- package/build/workers/index.node.d.ts.map +1 -0
- package/build/workers/index.node.js +26 -0
- package/build/workers/index.node.js.map +1 -0
- package/build/workers/psbt-parallel.d.ts +1 -1
- package/build/workers/psbt-parallel.d.ts.map +1 -1
- package/build/workers/psbt-parallel.js.map +1 -1
- package/build/workers/types.d.ts.map +1 -1
- package/build/workers/types.js.map +1 -1
- package/package.json +30 -10
- package/src/address.ts +53 -21
- package/src/block.ts +15 -8
- package/src/branded.ts +15 -13
- package/src/crypto.ts +1 -1
- package/src/ecc/context.ts +85 -64
- package/src/ecc/types.ts +1 -8
- package/src/index.ts +48 -14
- package/src/io/BinaryReader.ts +18 -18
- package/src/io/BinaryWriter.ts +43 -43
- package/src/io/MemoryPool.ts +32 -32
- package/src/opcodes.ts +21 -4
- package/src/payments/bip341.ts +2 -4
- package/src/payments/embed.ts +18 -18
- package/src/payments/p2ms.ts +32 -25
- package/src/payments/p2op.ts +22 -22
- package/src/payments/p2pk.ts +20 -20
- package/src/payments/p2pkh.ts +25 -25
- package/src/payments/p2sh.ts +30 -27
- package/src/payments/p2tr.ts +31 -31
- package/src/payments/p2wpkh.ts +25 -25
- package/src/payments/p2wsh.ts +27 -27
- package/src/payments/types.ts +1 -1
- package/src/psbt/PsbtCache.ts +325 -0
- package/src/psbt/PsbtFinalizer.ts +213 -0
- package/src/psbt/PsbtSigner.ts +302 -0
- package/src/psbt/PsbtTransaction.ts +82 -0
- package/src/psbt/bip371.ts +7 -3
- package/src/psbt/psbtutils.ts +1 -1
- package/src/psbt/types.ts +14 -21
- package/src/psbt/validation.ts +5 -12
- package/src/psbt.ts +363 -1130
- package/src/script.ts +6 -9
- package/src/transaction.ts +18 -14
- package/src/types.ts +28 -17
- package/src/workers/WorkerSigningPool.node.ts +31 -31
- package/src/workers/WorkerSigningPool.ts +35 -39
- package/src/workers/index.node.ts +27 -0
- package/src/workers/index.ts +7 -9
- package/src/workers/psbt-parallel.ts +2 -7
- package/src/workers/types.ts +5 -1
- package/test/address.spec.ts +2 -2
- package/test/bitcoin.core.spec.ts +5 -2
- package/test/browser/payments.spec.ts +151 -0
- package/test/browser/psbt.spec.ts +1510 -0
- package/test/browser/script.spec.ts +223 -0
- package/test/browser/setup.ts +13 -0
- package/test/browser/workers-signing.spec.ts +537 -0
- package/test/crypto.spec.ts +2 -2
- package/test/fixtures/core/base58_encode_decode.json +12 -48
- package/test/fixtures/core/base58_keys_invalid.json +50 -150
- package/test/fixtures/core/sighash.json +1 -3
- package/test/fixtures/core/tx_valid.json +133 -501
- package/test/fixtures/embed.json +3 -11
- package/test/fixtures/p2ms.json +21 -91
- package/test/fixtures/p2pk.json +5 -24
- package/test/fixtures/p2pkh.json +7 -36
- package/test/fixtures/p2sh.json +8 -54
- package/test/fixtures/p2tr.json +2 -6
- package/test/fixtures/p2wpkh.json +7 -36
- package/test/fixtures/p2wsh.json +14 -59
- package/test/fixtures/psbt.json +2 -6
- package/test/fixtures/script.json +12 -48
- package/test/integration/addresses.spec.ts +11 -5
- package/test/integration/bip32.spec.ts +1 -1
- package/test/integration/cltv.spec.ts +10 -6
- package/test/integration/csv.spec.ts +10 -9
- package/test/integration/payments.spec.ts +8 -4
- package/test/integration/taproot.spec.ts +26 -6
- package/test/integration/transactions.spec.ts +22 -8
- package/test/payments.spec.ts +1 -1
- package/test/payments.utils.ts +1 -1
- package/test/psbt.spec.ts +250 -64
- package/test/script_signature.spec.ts +1 -1
- package/test/transaction.spec.ts +18 -5
- package/test/tsconfig.json +6 -20
- package/test/workers-pool.spec.ts +22 -23
- package/test/workers-signing.spec.ts +7 -3
- package/test/workers.spec.ts +6 -7
- package/typedoc.json +39 -0
- package/vitest.config.browser.ts +68 -0
- package/browser/ecpair.d.ts +0 -99
- package/src/ecpair.d.ts +0 -99
- package/test/taproot-cache.spec.ts +0 -694
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Browser-adapted version of test/payments.spec.ts
|
|
3
|
+
* Replaces fs.readFileSync with static JSON imports.
|
|
4
|
+
*/
|
|
5
|
+
import assert from 'assert';
|
|
6
|
+
import * as ecc from 'tiny-secp256k1';
|
|
7
|
+
import { beforeEach, describe, it } from 'vitest';
|
|
8
|
+
import type { EccLib } from '../../src/index.js';
|
|
9
|
+
import { initEccLib } from '../../src/index.js';
|
|
10
|
+
import type { P2SHPayment, PaymentCreator } from '../../src/payments/index.js';
|
|
11
|
+
import { p2pk, p2wsh } from '../../src/payments/index.js';
|
|
12
|
+
import * as u from '../payments.utils.js';
|
|
13
|
+
import { fromHex } from '../../src/io/index.js';
|
|
14
|
+
import type { PublicKey } from '../../src/types.js';
|
|
15
|
+
|
|
16
|
+
// Pre-load all payment modules synchronously-like at import time
|
|
17
|
+
import * as embedModule from '../../src/payments/embed.js';
|
|
18
|
+
import * as p2msModule from '../../src/payments/p2ms.js';
|
|
19
|
+
import * as p2pkModule from '../../src/payments/p2pk.js';
|
|
20
|
+
import * as p2pkhModule from '../../src/payments/p2pkh.js';
|
|
21
|
+
import * as p2shModule from '../../src/payments/p2sh.js';
|
|
22
|
+
import * as p2wpkhModule from '../../src/payments/p2wpkh.js';
|
|
23
|
+
import * as p2wshModule from '../../src/payments/p2wsh.js';
|
|
24
|
+
import * as p2trModule from '../../src/payments/p2tr.js';
|
|
25
|
+
|
|
26
|
+
// Static JSON imports instead of fs.readFileSync
|
|
27
|
+
import embedFixtures from '../fixtures/embed.json' with { type: 'json' };
|
|
28
|
+
import p2msFixtures from '../fixtures/p2ms.json' with { type: 'json' };
|
|
29
|
+
import p2pkFixtures from '../fixtures/p2pk.json' with { type: 'json' };
|
|
30
|
+
import p2pkhFixtures from '../fixtures/p2pkh.json' with { type: 'json' };
|
|
31
|
+
import p2shFixtures from '../fixtures/p2sh.json' with { type: 'json' };
|
|
32
|
+
import p2wpkhFixtures from '../fixtures/p2wpkh.json' with { type: 'json' };
|
|
33
|
+
import p2wshFixtures from '../fixtures/p2wsh.json' with { type: 'json' };
|
|
34
|
+
import p2trFixtures from '../fixtures/p2tr.json' with { type: 'json' };
|
|
35
|
+
|
|
36
|
+
const fixtureMap: Record<string, any> = {
|
|
37
|
+
embed: embedFixtures,
|
|
38
|
+
p2ms: p2msFixtures,
|
|
39
|
+
p2pk: p2pkFixtures,
|
|
40
|
+
p2pkh: p2pkhFixtures,
|
|
41
|
+
p2sh: p2shFixtures,
|
|
42
|
+
p2wpkh: p2wpkhFixtures,
|
|
43
|
+
p2wsh: p2wshFixtures,
|
|
44
|
+
p2tr: p2trFixtures,
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
const paymentModules: Record<string, { [key: string]: PaymentCreator }> = {
|
|
48
|
+
embed: embedModule as any,
|
|
49
|
+
p2ms: p2msModule as any,
|
|
50
|
+
p2pk: p2pkModule as any,
|
|
51
|
+
p2pkh: p2pkhModule as any,
|
|
52
|
+
p2sh: p2shModule as any,
|
|
53
|
+
p2wpkh: p2wpkhModule as any,
|
|
54
|
+
p2wsh: p2wshModule as any,
|
|
55
|
+
p2tr: p2trModule as any,
|
|
56
|
+
};
|
|
57
|
+
|
|
58
|
+
// Initialize ECC library at module load time
|
|
59
|
+
initEccLib(ecc as unknown as EccLib);
|
|
60
|
+
|
|
61
|
+
['embed', 'p2ms', 'p2pk', 'p2pkh', 'p2sh', 'p2wpkh', 'p2wsh', 'p2tr'].forEach((p) => {
|
|
62
|
+
describe(p, () => {
|
|
63
|
+
// Ensure ECC library is initialized before each test
|
|
64
|
+
beforeEach(() => {
|
|
65
|
+
initEccLib(ecc as unknown as EccLib);
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
const payment = paymentModules[p]!;
|
|
69
|
+
let fn: PaymentCreator;
|
|
70
|
+
if (p === 'embed') {
|
|
71
|
+
fn = payment['p2data']!;
|
|
72
|
+
} else {
|
|
73
|
+
fn = payment[p]!;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
const fixtures = fixtureMap[p];
|
|
77
|
+
fixtures.valid.forEach((f: any) => {
|
|
78
|
+
it(f.description + ' as expected', () => {
|
|
79
|
+
const args = u.preform(f.arguments);
|
|
80
|
+
const actual = fn(args, f.options);
|
|
81
|
+
|
|
82
|
+
u.equate(actual, f.expected, f.arguments);
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
it(f.description + ' as expected (no validation)', () => {
|
|
86
|
+
const args = u.preform(f.arguments);
|
|
87
|
+
const actual = fn(
|
|
88
|
+
args,
|
|
89
|
+
Object.assign({}, f.options, {
|
|
90
|
+
validate: false,
|
|
91
|
+
}),
|
|
92
|
+
);
|
|
93
|
+
|
|
94
|
+
u.equate(actual, f.expected, f.arguments);
|
|
95
|
+
});
|
|
96
|
+
});
|
|
97
|
+
|
|
98
|
+
if (p === 'p2sh') {
|
|
99
|
+
it('properly assembles nested p2wsh with names', () => {
|
|
100
|
+
const actual = fn({
|
|
101
|
+
redeem: p2wsh({
|
|
102
|
+
redeem: p2pk({
|
|
103
|
+
pubkey: fromHex(
|
|
104
|
+
'03e15819590382a9dd878f01e2f0cbce541564eb415e43b440472d883ecd283058',
|
|
105
|
+
) as PublicKey,
|
|
106
|
+
}),
|
|
107
|
+
}),
|
|
108
|
+
} as P2SHPayment);
|
|
109
|
+
assert.strictEqual(actual.address, '3MGbrbye4ttNUXM8WAvBFRKry4fkS9fjuw');
|
|
110
|
+
assert.strictEqual(actual.name, 'p2sh-p2wsh-p2pk');
|
|
111
|
+
assert.strictEqual(actual.redeem!.name, 'p2wsh-p2pk');
|
|
112
|
+
assert.strictEqual(actual.redeem!.redeem!.name, 'p2pk');
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
// cross-verify dynamically too
|
|
117
|
+
if (!fixtures.dynamic) return;
|
|
118
|
+
const { depends, details } = fixtures.dynamic;
|
|
119
|
+
|
|
120
|
+
details.forEach((f: any) => {
|
|
121
|
+
const detail = u.preform(f);
|
|
122
|
+
const disabled: any = {};
|
|
123
|
+
if (f.disabled)
|
|
124
|
+
f.disabled.forEach((k: string) => {
|
|
125
|
+
disabled[k] = true;
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
for (const key in depends) {
|
|
129
|
+
if (key in disabled) continue;
|
|
130
|
+
const dependencies = depends[key];
|
|
131
|
+
|
|
132
|
+
dependencies.forEach((dependency: any) => {
|
|
133
|
+
if (!Array.isArray(dependency)) dependency = [dependency];
|
|
134
|
+
|
|
135
|
+
const args = {};
|
|
136
|
+
dependency.forEach((d: any) => {
|
|
137
|
+
u.from(d, detail, args);
|
|
138
|
+
});
|
|
139
|
+
const expected = u.from(key, detail);
|
|
140
|
+
|
|
141
|
+
it(
|
|
142
|
+
f.description + ', ' + key + ' derives from ' + JSON.stringify(dependency),
|
|
143
|
+
() => {
|
|
144
|
+
u.equate(fn(args), expected);
|
|
145
|
+
},
|
|
146
|
+
);
|
|
147
|
+
});
|
|
148
|
+
}
|
|
149
|
+
});
|
|
150
|
+
});
|
|
151
|
+
});
|