+tests.push(async () => {
+ const a = get_chanman();
+ const b = get_chanman();
+
+ const ignorer = ldk.IgnoringMessageHandler.constructor_new();
+ const pm_a = ldk.PeerManager.constructor_new(a.chan_man.as_ChannelMessageHandler(), ignorer.as_RoutingMessageHandler(), a.node_secret, a.node_secret, a.logger, ignorer.as_CustomMessageHandler());
+ const pm_b = ldk.PeerManager.constructor_new(b.chan_man.as_ChannelMessageHandler(), ignorer.as_RoutingMessageHandler(), b.node_secret, b.node_secret, b.logger, ignorer.as_CustomMessageHandler());
+
+ var sock_b: ldk.SocketDescriptor;
+ const sock_a = ldk.SocketDescriptor.new_impl({
+ send_data(data: Uint8Array, resume_read: boolean): number {
+ console.assert(pm_b.read_event(sock_b, data) instanceof ldk.Result_boolPeerHandleErrorZ_OK);
+ return data.length;
+ },
+ disconnect_socket(): void {
+ console.assert(false);
+ },
+ eq(other: ldk.SocketDescriptor): boolean {
+ return other.hash() == this.hash();
+ },
+ hash(): bigint {
+ return BigInt(1);
+ }
+ } as ldk.SocketDescriptorInterface);
+ sock_b = ldk.SocketDescriptor.new_impl({
+ send_data(data: Uint8Array, resume_read: boolean): number {
+ console.assert(pm_a.read_event(sock_a, data) instanceof ldk.Result_boolPeerHandleErrorZ_OK);
+ return data.length;
+ },
+ disconnect_socket(): void {
+ console.assert(false);
+ },
+ eq(other: ldk.SocketDescriptor): boolean {
+ return other.hash() == this.hash();
+ },
+ hash(): bigint {
+ return BigInt(2);
+ }
+ } as ldk.SocketDescriptorInterface);
+
+ const v4_netaddr = ldk.NetAddress.constructor_ipv4(Uint8Array.from([42,0,42,1]), 9735);
+ console.assert(pm_b.new_inbound_connection(sock_b, ldk.Option_NetAddressZ.constructor_some(v4_netaddr)) instanceof ldk.Result_NonePeerHandleErrorZ_OK);
+ const init_bytes = pm_a.new_outbound_connection(b.node_id, sock_a, ldk.Option_NetAddressZ.constructor_none());
+ if (!(init_bytes instanceof ldk.Result_CVec_u8ZPeerHandleErrorZ_OK)) return false;
+ console.assert(pm_b.read_event(sock_b, init_bytes.res) instanceof ldk.Result_boolPeerHandleErrorZ_OK);
+
+ console.assert(pm_a.get_peer_node_ids().length == 0);
+ console.assert(pm_b.get_peer_node_ids().length == 0);
+
+ pm_b.process_events();
+ pm_a.process_events();
+ pm_b.process_events();
+
+ console.assert(pm_a.get_peer_node_ids().length == 1);
+ console.assert(pm_b.get_peer_node_ids().length == 1);
+
+ const chan_create_res = a.chan_man.create_channel(b.node_id, BigInt(1000000), BigInt(400), BigInt(0), ldk.UserConfig.constructor_default());
+ if (!chan_create_res.is_ok()) return false;
+
+ pm_a.process_events();
+ pm_b.process_events();
+
+ const event = get_event(a.chan_man);
+ if (!(event instanceof ldk.Event_FundingGenerationReady)) return false;
+
+ return true;
+});
+
+tests.push(async () => {
+ // Test that we can do basic locking of a NetworkGraph
+ const genesis_hash = new Uint8Array([0x00, 0x00, 0x00, 0x00, 0x00, 0x19, 0xd6, 0x68, 0x9c, 0x08, 0x5a, 0xe1, 0x65, 0x83, 0x1e, 0x93, 0x4f, 0xf7, 0x63, 0xae, 0x46, 0xa2, 0xa6, 0xc1, 0x72, 0xb3, 0xf1, 0xb6, 0x0a, 0x8c, 0xe2, 0x6f]);
+ const logger = ldk.Logger.new_impl({
+ log(record: ldk.Record): void {
+ if (record.get_level() != ldk.Level.LDKLevel_Gossip)
+ console.log(record.get_module_path() + ": " + record.get_args());
+ }
+ } as ldk.LoggerInterface);
+ const network_graph = ldk.NetworkGraph.constructor_new(genesis_hash, logger);
+ const graph_lock_1 = network_graph.read_only();
+ graph_lock_1.free();
+ const graph_lock_2 = network_graph.read_only();
+ graph_lock_2.free();