@rosen-bridge/address-codec 0.2.1 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +6 -0
- package/dist/decoder.d.ts +2 -5
- package/dist/encoder.d.ts +1 -1
- package/dist/index.d.ts +2 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -1
- package/dist/lib/index.d.ts +1 -0
- package/dist/lib/index.d.ts.map +1 -1
- package/dist/lib/index.js +2 -1
- package/dist/lib/validator.d.ts +7 -0
- package/dist/lib/validator.d.ts.map +1 -0
- package/dist/lib/validator.js +33 -0
- package/dist/tests/testData.d.ts +6 -0
- package/dist/tests/testData.d.ts.map +1 -1
- package/dist/tests/testData.js +7 -1
- package/dist/tests/validator.spec.d.ts +2 -0
- package/dist/tests/validator.spec.d.ts.map +1 -0
- package/dist/tests/validator.spec.js +158 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/dist/types.d.ts +3 -3
- package/dist/types.js +7 -11
- package/dist/validator.d.ts +7 -0
- package/dist/validator.d.ts.map +1 -0
- package/dist/validator.js +33 -0
- package/lib/index.ts +1 -0
- package/lib/validator.ts +38 -0
- package/package.json +3 -2
- package/tests/testData.ts +11 -0
- package/tests/validator.spec.ts +178 -0
- package/tsconfig.build.tsbuildinfo +1 -1
package/dist/types.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
export declare class UnsupportedAddressError extends Error {
|
|
2
|
-
|
|
2
|
+
constructor(chain: string, address: string);
|
|
3
3
|
}
|
|
4
4
|
export declare class UnsupportedChainError extends Error {
|
|
5
|
-
|
|
5
|
+
constructor(chain: string);
|
|
6
6
|
}
|
|
7
|
-
//# sourceMappingURL=types.d.ts.map
|
|
7
|
+
//# sourceMappingURL=types.d.ts.map
|
package/dist/types.js
CHANGED
|
@@ -1,15 +1,11 @@
|
|
|
1
1
|
export class UnsupportedAddressError extends Error {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
);
|
|
6
|
-
}
|
|
2
|
+
constructor(chain, address) {
|
|
3
|
+
super(`UnsupportedAddressError: Address [${address}] is not supported in current implementation of [${chain}] chain`);
|
|
4
|
+
}
|
|
7
5
|
}
|
|
8
6
|
export class UnsupportedChainError extends Error {
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
);
|
|
13
|
-
}
|
|
7
|
+
constructor(chain) {
|
|
8
|
+
super(`UnsupportedChainError: Address encoding does not support [${chain}] chain currently`);
|
|
9
|
+
}
|
|
14
10
|
}
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9saWIvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLHVCQUF3QixTQUFRLEtBQUs7SUFDaEQsWUFBWSxLQUFhLEVBQUUsT0FBZTtRQUN4QyxLQUFLLENBQ0gscUNBQXFDLE9BQU8sb0RBQW9ELEtBQUssU0FBUyxDQUMvRyxDQUFDO0lBQ0osQ0FBQztDQUNGO0FBRUQsTUFBTSxPQUFPLHFCQUFzQixTQUFRLEtBQUs7SUFDOUMsWUFBWSxLQUFhO1FBQ3ZCLEtBQUssQ0FDSCw2REFBNkQsS0FBSyxtQkFBbUIsQ0FDdEYsQ0FBQztJQUNKLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBVbnN1cHBvcnRlZEFkZHJlc3NFcnJvciBleHRlbmRzIEVycm9yIHtcbiAgY29uc3RydWN0b3IoY2hhaW46IHN0cmluZywgYWRkcmVzczogc3RyaW5nKSB7XG4gICAgc3VwZXIoXG4gICAgICBgVW5zdXBwb3J0ZWRBZGRyZXNzRXJyb3I6IEFkZHJlc3MgWyR7YWRkcmVzc31dIGlzIG5vdCBzdXBwb3J0ZWQgaW4gY3VycmVudCBpbXBsZW1lbnRhdGlvbiBvZiBbJHtjaGFpbn1dIGNoYWluYFxuICAgICk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIFVuc3VwcG9ydGVkQ2hhaW5FcnJvciBleHRlbmRzIEVycm9yIHtcbiAgY29uc3RydWN0b3IoY2hhaW46IHN0cmluZykge1xuICAgIHN1cGVyKFxuICAgICAgYFVuc3VwcG9ydGVkQ2hhaW5FcnJvcjogQWRkcmVzcyBlbmNvZGluZyBkb2VzIG5vdCBzdXBwb3J0IFske2NoYWlufV0gY2hhaW4gY3VycmVudGx5YFxuICAgICk7XG4gIH1cbn1cbiJdfQ==
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9saWIvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLHVCQUF3QixTQUFRLEtBQUs7SUFDaEQsWUFBWSxLQUFhLEVBQUUsT0FBZTtRQUN4QyxLQUFLLENBQ0gscUNBQXFDLE9BQU8sb0RBQW9ELEtBQUssU0FBUyxDQUMvRyxDQUFDO0lBQ0osQ0FBQztDQUNGO0FBRUQsTUFBTSxPQUFPLHFCQUFzQixTQUFRLEtBQUs7SUFDOUMsWUFBWSxLQUFhO1FBQ3ZCLEtBQUssQ0FDSCw2REFBNkQsS0FBSyxtQkFBbUIsQ0FDdEYsQ0FBQztJQUNKLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBVbnN1cHBvcnRlZEFkZHJlc3NFcnJvciBleHRlbmRzIEVycm9yIHtcbiAgY29uc3RydWN0b3IoY2hhaW46IHN0cmluZywgYWRkcmVzczogc3RyaW5nKSB7XG4gICAgc3VwZXIoXG4gICAgICBgVW5zdXBwb3J0ZWRBZGRyZXNzRXJyb3I6IEFkZHJlc3MgWyR7YWRkcmVzc31dIGlzIG5vdCBzdXBwb3J0ZWQgaW4gY3VycmVudCBpbXBsZW1lbnRhdGlvbiBvZiBbJHtjaGFpbn1dIGNoYWluYFxuICAgICk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIFVuc3VwcG9ydGVkQ2hhaW5FcnJvciBleHRlbmRzIEVycm9yIHtcbiAgY29uc3RydWN0b3IoY2hhaW46IHN0cmluZykge1xuICAgIHN1cGVyKFxuICAgICAgYFVuc3VwcG9ydGVkQ2hhaW5FcnJvcjogQWRkcmVzcyBlbmNvZGluZyBkb2VzIG5vdCBzdXBwb3J0IFske2NoYWlufV0gY2hhaW4gY3VycmVudGx5YFxuICAgICk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validator.d.ts","sourceRoot":"","sources":["../lib/validator.ts"],"names":[],"mappings":"AAYA;;;;GAIG;AACH,eAAO,MAAM,eAAe,UAAW,MAAM,WAAW,MAAM,KAAG,OAoBhE,CAAC"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { BITCOIN_CHAIN, CARDANO_CHAIN, ERGO_CHAIN, ETHEREUM_CHAIN, } from './const';
|
|
2
|
+
import { UnsupportedAddressError, UnsupportedChainError } from './types';
|
|
3
|
+
import * as ergoLib from 'ergo-lib-wasm-nodejs';
|
|
4
|
+
import * as cardanoLib from '@emurgo/cardano-serialization-lib-nodejs';
|
|
5
|
+
import * as bitcoinLib from 'bitcoinjs-lib';
|
|
6
|
+
import * as ethereumLib from 'ethers';
|
|
7
|
+
/**
|
|
8
|
+
* validates address of a chain
|
|
9
|
+
* @param chain
|
|
10
|
+
* @param address
|
|
11
|
+
*/
|
|
12
|
+
export const validateAddress = (chain, address) => {
|
|
13
|
+
switch (chain) {
|
|
14
|
+
case ERGO_CHAIN:
|
|
15
|
+
ergoLib.Address.from_base58(address);
|
|
16
|
+
return true;
|
|
17
|
+
case CARDANO_CHAIN:
|
|
18
|
+
cardanoLib.Address.from_bech32(address);
|
|
19
|
+
return true;
|
|
20
|
+
case BITCOIN_CHAIN:
|
|
21
|
+
bitcoinLib.address.fromBech32(address);
|
|
22
|
+
if (address.slice(0, 4) != 'bc1q')
|
|
23
|
+
throw new UnsupportedAddressError(chain, address);
|
|
24
|
+
return true;
|
|
25
|
+
case ETHEREUM_CHAIN:
|
|
26
|
+
if (address.toLowerCase() != address || !ethereumLib.isAddress(address))
|
|
27
|
+
throw new UnsupportedAddressError(chain, address);
|
|
28
|
+
return true;
|
|
29
|
+
default:
|
|
30
|
+
throw new UnsupportedChainError(chain);
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vbGliL3ZhbGlkYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsYUFBYSxFQUNiLGFBQWEsRUFDYixVQUFVLEVBQ1YsY0FBYyxHQUNmLE1BQU0sU0FBUyxDQUFDO0FBQ2pCLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxxQkFBcUIsRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUN6RSxPQUFPLEtBQUssT0FBTyxNQUFNLHNCQUFzQixDQUFDO0FBQ2hELE9BQU8sS0FBSyxVQUFVLE1BQU0sMENBQTBDLENBQUM7QUFDdkUsT0FBTyxLQUFLLFVBQVUsTUFBTSxlQUFlLENBQUM7QUFDNUMsT0FBTyxLQUFLLFdBQVcsTUFBTSxRQUFRLENBQUM7QUFFdEM7Ozs7R0FJRztBQUNILE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRyxDQUFDLEtBQWEsRUFBRSxPQUFlLEVBQVcsRUFBRTtJQUN6RSxRQUFRLEtBQUssRUFBRSxDQUFDO1FBQ2QsS0FBSyxVQUFVO1lBQ2IsT0FBTyxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDckMsT0FBTyxJQUFJLENBQUM7UUFDZCxLQUFLLGFBQWE7WUFDaEIsVUFBVSxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDeEMsT0FBTyxJQUFJLENBQUM7UUFDZCxLQUFLLGFBQWE7WUFDaEIsVUFBVSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDdkMsSUFBSSxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsSUFBSSxNQUFNO2dCQUMvQixNQUFNLElBQUksdUJBQXVCLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO1lBQ3BELE9BQU8sSUFBSSxDQUFDO1FBQ2QsS0FBSyxjQUFjO1lBQ2pCLElBQUksT0FBTyxDQUFDLFdBQVcsRUFBRSxJQUFJLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDO2dCQUNyRSxNQUFNLElBQUksdUJBQXVCLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO1lBQ3BELE9BQU8sSUFBSSxDQUFDO1FBQ2Q7WUFDRSxNQUFNLElBQUkscUJBQXFCLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDM0MsQ0FBQztBQUNILENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEJJVENPSU5fQ0hBSU4sXG4gIENBUkRBTk9fQ0hBSU4sXG4gIEVSR09fQ0hBSU4sXG4gIEVUSEVSRVVNX0NIQUlOLFxufSBmcm9tICcuL2NvbnN0JztcbmltcG9ydCB7IFVuc3VwcG9ydGVkQWRkcmVzc0Vycm9yLCBVbnN1cHBvcnRlZENoYWluRXJyb3IgfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCAqIGFzIGVyZ29MaWIgZnJvbSAnZXJnby1saWItd2FzbS1ub2RlanMnO1xuaW1wb3J0ICogYXMgY2FyZGFub0xpYiBmcm9tICdAZW11cmdvL2NhcmRhbm8tc2VyaWFsaXphdGlvbi1saWItbm9kZWpzJztcbmltcG9ydCAqIGFzIGJpdGNvaW5MaWIgZnJvbSAnYml0Y29pbmpzLWxpYic7XG5pbXBvcnQgKiBhcyBldGhlcmV1bUxpYiBmcm9tICdldGhlcnMnO1xuXG4vKipcbiAqIHZhbGlkYXRlcyBhZGRyZXNzIG9mIGEgY2hhaW5cbiAqIEBwYXJhbSBjaGFpblxuICogQHBhcmFtIGFkZHJlc3NcbiAqL1xuZXhwb3J0IGNvbnN0IHZhbGlkYXRlQWRkcmVzcyA9IChjaGFpbjogc3RyaW5nLCBhZGRyZXNzOiBzdHJpbmcpOiBib29sZWFuID0+IHtcbiAgc3dpdGNoIChjaGFpbikge1xuICAgIGNhc2UgRVJHT19DSEFJTjpcbiAgICAgIGVyZ29MaWIuQWRkcmVzcy5mcm9tX2Jhc2U1OChhZGRyZXNzKTtcbiAgICAgIHJldHVybiB0cnVlO1xuICAgIGNhc2UgQ0FSREFOT19DSEFJTjpcbiAgICAgIGNhcmRhbm9MaWIuQWRkcmVzcy5mcm9tX2JlY2gzMihhZGRyZXNzKTtcbiAgICAgIHJldHVybiB0cnVlO1xuICAgIGNhc2UgQklUQ09JTl9DSEFJTjpcbiAgICAgIGJpdGNvaW5MaWIuYWRkcmVzcy5mcm9tQmVjaDMyKGFkZHJlc3MpO1xuICAgICAgaWYgKGFkZHJlc3Muc2xpY2UoMCwgNCkgIT0gJ2JjMXEnKVxuICAgICAgICB0aHJvdyBuZXcgVW5zdXBwb3J0ZWRBZGRyZXNzRXJyb3IoY2hhaW4sIGFkZHJlc3MpO1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgY2FzZSBFVEhFUkVVTV9DSEFJTjpcbiAgICAgIGlmIChhZGRyZXNzLnRvTG93ZXJDYXNlKCkgIT0gYWRkcmVzcyB8fCAhZXRoZXJldW1MaWIuaXNBZGRyZXNzKGFkZHJlc3MpKVxuICAgICAgICB0aHJvdyBuZXcgVW5zdXBwb3J0ZWRBZGRyZXNzRXJyb3IoY2hhaW4sIGFkZHJlc3MpO1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgZGVmYXVsdDpcbiAgICAgIHRocm93IG5ldyBVbnN1cHBvcnRlZENoYWluRXJyb3IoY2hhaW4pO1xuICB9XG59O1xuIl19
|
package/lib/index.ts
CHANGED
package/lib/validator.ts
ADDED
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import {
|
|
2
|
+
BITCOIN_CHAIN,
|
|
3
|
+
CARDANO_CHAIN,
|
|
4
|
+
ERGO_CHAIN,
|
|
5
|
+
ETHEREUM_CHAIN,
|
|
6
|
+
} from './const';
|
|
7
|
+
import { UnsupportedAddressError, UnsupportedChainError } from './types';
|
|
8
|
+
import * as ergoLib from 'ergo-lib-wasm-nodejs';
|
|
9
|
+
import * as cardanoLib from '@emurgo/cardano-serialization-lib-nodejs';
|
|
10
|
+
import * as bitcoinLib from 'bitcoinjs-lib';
|
|
11
|
+
import * as ethereumLib from 'ethers';
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* validates address of a chain
|
|
15
|
+
* @param chain
|
|
16
|
+
* @param address
|
|
17
|
+
*/
|
|
18
|
+
export const validateAddress = (chain: string, address: string): boolean => {
|
|
19
|
+
switch (chain) {
|
|
20
|
+
case ERGO_CHAIN:
|
|
21
|
+
ergoLib.Address.from_base58(address);
|
|
22
|
+
return true;
|
|
23
|
+
case CARDANO_CHAIN:
|
|
24
|
+
cardanoLib.Address.from_bech32(address);
|
|
25
|
+
return true;
|
|
26
|
+
case BITCOIN_CHAIN:
|
|
27
|
+
bitcoinLib.address.fromBech32(address);
|
|
28
|
+
if (address.slice(0, 4) != 'bc1q')
|
|
29
|
+
throw new UnsupportedAddressError(chain, address);
|
|
30
|
+
return true;
|
|
31
|
+
case ETHEREUM_CHAIN:
|
|
32
|
+
if (address.toLowerCase() != address || !ethereumLib.isAddress(address))
|
|
33
|
+
throw new UnsupportedAddressError(chain, address);
|
|
34
|
+
return true;
|
|
35
|
+
default:
|
|
36
|
+
throw new UnsupportedChainError(chain);
|
|
37
|
+
}
|
|
38
|
+
};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@rosen-bridge/address-codec",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.3.0",
|
|
4
4
|
"description": "A Typescript package for encoding and decoding of addresses in Rosen bridge supported chains",
|
|
5
5
|
"repository": "https://github.com/rosen-bridge/utils",
|
|
6
6
|
"license": "GPL-3.0",
|
|
@@ -35,6 +35,7 @@
|
|
|
35
35
|
"dependencies": {
|
|
36
36
|
"@emurgo/cardano-serialization-lib-nodejs": "^11.5.0",
|
|
37
37
|
"bitcoinjs-lib": "^6.1.5",
|
|
38
|
-
"ergo-lib-wasm-nodejs": "^0.24.1"
|
|
38
|
+
"ergo-lib-wasm-nodejs": "^0.24.1",
|
|
39
|
+
"ethers": "^6.13.2"
|
|
39
40
|
}
|
|
40
41
|
}
|
package/tests/testData.ts
CHANGED
|
@@ -2,13 +2,21 @@ export const ergoAddress =
|
|
|
2
2
|
'9iMjQx8PzwBKXRvsFUJFJAPoy31znfEeBUGz8DRkcnJX4rJYjVd';
|
|
3
3
|
export const encodedErgoAddress =
|
|
4
4
|
'03f999da8e6e42660e4464d17d29e63bc006734a6710a24eb489b466323d3a9339';
|
|
5
|
+
export const invalidErgoAddress =
|
|
6
|
+
'9iMjQx8PzwBKXRvsFUJFJAPoy31znfEeBUGz8DRkcnJX4rJYjVD';
|
|
5
7
|
|
|
6
8
|
export const cardanoAddress =
|
|
7
9
|
'addr1qxxa3kfnnh40yqtepa5frt0tkw4a0rys7v33422lzt8glx43sqtd4vkhjzawajej8aujh27p5a54zx62xf3wvuplynqs3fsqet';
|
|
8
10
|
export const encodedCardanoAddress =
|
|
9
11
|
'018dd8d9339deaf201790f6891adebb3abd78c90f3231aa95f12ce8f9ab18016dab2d790baeecb323f792babc1a769511b4a3262e6703f24c1';
|
|
12
|
+
export const invalidCardanoAddress =
|
|
13
|
+
'addr1qxxa3kfnnh40yqtepa5frt0tkw4a0rys7v33422lzt8glx43sqtd4vkhjzawajej8aujh27p5a54zx62xf3wvuplynqs3fsqee';
|
|
10
14
|
|
|
11
15
|
export const bitcoinAddress = 'bc1qkgp89fjerymm5ltg0hygnumr0m2qa7n22gyw6h';
|
|
16
|
+
export const invalidBitcoinAddress =
|
|
17
|
+
'bc1qkgp89fjerymm5ltg0hygnumr0m2qa7n22gyw6';
|
|
18
|
+
export const tapRootBitcoinAddress =
|
|
19
|
+
'bc1pxhtmm7mjrafdkw46wc7lmjn3gyrmdm4q0dnmw8j225gxtwtq7mwqd7e24v';
|
|
12
20
|
export const encodedBitcoinAddress =
|
|
13
21
|
'0014b20272a6591937ba7d687dc889f3637ed40efa6a';
|
|
14
22
|
|
|
@@ -23,3 +31,6 @@ export const encodedEthereumAddress =
|
|
|
23
31
|
|
|
24
32
|
export const invalidEthereumAddressLength =
|
|
25
33
|
'0xb416c8a7ec94706a9ae2c26c11d320519482b1';
|
|
34
|
+
export const invalidEthereumIcapAddress = 'XE65GB6LDNXYOFTX0NSV3FUWKOWIXAMJK36';
|
|
35
|
+
export const invalidEthereumChecksumAddress =
|
|
36
|
+
'0x4838B106FCe9647Bdf1E7877BF73cE8B0BAD5f97';
|
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
import * as testData from './testData';
|
|
2
|
+
import {
|
|
3
|
+
UnsupportedAddressError,
|
|
4
|
+
UnsupportedChainError,
|
|
5
|
+
validateAddress,
|
|
6
|
+
} from '../lib';
|
|
7
|
+
import {
|
|
8
|
+
BITCOIN_CHAIN,
|
|
9
|
+
CARDANO_CHAIN,
|
|
10
|
+
ERGO_CHAIN,
|
|
11
|
+
ETHEREUM_CHAIN,
|
|
12
|
+
} from '../lib/const';
|
|
13
|
+
|
|
14
|
+
describe('validateAddress', () => {
|
|
15
|
+
/**
|
|
16
|
+
* @target `validateAddress` should validate Ergo address successfully
|
|
17
|
+
* @dependencies
|
|
18
|
+
* @scenario
|
|
19
|
+
* - run test
|
|
20
|
+
* @expected
|
|
21
|
+
* - to validate correct Ergo address
|
|
22
|
+
*/
|
|
23
|
+
it('should validate Ergo address successfully', () => {
|
|
24
|
+
const res = validateAddress(ERGO_CHAIN, testData.ergoAddress);
|
|
25
|
+
expect(res).toEqual(true);
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* @target `validateAddress` should throw error for wrong Ergo address
|
|
30
|
+
* @dependencies
|
|
31
|
+
* @scenario
|
|
32
|
+
* - run test
|
|
33
|
+
* @expected
|
|
34
|
+
* - to throw error for wrong Ergo address
|
|
35
|
+
*/
|
|
36
|
+
it('should throw error for wrong Ergo address', () => {
|
|
37
|
+
expect(() => {
|
|
38
|
+
validateAddress(ERGO_CHAIN, testData.invalidErgoAddress);
|
|
39
|
+
}).toThrow();
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* @target `validateAddress` should validate Cardano address successfully
|
|
44
|
+
* @dependencies
|
|
45
|
+
* @scenario
|
|
46
|
+
* - run test
|
|
47
|
+
* @expected
|
|
48
|
+
* - to validate correct Cardano address
|
|
49
|
+
*/
|
|
50
|
+
it('should validate Cardano address successfully', () => {
|
|
51
|
+
const res = validateAddress(CARDANO_CHAIN, testData.cardanoAddress);
|
|
52
|
+
expect(res).toEqual(true);
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* @target `validateAddress` should throw error for wrong Cardano address
|
|
57
|
+
* @dependencies
|
|
58
|
+
* @scenario
|
|
59
|
+
* - run test
|
|
60
|
+
* @expected
|
|
61
|
+
* - to throw error for wrong Cardano address
|
|
62
|
+
*/
|
|
63
|
+
it('should throw error for wrong Cardano address', () => {
|
|
64
|
+
expect(() => {
|
|
65
|
+
validateAddress(CARDANO_CHAIN, testData.invalidCardanoAddress);
|
|
66
|
+
}).toThrow();
|
|
67
|
+
});
|
|
68
|
+
|
|
69
|
+
/**
|
|
70
|
+
* @target `validateAddress` should validate Bitcoin address successfully
|
|
71
|
+
* @dependencies
|
|
72
|
+
* @scenario
|
|
73
|
+
* - run test
|
|
74
|
+
* @expected
|
|
75
|
+
* - to validate correct Bitcoin address
|
|
76
|
+
*/
|
|
77
|
+
it('should validate Bitcoin address successfully', () => {
|
|
78
|
+
const res = validateAddress(BITCOIN_CHAIN, testData.bitcoinAddress);
|
|
79
|
+
expect(res).toEqual(true);
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
/**
|
|
83
|
+
* @target `validateAddress` should throw error for Bitcoin taproot address
|
|
84
|
+
* @dependencies
|
|
85
|
+
* @scenario
|
|
86
|
+
* - run test
|
|
87
|
+
* @expected
|
|
88
|
+
* - to throw error for Bitcoin taproot address
|
|
89
|
+
*/
|
|
90
|
+
it('should throw error for Bitcoin taproot address', () => {
|
|
91
|
+
expect(() => {
|
|
92
|
+
validateAddress(BITCOIN_CHAIN, testData.tapRootBitcoinAddress);
|
|
93
|
+
}).toThrow(UnsupportedAddressError);
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
/**
|
|
97
|
+
* @target `validateAddress` should throw error for wrong Bitcoin address
|
|
98
|
+
* @dependencies
|
|
99
|
+
* @scenario
|
|
100
|
+
* - run test
|
|
101
|
+
* @expected
|
|
102
|
+
* - to throw error for wrong Bitcoin address
|
|
103
|
+
*/
|
|
104
|
+
it('should throw error for wrong Bitcoin address', () => {
|
|
105
|
+
expect(() => {
|
|
106
|
+
validateAddress(BITCOIN_CHAIN, testData.invalidBitcoinAddress);
|
|
107
|
+
}).toThrowError();
|
|
108
|
+
});
|
|
109
|
+
|
|
110
|
+
/**
|
|
111
|
+
* @target `validateAddress` should validate Ethereum address successfully
|
|
112
|
+
* @dependencies
|
|
113
|
+
* @scenario
|
|
114
|
+
* - run test
|
|
115
|
+
* @expected
|
|
116
|
+
* - to validate correct Ethereum address
|
|
117
|
+
*/
|
|
118
|
+
it('should validate Ethereum address successfully', () => {
|
|
119
|
+
const res = validateAddress(ETHEREUM_CHAIN, testData.ethereumAddress);
|
|
120
|
+
expect(res).toEqual(true);
|
|
121
|
+
});
|
|
122
|
+
|
|
123
|
+
/**
|
|
124
|
+
* @target `validateAddress` should throw error for ICAP Ethereum address
|
|
125
|
+
* @dependencies
|
|
126
|
+
* @scenario
|
|
127
|
+
* - run test
|
|
128
|
+
* @expected
|
|
129
|
+
* - to throw error for ICAP Ethereum address
|
|
130
|
+
*/
|
|
131
|
+
it('should throw error for ICAP Ethereum address', () => {
|
|
132
|
+
expect(() => {
|
|
133
|
+
validateAddress(ETHEREUM_CHAIN, testData.invalidEthereumIcapAddress);
|
|
134
|
+
}).toThrow(UnsupportedAddressError);
|
|
135
|
+
});
|
|
136
|
+
|
|
137
|
+
/**
|
|
138
|
+
* @target `validateAddress` should throw error for Ethereum address with checksum
|
|
139
|
+
* @dependencies
|
|
140
|
+
* @scenario
|
|
141
|
+
* - run test
|
|
142
|
+
* @expected
|
|
143
|
+
* - to throw error for Ethereum address with checksum
|
|
144
|
+
*/
|
|
145
|
+
it('should throw error for Ethereum address with checksum', () => {
|
|
146
|
+
expect(() => {
|
|
147
|
+
validateAddress(ETHEREUM_CHAIN, testData.invalidEthereumChecksumAddress);
|
|
148
|
+
}).toThrow(UnsupportedAddressError);
|
|
149
|
+
});
|
|
150
|
+
|
|
151
|
+
/**
|
|
152
|
+
* @target `validateAddress` should throw error for wrong Ethereum address
|
|
153
|
+
* @dependencies
|
|
154
|
+
* @scenario
|
|
155
|
+
* - run test
|
|
156
|
+
* @expected
|
|
157
|
+
* - to throw error for wrong Ethereum address
|
|
158
|
+
*/
|
|
159
|
+
it('should throw error for wrong Ethereum address', () => {
|
|
160
|
+
expect(() => {
|
|
161
|
+
validateAddress(ETHEREUM_CHAIN, testData.invalidEthereumAddressLength);
|
|
162
|
+
}).toThrow(UnsupportedAddressError);
|
|
163
|
+
});
|
|
164
|
+
|
|
165
|
+
/**
|
|
166
|
+
* @target `validateAddress` should throw error when chain is not supported
|
|
167
|
+
* @dependencies
|
|
168
|
+
* @scenario
|
|
169
|
+
* - run test
|
|
170
|
+
* @expected
|
|
171
|
+
* - it should throw UnsupportedChain error
|
|
172
|
+
*/
|
|
173
|
+
it('should throw error when chain is not supported', () => {
|
|
174
|
+
expect(() => {
|
|
175
|
+
validateAddress('unsupported-chain', '0011223344');
|
|
176
|
+
}).toThrow(UnsupportedChainError);
|
|
177
|
+
});
|
|
178
|
+
});
|