86b6b3a2af9f1871fc5bfe6329da68f647fa0a9a
[ldk-java] / node-net / test / test.mts
1 import * as ldk from "../../ts/index.mjs";
2 import * as node_net from '../net.mjs';
3
4 import * as fs from 'fs';
5
6 const wasm_file = fs.readFileSync('../ts/liblightningjs.wasm');
7 await ldk.initializeWasmFromBinary(wasm_file);
8
9 const logger_a = ldk.Logger.new_impl({
10         log(record: ldk.Record): void {
11                 console.log(record.get_module_path() + ": " + record.get_args());
12         }
13 } as ldk.LoggerInterface);
14 const logger_b = logger_a;
15
16 const node_a_secret = new Uint8Array(32);
17 for (var i = 0; i < 32; i++) node_a_secret[i] = 42;
18 // The public key for a secret key of all 42s:
19 const node_a_pk = new Uint8Array([3, 91, 229, 233, 71, 130, 9, 103, 74, 150, 230, 15, 31, 3, 127, 97, 118, 84, 15, 208, 1, 250, 29, 100, 105, 71, 112, 197, 106, 119, 9, 196, 44]);
20
21 const node_b_secret = new Uint8Array(32);
22 for (var i = 0; i < 32; i++) node_b_secret[i] = 43;
23
24 const rng_seed = new Uint8Array(32);
25 const routing_handler = ldk.IgnoringMessageHandler.constructor_new().as_RoutingMessageHandler();
26 const chan_handler = ldk.ErroringMessageHandler.constructor_new().as_ChannelMessageHandler();
27 const cust_handler = ldk.IgnoringMessageHandler.constructor_new().as_CustomMessageHandler();
28 const onion_handler = ldk.IgnoringMessageHandler.constructor_new().as_OnionMessageHandler();
29
30 const a_pm = ldk.PeerManager.constructor_new(chan_handler, routing_handler, onion_handler, node_a_secret, 0xdeadbeefn, rng_seed, logger_a, cust_handler);
31 const a_net_handler = new node_net.NodeLDKNet(a_pm);
32 var port = 10000;
33 for (; port < 11000; port++) {
34         try {
35                 // Try ports until we find one we can bind to.
36                 await a_net_handler.bind_listener("127.0.0.1", port);
37                 break;
38         } catch(_) {}
39 }
40
41 const b_pm = ldk.PeerManager.constructor_new(chan_handler, routing_handler, onion_handler, node_b_secret, 0xdeadbeefn, rng_seed, logger_b, cust_handler);
42 const b_net_handler = new node_net.NodeLDKNet(b_pm);
43 await b_net_handler.connect_peer("127.0.0.1", port, node_a_pk);
44
45 try {
46         // Ensure we get an error if we try to bind the same port twice.
47         await a_net_handler.bind_listener("127.0.0.1", port);
48         console.assert(false);
49 } catch(_) {}
50
51 await new Promise<void>(resolve => {
52         // Wait until the peers are connected and have exchanged the initial handshake
53         var timer: ReturnType<typeof setInterval>;
54         timer = setInterval(function() {
55                 if (a_pm.get_peer_node_ids().length == 1 && b_pm.get_peer_node_ids().length == 1) {
56                         resolve();
57                         clearInterval(timer);
58                 }
59         }, 500);
60 });
61
62 b_pm.disconnect_by_node_id(node_a_pk, false);
63 await new Promise<void>(resolve => {
64         // Wait until A learns the connection is closed from the socket closure
65         var timer: ReturnType<typeof setInterval>;
66         timer = setInterval(function() {
67                 if (a_pm.get_peer_node_ids().length == 0 && b_pm.get_peer_node_ids().length == 0) {
68                         resolve();
69                         clearInterval(timer);
70                 }
71         }, 500);
72 });
73
74 a_net_handler.stop();
75 b_net_handler.stop();
76
77 function arr_eq(a: number[]|Uint8Array, b: number[]|Uint8Array): boolean {
78         return a.length == b.length && a.every((val, idx) => val == b[idx]);
79 }
80
81 const v4_parse = node_net.NodeLDKNet["v4_addr_from_ip"];
82 console.assert((v4_parse("127.0.0.1", 4242) as ldk.NetAddress_IPv4).port == 4242);
83 console.assert(arr_eq((v4_parse("127.0.0.1", 4242) as ldk.NetAddress_IPv4).addr, [127,0,0,1]));
84 console.assert(arr_eq((v4_parse("0.0.0.0", 4242) as ldk.NetAddress_IPv4).addr, [0,0,0,0]));
85
86 const v6_parse = node_net.NodeLDKNet["v6_addr_from_ip"];
87 console.assert((v6_parse("::", 4242) as ldk.NetAddress_IPv4).port == 4242);
88 console.assert(arr_eq((v6_parse("::", 4242) as ldk.NetAddress_IPv6).addr,
89         [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]));
90 console.assert(arr_eq((v6_parse("fe80::", 4242) as ldk.NetAddress_IPv6).addr,
91         [0xfe,0x80,0,0,0,0,0,0,0,0,0,0,0,0,0,0]));
92 console.assert(arr_eq((v6_parse("fe80::42", 4242) as ldk.NetAddress_IPv6).addr,
93         [0xfe,0x80,0,0,0,0,0,0,0,0,0,0,0,0,0,0x42]));
94 console.assert(arr_eq((v6_parse("fe80:A:b::", 4242) as ldk.NetAddress_IPv6).addr,
95         [0xfe,0x80,0,0xa,0,0xb,0,0,0,0,0,0,0,0,0,0]));
96 console.assert(arr_eq((v6_parse("2001:1:bad::beef:cafe", 4242) as ldk.NetAddress_IPv6).addr,
97         [0x20, 0x01, 0, 1, 0xb, 0xad, 0, 0, 0, 0, 0, 0, 0xbe, 0xef, 0xca, 0xfe]));