@transia/ripple-binary-codec 1.4.6-alpha.9 → 2.5.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/dist/binary.d.ts +30 -16
- package/dist/binary.js +36 -16
- package/dist/binary.js.map +1 -1
- package/dist/enums/bytes.d.ts +1 -2
- package/dist/enums/bytes.js +3 -2
- package/dist/enums/bytes.js.map +1 -1
- package/dist/enums/constants.d.ts +1 -0
- package/dist/enums/constants.js +6 -5
- package/dist/enums/constants.js.map +1 -1
- package/dist/enums/definitions.json +1604 -969
- package/dist/enums/field.d.ts +1 -2
- package/dist/enums/field.js +1 -2
- package/dist/enums/field.js.map +1 -1
- package/dist/enums/index.d.ts +1 -2
- package/dist/enums/index.js +5 -27
- package/dist/enums/index.js.map +1 -1
- package/dist/enums/src/enums/definitions.json +1606 -971
- package/dist/enums/xrpl-definitions-base.d.ts +5 -3
- package/dist/enums/xrpl-definitions-base.js +26 -6
- package/dist/enums/xrpl-definitions-base.js.map +1 -1
- package/dist/enums/xrpl-definitions.d.ts +2 -1
- package/dist/enums/xrpl-definitions.js +2 -1
- package/dist/enums/xrpl-definitions.js.map +1 -1
- package/dist/hash-prefixes.d.ts +1 -2
- package/dist/hash-prefixes.js +8 -6
- package/dist/hash-prefixes.js.map +1 -1
- package/dist/hashes.d.ts +6 -7
- package/dist/hashes.js +6 -7
- package/dist/hashes.js.map +1 -1
- package/dist/index.d.ts +16 -11
- package/dist/index.js +53 -58
- package/dist/index.js.map +1 -1
- package/dist/ledger-hashes.d.ts +1 -2
- package/dist/ledger-hashes.js +11 -30
- package/dist/ledger-hashes.js.map +1 -1
- package/dist/quality.d.ts +3 -4
- package/dist/quality.js +10 -8
- package/dist/quality.js.map +1 -1
- package/dist/serdes/binary-parser.d.ts +2 -3
- package/dist/serdes/binary-parser.js +16 -32
- package/dist/serdes/binary-parser.js.map +1 -1
- package/dist/serdes/binary-serializer.d.ts +7 -8
- package/dist/serdes/binary-serializer.js +14 -37
- package/dist/serdes/binary-serializer.js.map +1 -1
- package/dist/shamap.d.ts +4 -5
- package/dist/shamap.js +5 -5
- package/dist/shamap.js.map +1 -1
- package/dist/src/binary.d.ts +106 -0
- package/dist/src/binary.js +154 -0
- package/dist/src/binary.js.map +1 -0
- package/dist/src/coretypes.d.ts +9 -0
- package/dist/src/coretypes.js +48 -0
- package/dist/src/coretypes.js.map +1 -0
- package/dist/src/enums/bytes.d.ts +25 -0
- package/dist/src/enums/bytes.js +65 -0
- package/dist/src/enums/bytes.js.map +1 -0
- package/dist/src/enums/constants.d.ts +5 -0
- package/dist/src/enums/constants.js +9 -0
- package/dist/src/enums/constants.js.map +1 -0
- package/dist/src/enums/definitions.json +3404 -0
- package/dist/src/enums/field.d.ts +28 -0
- package/dist/src/enums/field.js +58 -0
- package/dist/src/enums/field.js.map +1 -0
- package/dist/src/enums/index.d.ts +12 -0
- package/dist/src/enums/index.js +31 -0
- package/dist/src/enums/index.js.map +1 -0
- package/dist/src/enums/utils-renumber.d.ts +101 -0
- package/dist/src/enums/utils-renumber.js +127 -0
- package/dist/src/enums/utils-renumber.js.map +1 -0
- package/dist/src/enums/xrpl-definitions-base.d.ts +47 -0
- package/dist/src/enums/xrpl-definitions-base.js +83 -0
- package/dist/src/enums/xrpl-definitions-base.js.map +1 -0
- package/dist/src/enums/xrpl-definitions.d.ts +22 -0
- package/dist/src/enums/xrpl-definitions.js +30 -0
- package/dist/src/enums/xrpl-definitions.js.map +1 -0
- package/dist/src/hash-prefixes.d.ts +5 -0
- package/dist/src/hash-prefixes.js +43 -0
- package/dist/src/hash-prefixes.js.map +1 -0
- package/dist/src/hashes.d.ts +50 -0
- package/dist/src/hashes.js +76 -0
- package/dist/src/hashes.js.map +1 -0
- package/dist/src/index.d.ts +69 -0
- package/dist/src/index.js +134 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/ledger-hashes.d.ts +48 -0
- package/dist/src/ledger-hashes.js +141 -0
- package/dist/src/ledger-hashes.js.map +1 -0
- package/dist/src/quality.d.ts +21 -0
- package/dist/src/quality.js +42 -0
- package/dist/src/quality.js.map +1 -0
- package/dist/src/serdes/binary-parser.d.ts +100 -0
- package/dist/src/serdes/binary-parser.js +194 -0
- package/dist/src/serdes/binary-parser.js.map +1 -0
- package/dist/src/serdes/binary-serializer.d.ts +81 -0
- package/dist/src/serdes/binary-serializer.js +149 -0
- package/dist/src/serdes/binary-serializer.js.map +1 -0
- package/dist/src/shamap.d.ts +102 -0
- package/dist/src/shamap.js +172 -0
- package/dist/src/shamap.js.map +1 -0
- package/dist/src/types/account-id.d.ts +37 -0
- package/dist/src/types/account-id.js +73 -0
- package/dist/src/types/account-id.js.map +1 -0
- package/dist/src/types/amount.d.ts +92 -0
- package/dist/src/types/amount.js +292 -0
- package/dist/src/types/amount.js.map +1 -0
- package/dist/src/types/blob.d.ts +25 -0
- package/dist/src/types/blob.js +46 -0
- package/dist/src/types/blob.js.map +1 -0
- package/dist/src/types/currency.d.ts +30 -0
- package/dist/src/types/currency.js +131 -0
- package/dist/src/types/currency.js.map +1 -0
- package/dist/src/types/data.d.ts +104 -0
- package/dist/src/types/data.js +387 -0
- package/dist/src/types/data.js.map +1 -0
- package/dist/src/types/dataType.d.ts +94 -0
- package/dist/src/types/dataType.js +145 -0
- package/dist/src/types/dataType.js.map +1 -0
- package/dist/src/types/hash-128.d.ts +18 -0
- package/dist/src/types/hash-128.js +36 -0
- package/dist/src/types/hash-128.js.map +1 -0
- package/dist/src/types/hash-160.d.ts +12 -0
- package/dist/src/types/hash-160.js +23 -0
- package/dist/src/types/hash-160.js.map +1 -0
- package/dist/src/types/hash-192.d.ts +12 -0
- package/dist/src/types/hash-192.js +23 -0
- package/dist/src/types/hash-192.js.map +1 -0
- package/dist/src/types/hash-256.d.ts +12 -0
- package/dist/src/types/hash-256.js +20 -0
- package/dist/src/types/hash-256.js.map +1 -0
- package/dist/src/types/hash.d.ts +40 -0
- package/dist/src/types/hash.js +76 -0
- package/dist/src/types/hash.js.map +1 -0
- package/dist/src/types/index.d.ts +21 -0
- package/dist/src/types/index.js +72 -0
- package/dist/src/types/index.js.map +1 -0
- package/dist/src/types/issue.d.ts +49 -0
- package/dist/src/types/issue.js +107 -0
- package/dist/src/types/issue.js.map +1 -0
- package/dist/src/types/json.d.ts +169 -0
- package/dist/src/types/json.js +529 -0
- package/dist/src/types/json.js.map +1 -0
- package/dist/src/types/path-set.d.ts +37 -0
- package/dist/src/types/path-set.js +236 -0
- package/dist/src/types/path-set.js.map +1 -0
- package/dist/src/types/serialized-type.d.ts +117 -0
- package/dist/src/types/serialized-type.js +242 -0
- package/dist/src/types/serialized-type.js.map +1 -0
- package/dist/src/types/st-array.d.ts +32 -0
- package/dist/src/types/st-array.js +89 -0
- package/dist/src/types/st-array.js.map +1 -0
- package/dist/src/types/st-number.d.ts +55 -0
- package/dist/src/types/st-number.js +212 -0
- package/dist/src/types/st-number.js.map +1 -0
- package/dist/src/types/st-object.d.ts +33 -0
- package/dist/src/types/st-object.js +176 -0
- package/dist/src/types/st-object.js.map +1 -0
- package/dist/src/types/uint-16.d.ts +26 -0
- package/dist/src/types/uint-16.js +49 -0
- package/dist/src/types/uint-16.js.map +1 -0
- package/dist/src/types/uint-32.d.ts +26 -0
- package/dist/src/types/uint-32.js +54 -0
- package/dist/src/types/uint-32.js.map +1 -0
- package/dist/src/types/uint-64.d.ts +40 -0
- package/dist/src/types/uint-64.js +112 -0
- package/dist/src/types/uint-64.js.map +1 -0
- package/dist/src/types/uint-8.d.ts +26 -0
- package/dist/src/types/uint-8.js +50 -0
- package/dist/src/types/uint-8.js.map +1 -0
- package/dist/src/types/uint.d.ts +29 -0
- package/dist/src/types/uint.js +47 -0
- package/dist/src/types/uint.js.map +1 -0
- package/dist/src/types/vector-256.d.ts +31 -0
- package/dist/src/types/vector-256.js +76 -0
- package/dist/src/types/vector-256.js.map +1 -0
- package/dist/src/types/xchain-bridge.d.ts +45 -0
- package/dist/src/types/xchain-bridge.js +105 -0
- package/dist/src/types/xchain-bridge.js.map +1 -0
- package/dist/src/utils.d.ts +79 -0
- package/dist/src/utils.js +181 -0
- package/dist/src/utils.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/dist/types/account-id.d.ts +3 -2
- package/dist/types/account-id.js +8 -6
- package/dist/types/account-id.js.map +1 -1
- package/dist/types/amount.d.ts +33 -9
- package/dist/types/amount.js +128 -43
- package/dist/types/amount.js.map +1 -1
- package/dist/types/blob.d.ts +3 -3
- package/dist/types/blob.js +8 -2
- package/dist/types/blob.js.map +1 -1
- package/dist/types/currency.d.ts +3 -2
- package/dist/types/currency.js +17 -13
- package/dist/types/currency.js.map +1 -1
- package/dist/types/data.d.ts +104 -0
- package/dist/types/data.js +387 -0
- package/dist/types/data.js.map +1 -0
- package/dist/types/dataType.d.ts +94 -0
- package/dist/types/dataType.js +145 -0
- package/dist/types/dataType.js.map +1 -0
- package/dist/types/hash-128.d.ts +3 -2
- package/dist/types/hash-128.js +7 -3
- package/dist/types/hash-128.js.map +1 -1
- package/dist/types/hash-160.d.ts +3 -2
- package/dist/types/hash-160.js +5 -2
- package/dist/types/hash-160.js.map +1 -1
- package/dist/types/hash-192.d.ts +12 -0
- package/dist/types/hash-192.js +23 -0
- package/dist/types/hash-192.js.map +1 -0
- package/dist/types/hash-256.d.ts +3 -2
- package/dist/types/hash-256.js +5 -2
- package/dist/types/hash-256.js.map +1 -1
- package/dist/types/hash.d.ts +2 -3
- package/dist/types/hash.js +8 -4
- package/dist/types/hash.js.map +1 -1
- package/dist/types/index.d.ts +4 -1
- package/dist/types/index.js +17 -2
- package/dist/types/index.js.map +1 -1
- package/dist/types/issue.d.ts +49 -0
- package/dist/types/issue.js +107 -0
- package/dist/types/issue.js.map +1 -0
- package/dist/types/json.d.ts +169 -0
- package/dist/types/json.js +529 -0
- package/dist/types/json.js.map +1 -0
- package/dist/types/path-set.d.ts +2 -1
- package/dist/types/path-set.js +15 -12
- package/dist/types/path-set.js.map +1 -1
- package/dist/types/serialized-type.d.ts +70 -16
- package/dist/types/serialized-type.js +153 -8
- package/dist/types/serialized-type.js.map +1 -1
- package/dist/types/st-array.d.ts +7 -3
- package/dist/types/st-array.js +20 -11
- package/dist/types/st-array.js.map +1 -1
- package/dist/types/st-number.d.ts +55 -0
- package/dist/types/st-number.js +212 -0
- package/dist/types/st-number.js.map +1 -0
- package/dist/types/st-object.d.ts +2 -1
- package/dist/types/st-object.js +35 -8
- package/dist/types/st-object.js.map +1 -1
- package/dist/types/uint-16.d.ts +3 -2
- package/dist/types/uint-16.js +10 -5
- package/dist/types/uint-16.js.map +1 -1
- package/dist/types/uint-32.d.ts +3 -2
- package/dist/types/uint-32.js +11 -6
- package/dist/types/uint-32.js.map +1 -1
- package/dist/types/uint-64.d.ts +8 -7
- package/dist/types/uint-64.js +49 -24
- package/dist/types/uint-64.js.map +1 -1
- package/dist/types/uint-8.d.ts +3 -2
- package/dist/types/uint-8.js +11 -5
- package/dist/types/uint-8.js.map +1 -1
- package/dist/types/uint.d.ts +5 -6
- package/dist/types/uint.js +5 -0
- package/dist/types/uint.js.map +1 -1
- package/dist/types/vector-256.d.ts +3 -3
- package/dist/types/vector-256.js +5 -4
- package/dist/types/vector-256.js.map +1 -1
- package/dist/types/xchain-bridge.d.ts +45 -0
- package/dist/types/xchain-bridge.js +105 -0
- package/dist/types/xchain-bridge.js.map +1 -0
- package/dist/utils.d.ts +79 -0
- package/dist/utils.js +181 -0
- package/dist/utils.js.map +1 -0
- package/package.json +21 -17
- package/src/README.md +5 -0
- package/src/binary.ts +235 -0
- package/src/coretypes.ts +31 -0
- package/src/enums/README.md +144 -0
- package/src/enums/bytes.ts +80 -0
- package/src/enums/constants.ts +5 -0
- package/src/enums/definitions.json +3409 -0
- package/src/enums/field.ts +84 -0
- package/src/enums/index.ts +34 -0
- package/src/enums/utils-renumber.ts +134 -0
- package/src/enums/xrpl-definitions-base.ts +150 -0
- package/src/enums/xrpl-definitions.ts +33 -0
- package/src/hash-prefixes.ts +42 -0
- package/src/hashes.ts +75 -0
- package/src/index.ts +166 -0
- package/src/ledger-hashes.ts +191 -0
- package/src/quality.ts +38 -0
- package/src/serdes/binary-parser.ts +228 -0
- package/src/serdes/binary-serializer.ts +166 -0
- package/src/shamap.ts +189 -0
- package/src/types/account-id.ts +91 -0
- package/src/types/amount.ts +366 -0
- package/src/types/blob.ts +50 -0
- package/src/types/currency.ts +145 -0
- package/src/types/data.ts +496 -0
- package/src/types/dataType.ts +178 -0
- package/src/types/hash-128.ts +38 -0
- package/src/types/hash-160.ts +24 -0
- package/src/types/hash-192.ts +24 -0
- package/src/types/hash-256.ts +20 -0
- package/src/types/hash.ts +86 -0
- package/src/types/index.ts +74 -0
- package/src/types/issue.ts +140 -0
- package/src/types/json.ts +641 -0
- package/src/types/path-set.ts +294 -0
- package/src/types/serialized-type.ts +271 -0
- package/src/types/st-array.ts +117 -0
- package/src/types/st-number.ts +238 -0
- package/src/types/st-object.ts +219 -0
- package/src/types/uint-16.ts +58 -0
- package/src/types/uint-32.ts +64 -0
- package/src/types/uint-64.ts +141 -0
- package/src/types/uint-8.ts +57 -0
- package/src/types/uint.ts +60 -0
- package/src/types/vector-256.ts +83 -0
- package/src/types/xchain-bridge.ts +132 -0
- package/src/utils.ts +220 -0
- package/test/amount.test.js +0 -43
- package/test/binary-json.test.js +0 -45
- package/test/binary-parser.test.js +0 -396
- package/test/binary-serializer.test.js +0 -319
- package/test/definitions.test.js +0 -100
- package/test/fixtures/account-tx-transactions.db +0 -0
- package/test/fixtures/codec-fixtures.json +0 -4466
- package/test/fixtures/data-driven-tests.json +0 -2919
- package/test/fixtures/delivermin-tx-binary.json +0 -1
- package/test/fixtures/delivermin-tx.json +0 -98
- package/test/fixtures/deposit-preauth-tx-binary.json +0 -1
- package/test/fixtures/deposit-preauth-tx-meta-binary.json +0 -1
- package/test/fixtures/deposit-preauth-tx.json +0 -58
- package/test/fixtures/escrow-cancel-binary.json +0 -1
- package/test/fixtures/escrow-cancel-tx.json +0 -6
- package/test/fixtures/escrow-create-binary.json +0 -1
- package/test/fixtures/escrow-create-tx.json +0 -10
- package/test/fixtures/escrow-finish-binary.json +0 -1
- package/test/fixtures/escrow-finish-meta-binary.json +0 -1
- package/test/fixtures/escrow-finish-tx.json +0 -95
- package/test/fixtures/ledger-full-38129.json +0 -1
- package/test/fixtures/ledger-full-40000.json +0 -1
- package/test/fixtures/negative-unl.json +0 -12
- package/test/fixtures/nf-token.json +0 -547
- package/test/fixtures/payment-channel-claim-binary.json +0 -1
- package/test/fixtures/payment-channel-claim-tx.json +0 -8
- package/test/fixtures/payment-channel-create-binary.json +0 -1
- package/test/fixtures/payment-channel-create-tx.json +0 -11
- package/test/fixtures/payment-channel-fund-binary.json +0 -1
- package/test/fixtures/payment-channel-fund-tx.json +0 -7
- package/test/fixtures/remit-binary.json +0 -1
- package/test/fixtures/remit-tx.json +0 -39
- package/test/fixtures/signerlistset-tx-binary.json +0 -1
- package/test/fixtures/signerlistset-tx-meta-binary.json +0 -1
- package/test/fixtures/signerlistset-tx.json +0 -94
- package/test/fixtures/ticket-create-binary.json +0 -1
- package/test/fixtures/ticket-create-tx.json +0 -7
- package/test/fixtures/unl-report-binary.json +0 -1
- package/test/fixtures/unl-report-meta-binary.json +0 -1
- package/test/fixtures/unl-report.json +0 -89
- package/test/fixtures/x-codec-fixtures.json +0 -188
- package/test/hash.test.js +0 -135
- package/test/ledger.test.js +0 -29
- package/test/lower-case-hex.test.js +0 -46
- package/test/pseudo-transaction.test.js +0 -38
- package/test/quality.test.js +0 -15
- package/test/shamap.test.js +0 -89
- package/test/signing-data-encoding.test.js +0 -213
- package/test/tx-encode-decode.test.js +0 -119
- package/test/types.test.js +0 -34
- package/test/uint.test.js +0 -148
- package/test/utils.js +0 -30
- package/test/x-address.test.js +0 -181
package/test/shamap.test.js
DELETED
|
@@ -1,89 +0,0 @@
|
|
|
1
|
-
const { ShaMap } = require('../src/shamap')
|
|
2
|
-
const { binary, HashPrefix } = require('../src/coretypes')
|
|
3
|
-
const { coreTypes } = require('../src/types')
|
|
4
|
-
const { loadFixture } = require('./utils')
|
|
5
|
-
const { Buffer } = require('buffer/')
|
|
6
|
-
|
|
7
|
-
function now() {
|
|
8
|
-
return Number(Date.now()) / 1000
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
const ZERO = '0000000000000000000000000000000000000000000000000000000000000000'
|
|
12
|
-
|
|
13
|
-
function makeItem(indexArg) {
|
|
14
|
-
let str = indexArg
|
|
15
|
-
while (str.length < 64) {
|
|
16
|
-
str += '0'
|
|
17
|
-
}
|
|
18
|
-
const index = coreTypes.Hash256.from(str)
|
|
19
|
-
const item = {
|
|
20
|
-
toBytesSink(sink) {
|
|
21
|
-
index.toBytesSink(sink)
|
|
22
|
-
},
|
|
23
|
-
hashPrefix() {
|
|
24
|
-
return Buffer.from([1, 3, 3, 7])
|
|
25
|
-
},
|
|
26
|
-
}
|
|
27
|
-
return [index, item]
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
describe('ShaMap', () => {
|
|
31
|
-
now()
|
|
32
|
-
|
|
33
|
-
test('hashes to zero when empty', () => {
|
|
34
|
-
const map = new ShaMap()
|
|
35
|
-
expect(map.hash().toHex()).toBe(ZERO)
|
|
36
|
-
})
|
|
37
|
-
test('creates the same hash no matter which order items are added', () => {
|
|
38
|
-
let map = new ShaMap()
|
|
39
|
-
const items = [
|
|
40
|
-
'0',
|
|
41
|
-
'1',
|
|
42
|
-
'11',
|
|
43
|
-
'7000DE445E22CB9BB7E1717589FA858736BAA5FD192310E20000000000000000',
|
|
44
|
-
'7000DE445E22CB9BB7E1717589FA858736BAA5FD192310E21000000000000000',
|
|
45
|
-
'7000DE445E22CB9BB7E1717589FA858736BAA5FD192310E22000000000000000',
|
|
46
|
-
'7000DE445E22CB9BB7E1717589FA858736BAA5FD192310E23000000000000000',
|
|
47
|
-
'12',
|
|
48
|
-
'122',
|
|
49
|
-
]
|
|
50
|
-
items.forEach((i) => map.addItem(...makeItem(i)))
|
|
51
|
-
const h1 = map.hash()
|
|
52
|
-
expect(h1.eq(h1)).toBe(true)
|
|
53
|
-
map = new ShaMap()
|
|
54
|
-
items.reverse().forEach((i) => map.addItem(...makeItem(i)))
|
|
55
|
-
expect(map.hash()).toStrictEqual(h1)
|
|
56
|
-
})
|
|
57
|
-
function factory(fixture) {
|
|
58
|
-
test(`recreate account state hash from ${fixture}`, () => {
|
|
59
|
-
const map = new ShaMap()
|
|
60
|
-
const ledger = loadFixture(fixture)
|
|
61
|
-
// const t = now();
|
|
62
|
-
const leafNodePrefix = HashPrefix.accountStateEntry
|
|
63
|
-
ledger.accountState
|
|
64
|
-
.map((e, i) => {
|
|
65
|
-
if ((i > 1000) & (i % 1000 === 0)) {
|
|
66
|
-
console.log(e.index)
|
|
67
|
-
console.log(i)
|
|
68
|
-
}
|
|
69
|
-
const bytes = binary.serializeObject(e)
|
|
70
|
-
return {
|
|
71
|
-
index: coreTypes.Hash256.from(e.index),
|
|
72
|
-
hashPrefix() {
|
|
73
|
-
return leafNodePrefix
|
|
74
|
-
},
|
|
75
|
-
toBytesSink(sink) {
|
|
76
|
-
sink.put(bytes)
|
|
77
|
-
},
|
|
78
|
-
}
|
|
79
|
-
})
|
|
80
|
-
.forEach((so) => map.addItem(so.index, so))
|
|
81
|
-
expect(map.hash().toHex()).toBe(ledger.account_hash)
|
|
82
|
-
// console.log('took seconds: ', (now() - t));
|
|
83
|
-
})
|
|
84
|
-
}
|
|
85
|
-
factory('ledger-full-38129.json')
|
|
86
|
-
factory('ledger-full-40000.json')
|
|
87
|
-
// factory('ledger-4320277.json');
|
|
88
|
-
// factory('14280680.json');
|
|
89
|
-
})
|
|
@@ -1,213 +0,0 @@
|
|
|
1
|
-
const { throws } = require('assert')
|
|
2
|
-
const {
|
|
3
|
-
encodeForSigning,
|
|
4
|
-
encodeForSigningClaim,
|
|
5
|
-
encodeForMultisigning,
|
|
6
|
-
} = require('../src')
|
|
7
|
-
const { XrplDefinitions } = require('../src/enums/xrpl-definitions')
|
|
8
|
-
|
|
9
|
-
const normalDefinitions = require('../src/enums/definitions.json')
|
|
10
|
-
|
|
11
|
-
const tx_json = {
|
|
12
|
-
Account: 'r9LqNeG6qHxjeUocjvVki2XR35weJ9mZgQ',
|
|
13
|
-
Amount: '1000',
|
|
14
|
-
Destination: 'rHb9CJAWyB4rj91VRWn96DkukG4bwdtyTh',
|
|
15
|
-
Fee: '10',
|
|
16
|
-
Flags: 2147483648,
|
|
17
|
-
Sequence: 1,
|
|
18
|
-
TransactionType: 'Payment',
|
|
19
|
-
TxnSignature:
|
|
20
|
-
'30440220718D264EF05CAED7C781FF6DE298DCAC68D002562C9BF3A07C1' +
|
|
21
|
-
'E721B420C0DAB02203A5A4779EF4D2CCC7BC3EF886676D803A9981B928D3B8ACA483B80' +
|
|
22
|
-
'ECA3CD7B9B',
|
|
23
|
-
Signature:
|
|
24
|
-
'30440220718D264EF05CAED7C781FF6DE298DCAC68D002562C9BF3A07C1E72' +
|
|
25
|
-
'1B420C0DAB02203A5A4779EF4D2CCC7BC3EF886676D803A9981B928D3B8ACA483B80ECA' +
|
|
26
|
-
'3CD7B9B',
|
|
27
|
-
SigningPubKey:
|
|
28
|
-
'ED5F5AC8B98974A3CA843326D9B88CEBD0560177B973EE0B149F782CFAA06DC66A',
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
describe('Signing data', function () {
|
|
32
|
-
test('can create single signing blobs', function () {
|
|
33
|
-
const actual = encodeForSigning(tx_json)
|
|
34
|
-
expect(actual).toBe(
|
|
35
|
-
[
|
|
36
|
-
'53545800', // signingPrefix
|
|
37
|
-
// TransactionType
|
|
38
|
-
'12',
|
|
39
|
-
'0000',
|
|
40
|
-
// Flags
|
|
41
|
-
'22',
|
|
42
|
-
'80000000',
|
|
43
|
-
// Sequence
|
|
44
|
-
'24',
|
|
45
|
-
'00000001',
|
|
46
|
-
// Amount
|
|
47
|
-
'61',
|
|
48
|
-
// native amount
|
|
49
|
-
'40000000000003E8',
|
|
50
|
-
// Fee
|
|
51
|
-
'68',
|
|
52
|
-
// native amount
|
|
53
|
-
'400000000000000A',
|
|
54
|
-
// SigningPubKey
|
|
55
|
-
'73',
|
|
56
|
-
// VLLength
|
|
57
|
-
'21',
|
|
58
|
-
'ED5F5AC8B98974A3CA843326D9B88CEBD0560177B973EE0B149F782CFAA06DC66A',
|
|
59
|
-
// Account
|
|
60
|
-
'81',
|
|
61
|
-
// VLLength
|
|
62
|
-
'14',
|
|
63
|
-
'5B812C9D57731E27A2DA8B1830195F88EF32A3B6',
|
|
64
|
-
// Destination
|
|
65
|
-
'83',
|
|
66
|
-
// VLLength
|
|
67
|
-
'14',
|
|
68
|
-
'B5F762798A53D543A014CAF8B297CFF8F2F937E8',
|
|
69
|
-
].join(''),
|
|
70
|
-
)
|
|
71
|
-
})
|
|
72
|
-
|
|
73
|
-
test('can create single signing blobs with modified type', function () {
|
|
74
|
-
const customPaymentDefinitions = JSON.parse(
|
|
75
|
-
JSON.stringify(normalDefinitions),
|
|
76
|
-
)
|
|
77
|
-
customPaymentDefinitions.TRANSACTION_TYPES.Payment = 31
|
|
78
|
-
|
|
79
|
-
const newDefs = new XrplDefinitions(customPaymentDefinitions)
|
|
80
|
-
const actual = encodeForSigning(tx_json, newDefs)
|
|
81
|
-
expect(actual).toBe(
|
|
82
|
-
[
|
|
83
|
-
'53545800', // signingPrefix
|
|
84
|
-
// TransactionType
|
|
85
|
-
'12',
|
|
86
|
-
'001F',
|
|
87
|
-
// Flags
|
|
88
|
-
'22',
|
|
89
|
-
'80000000',
|
|
90
|
-
// Sequence
|
|
91
|
-
'24',
|
|
92
|
-
'00000001',
|
|
93
|
-
// Amount
|
|
94
|
-
'61',
|
|
95
|
-
// native amount
|
|
96
|
-
'40000000000003E8',
|
|
97
|
-
// Fee
|
|
98
|
-
'68',
|
|
99
|
-
// native amount
|
|
100
|
-
'400000000000000A',
|
|
101
|
-
// SigningPubKey
|
|
102
|
-
'73',
|
|
103
|
-
// VLLength
|
|
104
|
-
'21',
|
|
105
|
-
'ED5F5AC8B98974A3CA843326D9B88CEBD0560177B973EE0B149F782CFAA06DC66A',
|
|
106
|
-
// Account
|
|
107
|
-
'81',
|
|
108
|
-
// VLLength
|
|
109
|
-
'14',
|
|
110
|
-
'5B812C9D57731E27A2DA8B1830195F88EF32A3B6',
|
|
111
|
-
// Destination
|
|
112
|
-
'83',
|
|
113
|
-
// VLLength
|
|
114
|
-
'14',
|
|
115
|
-
'B5F762798A53D543A014CAF8B297CFF8F2F937E8',
|
|
116
|
-
].join(''),
|
|
117
|
-
)
|
|
118
|
-
})
|
|
119
|
-
|
|
120
|
-
test('can fail gracefully for invalid TransactionType', function () {
|
|
121
|
-
const invalidTransactionType = {
|
|
122
|
-
...tx_json,
|
|
123
|
-
TransactionType: 'NotAPayment',
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
throws(() => encodeForSigning(invalidTransactionType), /NotAPayment/u)
|
|
127
|
-
})
|
|
128
|
-
|
|
129
|
-
test('can create multi signing blobs', function () {
|
|
130
|
-
const signingAccount = 'rJZdUusLDtY9NEsGea7ijqhVrXv98rYBYN'
|
|
131
|
-
const signingJson = { ...tx_json, SigningPubKey: '' }
|
|
132
|
-
const actual = encodeForMultisigning(signingJson, signingAccount)
|
|
133
|
-
expect(actual).toBe(
|
|
134
|
-
[
|
|
135
|
-
'534D5400', // signingPrefix
|
|
136
|
-
// TransactionType
|
|
137
|
-
'12',
|
|
138
|
-
'0000',
|
|
139
|
-
// Flags
|
|
140
|
-
'22',
|
|
141
|
-
'80000000',
|
|
142
|
-
// Sequence
|
|
143
|
-
'24',
|
|
144
|
-
'00000001',
|
|
145
|
-
// Amount
|
|
146
|
-
'61',
|
|
147
|
-
// native amount
|
|
148
|
-
'40000000000003E8',
|
|
149
|
-
// Fee
|
|
150
|
-
'68',
|
|
151
|
-
// native amount
|
|
152
|
-
'400000000000000A',
|
|
153
|
-
// SigningPubKey
|
|
154
|
-
'73',
|
|
155
|
-
// VLLength
|
|
156
|
-
'00',
|
|
157
|
-
// '',
|
|
158
|
-
// Account
|
|
159
|
-
'81',
|
|
160
|
-
// VLLength
|
|
161
|
-
'14',
|
|
162
|
-
'5B812C9D57731E27A2DA8B1830195F88EF32A3B6',
|
|
163
|
-
// Destination
|
|
164
|
-
'83',
|
|
165
|
-
// VLLength
|
|
166
|
-
'14',
|
|
167
|
-
'B5F762798A53D543A014CAF8B297CFF8F2F937E8',
|
|
168
|
-
// signingAccount suffix
|
|
169
|
-
'C0A5ABEF242802EFED4B041E8F2D4A8CC86AE3D1',
|
|
170
|
-
].join(''),
|
|
171
|
-
)
|
|
172
|
-
})
|
|
173
|
-
test('can create native claim blob', function () {
|
|
174
|
-
const channel =
|
|
175
|
-
'43904CBFCDCEC530B4037871F86EE90BF799DF8D2E0EA564BC8A3F332E4F5FB1'
|
|
176
|
-
const amount = '1000'
|
|
177
|
-
const json = { channel, amount }
|
|
178
|
-
const actual = encodeForSigningClaim(json)
|
|
179
|
-
expect(actual).toBe(
|
|
180
|
-
[
|
|
181
|
-
// hash prefix
|
|
182
|
-
'434C4D00',
|
|
183
|
-
// channel ID
|
|
184
|
-
'43904CBFCDCEC530B4037871F86EE90BF799DF8D2E0EA564BC8A3F332E4F5FB1',
|
|
185
|
-
// amount as a uint64
|
|
186
|
-
'00000000000003E8',
|
|
187
|
-
].join(''),
|
|
188
|
-
)
|
|
189
|
-
})
|
|
190
|
-
test('can create ic claim blob', function () {
|
|
191
|
-
const channel =
|
|
192
|
-
'43904CBFCDCEC530B4037871F86EE90BF799DF8D2E0EA564BC8A3F332E4F5FB1'
|
|
193
|
-
const amount = {
|
|
194
|
-
issuer: 'rJZdUusLDtY9NEsGea7ijqhVrXv98rYBYN',
|
|
195
|
-
currency: 'USD',
|
|
196
|
-
value: '10',
|
|
197
|
-
}
|
|
198
|
-
const json = { channel, amount }
|
|
199
|
-
const actual = encodeForSigningClaim(json)
|
|
200
|
-
expect(actual).toBe(
|
|
201
|
-
[
|
|
202
|
-
// hash prefix
|
|
203
|
-
'434C4D00',
|
|
204
|
-
// channel ID
|
|
205
|
-
'43904CBFCDCEC530B4037871F86EE90BF799DF8D2E0EA564BC8A3F332E4F5FB1',
|
|
206
|
-
// amount as a uint64
|
|
207
|
-
'D4C38D7EA4C680000000000000000000000000005553440000000000C0A5ABEF',
|
|
208
|
-
// amount as a uint64
|
|
209
|
-
'242802EFED4B041E8F2D4A8CC86AE3D1',
|
|
210
|
-
].join(''),
|
|
211
|
-
)
|
|
212
|
-
})
|
|
213
|
-
})
|
|
@@ -1,119 +0,0 @@
|
|
|
1
|
-
const { encode, decode } = require('../src')
|
|
2
|
-
|
|
3
|
-
// Notice: no Amount or Fee
|
|
4
|
-
const tx_json = {
|
|
5
|
-
Account: 'r9LqNeG6qHxjeUocjvVki2XR35weJ9mZgQ',
|
|
6
|
-
// Amount: '1000',
|
|
7
|
-
Destination: 'rHb9CJAWyB4rj91VRWn96DkukG4bwdtyTh',
|
|
8
|
-
// Fee: '10',
|
|
9
|
-
|
|
10
|
-
// JavaScript converts operands to 32-bit signed ints after doing bitwise
|
|
11
|
-
// operations. We need to convert it back to an unsigned int with >>> 0.
|
|
12
|
-
Flags: (1 << 31) >>> 0, // tfFullyCanonicalSig
|
|
13
|
-
|
|
14
|
-
Sequence: 1,
|
|
15
|
-
TransactionType: 'Payment',
|
|
16
|
-
// TxnSignature,
|
|
17
|
-
// Signature,
|
|
18
|
-
// SigningPubKey
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
describe('encoding and decoding tx_json', function () {
|
|
22
|
-
test('can encode tx_json without Amount or Fee', function () {
|
|
23
|
-
const encoded = encode(tx_json)
|
|
24
|
-
const decoded = decode(encoded)
|
|
25
|
-
expect(tx_json).toEqual(decoded)
|
|
26
|
-
})
|
|
27
|
-
test('can encode tx_json with Amount and Fee', function () {
|
|
28
|
-
const my_tx = Object.assign({}, tx_json, {
|
|
29
|
-
Amount: '1000',
|
|
30
|
-
Fee: '10',
|
|
31
|
-
})
|
|
32
|
-
const encoded = encode(my_tx)
|
|
33
|
-
const decoded = decode(encoded)
|
|
34
|
-
expect(my_tx).toEqual(decoded)
|
|
35
|
-
})
|
|
36
|
-
test('can encode tx_json with TicketCount', function () {
|
|
37
|
-
const my_tx = Object.assign({}, tx_json, {
|
|
38
|
-
TicketCount: 2,
|
|
39
|
-
})
|
|
40
|
-
const encoded = encode(my_tx)
|
|
41
|
-
const decoded = decode(encoded)
|
|
42
|
-
expect(my_tx).toEqual(decoded)
|
|
43
|
-
})
|
|
44
|
-
test('can encode tx_json with TicketSequence', function () {
|
|
45
|
-
const my_tx = Object.assign({}, tx_json, {
|
|
46
|
-
Sequence: 0,
|
|
47
|
-
TicketSequence: 2,
|
|
48
|
-
})
|
|
49
|
-
const encoded = encode(my_tx)
|
|
50
|
-
const decoded = decode(encoded)
|
|
51
|
-
expect(my_tx).toEqual(decoded)
|
|
52
|
-
})
|
|
53
|
-
test('can decode a transaction with an issued currency that evaluates to XRP', function () {
|
|
54
|
-
// Encoding is done prior, because this is disallowed during encoding with client libraries to avoid scam XRP tokens.
|
|
55
|
-
const expectedTx = {
|
|
56
|
-
TransactionType: 'TrustSet',
|
|
57
|
-
Flags: 0,
|
|
58
|
-
Sequence: 19,
|
|
59
|
-
LimitAmount: {
|
|
60
|
-
value: '200',
|
|
61
|
-
currency: '0000000000000000000000005841480000000000',
|
|
62
|
-
issuer: 'r9hEDb4xBGRfBCcX3E4FirDWQBAYtpxC8K',
|
|
63
|
-
},
|
|
64
|
-
Fee: '10',
|
|
65
|
-
SigningPubKey:
|
|
66
|
-
'023076CBB7A61837F1A23D4A3DD7CE810B694992EB0959AB9D6F4BB6FED6F8CC26',
|
|
67
|
-
TxnSignature:
|
|
68
|
-
'304502202D0CD77D8E765E3783C309CD663723B18406B7950A348A6F301492916A990FC70221008A76D586111205304F10ADEFDFDDAF804EF202D8CD1E492DC6E1AA8030EA1844',
|
|
69
|
-
Account: 'rPtfQWdcdhuL9eNeNv5YfmekSX3K7vJHbG',
|
|
70
|
-
}
|
|
71
|
-
const encoded = encode(expectedTx)
|
|
72
|
-
const decoded = decode(encoded)
|
|
73
|
-
expect(expectedTx).toEqual(decoded)
|
|
74
|
-
})
|
|
75
|
-
test('throws when Amount is invalid', function () {
|
|
76
|
-
const my_tx = Object.assign({}, tx_json, {
|
|
77
|
-
Amount: '1000.001',
|
|
78
|
-
Fee: '10',
|
|
79
|
-
})
|
|
80
|
-
expect(() => {
|
|
81
|
-
encode(my_tx)
|
|
82
|
-
}).toThrow()
|
|
83
|
-
})
|
|
84
|
-
test('throws when Fee is invalid', function () {
|
|
85
|
-
const my_tx = Object.assign({}, tx_json, {
|
|
86
|
-
Amount: '1000',
|
|
87
|
-
Fee: '10.123',
|
|
88
|
-
})
|
|
89
|
-
expect(() => {
|
|
90
|
-
encode(my_tx)
|
|
91
|
-
}).toThrow()
|
|
92
|
-
})
|
|
93
|
-
test('throws when Amount and Fee are invalid', function () {
|
|
94
|
-
const my_tx = Object.assign({}, tx_json, {
|
|
95
|
-
Amount: '1000.789',
|
|
96
|
-
Fee: '10.123',
|
|
97
|
-
})
|
|
98
|
-
expect(() => {
|
|
99
|
-
encode(my_tx)
|
|
100
|
-
}).toThrow()
|
|
101
|
-
})
|
|
102
|
-
test('throws when Amount is a number instead of a string-encoded integer', function () {
|
|
103
|
-
const my_tx = Object.assign({}, tx_json, {
|
|
104
|
-
Amount: 1000.789,
|
|
105
|
-
})
|
|
106
|
-
expect(() => {
|
|
107
|
-
encode(my_tx)
|
|
108
|
-
}).toThrow()
|
|
109
|
-
})
|
|
110
|
-
|
|
111
|
-
test('throws when Fee is a number instead of a string-encoded integer', function () {
|
|
112
|
-
const my_tx = Object.assign({}, tx_json, {
|
|
113
|
-
Amount: 1234.56,
|
|
114
|
-
})
|
|
115
|
-
expect(() => {
|
|
116
|
-
encode(my_tx)
|
|
117
|
-
}).toThrow()
|
|
118
|
-
})
|
|
119
|
-
})
|
package/test/types.test.js
DELETED
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
const { coreTypes } = require('../src/types')
|
|
2
|
-
const { SerializedType } = require('../src/types/serialized-type')
|
|
3
|
-
|
|
4
|
-
describe('SerializedType interfaces', () => {
|
|
5
|
-
Object.entries(coreTypes).forEach(([name, Value]) => {
|
|
6
|
-
test(`${name} has a \`from\` static constructor`, () => {
|
|
7
|
-
expect(Value.from && Value.from !== Array.from).toBe(true)
|
|
8
|
-
})
|
|
9
|
-
test(`${name} has a default constructor`, () => {
|
|
10
|
-
expect(new Value()).not.toBe(undefined)
|
|
11
|
-
})
|
|
12
|
-
test(`${name}.from will return the same object`, () => {
|
|
13
|
-
const instance = new Value()
|
|
14
|
-
expect(Value.from(instance) === instance).toBe(true)
|
|
15
|
-
})
|
|
16
|
-
test(`${name} instances have toBytesSink`, () => {
|
|
17
|
-
expect(new Value().toBytesSink).not.toBe(undefined)
|
|
18
|
-
})
|
|
19
|
-
test(`${name} instances have toJSON`, () => {
|
|
20
|
-
expect(new Value().toJSON).not.toBe(undefined)
|
|
21
|
-
})
|
|
22
|
-
test(`${name}.from(json).toJSON() == json`, () => {
|
|
23
|
-
const newJSON = new Value().toJSON()
|
|
24
|
-
expect(Value.from(newJSON).toJSON()).toEqual(newJSON)
|
|
25
|
-
})
|
|
26
|
-
describe(`${name} supports all methods of the SerializedType mixin`, () => {
|
|
27
|
-
Object.keys(SerializedType.prototype).forEach((k) => {
|
|
28
|
-
test(`new ${name}.prototype.${k} !== undefined`, () => {
|
|
29
|
-
expect(Value.prototype[k]).not.toBe(undefined)
|
|
30
|
-
})
|
|
31
|
-
})
|
|
32
|
-
})
|
|
33
|
-
})
|
|
34
|
-
})
|
package/test/uint.test.js
DELETED
|
@@ -1,148 +0,0 @@
|
|
|
1
|
-
const { coreTypes } = require('../src/types')
|
|
2
|
-
const { UInt8, UInt64 } = coreTypes
|
|
3
|
-
|
|
4
|
-
const { encode } = require('../src')
|
|
5
|
-
|
|
6
|
-
const binary =
|
|
7
|
-
'11007222000300003700000000000000003800000000000000006280000000000000000000000000000000000000005553440000000000000000000000000000000000000000000000000166D5438D7EA4C680000000000000000000000000005553440000000000AE123A8556F3CF91154711376AFB0F894F832B3D67D5438D7EA4C680000000000000000000000000005553440000000000F51DFC2A09D62CBBA1DFBDD4691DAC96AD98B90F'
|
|
8
|
-
const json = {
|
|
9
|
-
Balance: {
|
|
10
|
-
currency: 'USD',
|
|
11
|
-
issuer: 'rrrrrrrrrrrrrrrrrrrrBZbvji',
|
|
12
|
-
value: '0',
|
|
13
|
-
},
|
|
14
|
-
Flags: 196608,
|
|
15
|
-
HighLimit: {
|
|
16
|
-
currency: 'USD',
|
|
17
|
-
issuer: 'rPMh7Pi9ct699iZUTWaytJUoHcJ7cgyziK',
|
|
18
|
-
value: '1000',
|
|
19
|
-
},
|
|
20
|
-
HighNode: '0',
|
|
21
|
-
LedgerEntryType: 'RippleState',
|
|
22
|
-
LowLimit: {
|
|
23
|
-
currency: 'USD',
|
|
24
|
-
issuer: 'rG1QQv2nh2gr7RCZ1P8YYcBUKCCN633jCn',
|
|
25
|
-
value: '1000',
|
|
26
|
-
},
|
|
27
|
-
LowNode: '0',
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
const binaryEntry0 =
|
|
31
|
-
'11007222001100002501EC24873700000000000000003800000000000000A35506FC7DE374089D50F81AAE13E7BBF3D0E694769331E14F55351B38D0148018EA62D44BF89AC2A40B800000000000000000000000004A50590000000000000000000000000000000000000000000000000166D6C38D7EA4C680000000000000000000000000004A5059000000000047C1258B4B79774B28176324068F759EDE226F686780000000000000000000000000000000000000004A505900000000005BBC0F22F61D9224A110650CFE21CC0C4BE13098'
|
|
32
|
-
const jsonEntry0 = {
|
|
33
|
-
Balance: {
|
|
34
|
-
currency: 'JPY',
|
|
35
|
-
issuer: 'rrrrrrrrrrrrrrrrrrrrBZbvji',
|
|
36
|
-
value: '0.3369568318',
|
|
37
|
-
},
|
|
38
|
-
Flags: 1114112,
|
|
39
|
-
HighLimit: {
|
|
40
|
-
currency: 'JPY',
|
|
41
|
-
issuer: 'r94s8px6kSw1uZ1MV98dhSRTvc6VMPoPcN',
|
|
42
|
-
value: '0',
|
|
43
|
-
},
|
|
44
|
-
HighNode: 'a3',
|
|
45
|
-
LedgerEntryType: 'RippleState',
|
|
46
|
-
LowLimit: {
|
|
47
|
-
currency: 'JPY',
|
|
48
|
-
issuer: 'rfYQMgj3g3Qp8VLoZNvvU35mEuuJC8nCmY',
|
|
49
|
-
value: '1000000000',
|
|
50
|
-
},
|
|
51
|
-
LowNode: '0',
|
|
52
|
-
PreviousTxnID:
|
|
53
|
-
'06FC7DE374089D50F81AAE13E7BBF3D0E694769331E14F55351B38D0148018EA',
|
|
54
|
-
PreviousTxnLgrSeq: 32253063,
|
|
55
|
-
index: '000319BAE0A618A7D3BB492F17E98E5D92EA0C6458AFEBED44206B5B4798A840',
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
const binaryEntry1 =
|
|
59
|
-
'1100642200000000320000000000000002580CB3C1AD2C371136AEA434246D971C5FCCD32CBF520667E131AB7B10D706E7528214BA53D10260FFCC968ACD16BA30F7CEABAD6E5D92011340A3454ACED87177146EABD5E4A256021D836D1E3617618B1EB362D10B0D1BAC6AE1ED9E8D280BBE0B6656748FD647231851C6C650794D5E6852DFA1E35E68630F'
|
|
60
|
-
const jsonEntry1 = {
|
|
61
|
-
Flags: 0,
|
|
62
|
-
IndexPrevious: '2',
|
|
63
|
-
Indexes: [
|
|
64
|
-
'A3454ACED87177146EABD5E4A256021D836D1E3617618B1EB362D10B0D1BAC6A',
|
|
65
|
-
'E1ED9E8D280BBE0B6656748FD647231851C6C650794D5E6852DFA1E35E68630F',
|
|
66
|
-
],
|
|
67
|
-
LedgerEntryType: 'DirectoryNode',
|
|
68
|
-
Owner: 'rHzDaMNybxQppiE3uWyt2N265KvAKdiRdP',
|
|
69
|
-
RootIndex: '0CB3C1AD2C371136AEA434246D971C5FCCD32CBF520667E131AB7B10D706E752',
|
|
70
|
-
index: '0B4A2E68C111F7E42FAEEE405F7344560C8240840B151D9D04131EB79D080167',
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
const binaryEntry2 =
|
|
74
|
-
'1100722200210000250178D1CA37000000000000000038000000000000028355C0C37CE200B509E0A529880634F7841A9EF4CB65F03C12E6004CFAD9718D66946280000000000000000000000000000000000000004743420000000000000000000000000000000000000000000000000166D6071AFD498D000000000000000000000000000047434200000000002599D1D255BCA61189CA64C84528F2FCBE4BFC3867800000000000000000000000000000000000000047434200000000006EEBB1D1852CE667876A0B3630861FB6C6AB358E'
|
|
75
|
-
const jsonEntry2 = {
|
|
76
|
-
Balance: {
|
|
77
|
-
currency: 'GCB',
|
|
78
|
-
issuer: 'rrrrrrrrrrrrrrrrrrrrBZbvji',
|
|
79
|
-
value: '0',
|
|
80
|
-
},
|
|
81
|
-
Flags: 2162688,
|
|
82
|
-
HighLimit: {
|
|
83
|
-
currency: 'GCB',
|
|
84
|
-
issuer: 'rBfVgTnsdh8ckC19RM8aVGNuMZnpwrMP6n',
|
|
85
|
-
value: '0',
|
|
86
|
-
},
|
|
87
|
-
HighNode: '283',
|
|
88
|
-
LedgerEntryType: 'RippleState',
|
|
89
|
-
LowLimit: {
|
|
90
|
-
currency: 'GCB',
|
|
91
|
-
issuer: 'rhRFGCy2RJTA8oxkjjtYTvofPVGqcgvXWj',
|
|
92
|
-
value: '2000000',
|
|
93
|
-
},
|
|
94
|
-
LowNode: '0',
|
|
95
|
-
PreviousTxnID:
|
|
96
|
-
'C0C37CE200B509E0A529880634F7841A9EF4CB65F03C12E6004CFAD9718D6694',
|
|
97
|
-
PreviousTxnLgrSeq: 24695242,
|
|
98
|
-
index: '0000041EFD027808D3F78C8352F97E324CB816318E00B977C74ECDDC7CD975B2',
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
test('compareToTests[0]', () => {
|
|
102
|
-
expect(UInt8.from(124).compareTo(UInt64.from(124))).toBe(0)
|
|
103
|
-
})
|
|
104
|
-
|
|
105
|
-
test('compareToTest[1]', () => {
|
|
106
|
-
expect(UInt64.from(124).compareTo(UInt8.from(124))).toBe(0)
|
|
107
|
-
})
|
|
108
|
-
|
|
109
|
-
test('compareToTest[2]', () => {
|
|
110
|
-
expect(UInt64.from(124).compareTo(UInt8.from(123))).toBe(1)
|
|
111
|
-
})
|
|
112
|
-
|
|
113
|
-
test('compareToTest[3]', () => {
|
|
114
|
-
expect(UInt8.from(124).compareTo(UInt8.from(13))).toBe(1)
|
|
115
|
-
})
|
|
116
|
-
|
|
117
|
-
test('compareToTest[4]', () => {
|
|
118
|
-
expect(UInt8.from(124).compareTo(124)).toBe(0)
|
|
119
|
-
})
|
|
120
|
-
|
|
121
|
-
test('compareToTest[5]', () => {
|
|
122
|
-
expect(UInt64.from(124).compareTo(124)).toBe(0)
|
|
123
|
-
})
|
|
124
|
-
|
|
125
|
-
test('compareToTest[6]', () => {
|
|
126
|
-
expect(UInt64.from(124).compareTo(123)).toBe(1)
|
|
127
|
-
})
|
|
128
|
-
|
|
129
|
-
test('compareToTest[7]', () => {
|
|
130
|
-
expect(UInt8.from(124).compareTo(13)).toBe(1)
|
|
131
|
-
})
|
|
132
|
-
|
|
133
|
-
test('UInt64 from string zero', () => {
|
|
134
|
-
expect(UInt64.from('0')).toEqual(UInt64.from(0))
|
|
135
|
-
expect(encode(json)).toEqual(binary)
|
|
136
|
-
})
|
|
137
|
-
|
|
138
|
-
test('UInt64 from non 16 length hex', () => {
|
|
139
|
-
expect(encode(jsonEntry0)).toEqual(binaryEntry0)
|
|
140
|
-
expect(encode(jsonEntry1)).toEqual(binaryEntry1)
|
|
141
|
-
expect(encode(jsonEntry2)).toEqual(binaryEntry2)
|
|
142
|
-
})
|
|
143
|
-
|
|
144
|
-
test('valueOfTests', () => {
|
|
145
|
-
let val = UInt8.from(1)
|
|
146
|
-
val |= 0x2
|
|
147
|
-
expect(val).toBe(3)
|
|
148
|
-
})
|
package/test/utils.js
DELETED
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
const fs = require("fs");
|
|
2
|
-
const { Buffer } = require('buffer/')
|
|
3
|
-
|
|
4
|
-
function hexOnly(hex) {
|
|
5
|
-
return hex.replace(/[^a-fA-F0-9]/g, "");
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
function unused() {}
|
|
9
|
-
|
|
10
|
-
function parseHexOnly(hex) {
|
|
11
|
-
return Buffer.from(hexOnly(hex), "hex");
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
function loadFixture(relativePath) {
|
|
15
|
-
const fn = __dirname + "/fixtures/" + relativePath;
|
|
16
|
-
return require(fn);
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
function loadFixtureText(relativePath) {
|
|
20
|
-
const fn = __dirname + "/fixtures/" + relativePath;
|
|
21
|
-
return fs.readFileSync(fn).toString("utf8");
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
module.exports = {
|
|
25
|
-
hexOnly,
|
|
26
|
-
parseHexOnly,
|
|
27
|
-
loadFixture,
|
|
28
|
-
loadFixtureText,
|
|
29
|
-
unused,
|
|
30
|
-
};
|