js-waku/src/lib/node.spec.ts

192 lines
5.8 KiB
TypeScript
Raw Normal View History

2021-03-10 14:24:23 +11:00
import test from 'ava';
2021-03-15 17:29:48 +11:00
import Libp2p from 'libp2p';
2021-03-10 14:55:16 +11:00
import Pubsub from 'libp2p-interfaces/src/pubsub';
2021-03-10 14:24:23 +11:00
2021-03-10 17:39:53 +11:00
import { NimWaku } from '../test_utils/nim_waku';
2021-03-10 14:24:23 +11:00
import { createNode } from './node';
2021-03-10 16:22:49 +11:00
import { Message } from './waku_message';
import { CODEC, TOPIC, WakuRelay } from './waku_relay';
2021-03-10 14:24:23 +11:00
test('Publishes message', async (t) => {
2021-03-12 14:23:21 +11:00
const message = Message.fromUtf8String('Bird bird bird, bird is the word!');
2021-03-10 14:24:23 +11:00
const [node1, node2] = await Promise.all([createNode(), createNode()]);
2021-03-10 16:22:49 +11:00
const wakuRelayNode1 = new WakuRelay(node1.pubsub);
const wakuRelayNode2 = new WakuRelay(node2.pubsub);
2021-03-10 14:24:23 +11:00
// Add node's 2 data to the PeerStore
node1.peerStore.addressBook.set(node2.peerId, node2.multiaddrs);
await node1.dial(node2.peerId);
await wakuRelayNode1.subscribe();
await new Promise((resolve) =>
node2.pubsub.once('pubsub:subscription-change', (...args) => resolve(args))
);
2021-03-10 14:24:23 +11:00
2021-03-10 14:55:16 +11:00
// Setup the promise before publishing to ensure the event is not missed
const promise = waitForNextData(node1.pubsub);
2021-03-10 14:24:23 +11:00
await wakuRelayNode2.publish(message);
2021-03-10 14:24:23 +11:00
2021-03-10 14:55:16 +11:00
const node1Received = await promise;
2021-03-10 14:24:23 +11:00
2021-03-10 16:22:49 +11:00
t.true(node1Received.isEqualTo(message));
2021-03-10 14:24:23 +11:00
});
2021-03-10 14:55:16 +11:00
test('Registers waku relay protocol', async (t) => {
const node = await createNode();
const protocols = Array.from(node.upgrader.protocols.keys());
t.truthy(protocols.findIndex((value) => value == CODEC));
});
test('Does not register any sub protocol', async (t) => {
const node = await createNode();
const protocols = Array.from(node.upgrader.protocols.keys());
t.truthy(protocols.findIndex((value) => value.match(/sub/)));
});
test('Nim-interop: nim-waku node connects to js node', async (t) => {
2021-03-10 17:39:53 +11:00
const node = await createNode();
2021-03-11 10:54:35 +11:00
const peerId = node.peerId.toB58String();
const localMultiaddr = node.multiaddrs.find((addr) =>
addr.toString().match(/127\.0\.0\.1/)
);
const multiAddrWithId = localMultiaddr + '/p2p/' + peerId;
const nimWaku = new NimWaku(t.title);
await nimWaku.start({ staticnode: multiAddrWithId });
2021-03-10 17:39:53 +11:00
const nimPeers = await nimWaku.peers();
2021-03-10 17:39:53 +11:00
t.deepEqual(nimPeers, [
{
multiaddr: multiAddrWithId,
protocol: CODEC,
connected: true,
},
]);
const nimPeerId = await nimWaku.getPeerId();
const jsPeers = node.peerStore.peers;
t.true(jsPeers.has(nimPeerId.toB58String()));
2021-03-10 17:39:53 +11:00
});
test('Nim-interop: js node receives default subscription from nim node', async (t) => {
const node = await createNode();
const peerId = node.peerId.toB58String();
const localMultiaddr = node.multiaddrs.find((addr) =>
addr.toString().match(/127\.0\.0\.1/)
);
const multiAddrWithId = localMultiaddr + '/p2p/' + peerId;
const nimWaku = new NimWaku(t.title);
await nimWaku.start({ staticnode: multiAddrWithId });
const nimPeerId = await nimWaku.getPeerId();
const subscribers = node.pubsub.getSubscribers(TOPIC);
t.true(subscribers.includes(nimPeerId.toB58String()));
});
test('Nim-interop: js node sends message to nim node', async (t) => {
const message = Message.fromUtf8String('This is a message');
const node = await createNode();
const wakuRelayNode = new WakuRelay(node.pubsub);
// TODO: nim-waku does follow the `StrictNoSign` policy hence we need to change
// it for nim-waku to process our messages. Can be removed once
// https://github.com/status-im/nim-waku/issues/422 is fixed
node.pubsub.globalSignaturePolicy = 'StrictSign';
const peerId = node.peerId.toB58String();
const localMultiaddr = node.multiaddrs.find((addr) =>
addr.toString().match(/127\.0\.0\.1/)
);
const multiAddrWithId = localMultiaddr + '/p2p/' + peerId;
const nimWaku = new NimWaku(t.title);
await nimWaku.start({ staticnode: multiAddrWithId });
2021-03-15 17:29:48 +11:00
await patchPeerStore(nimWaku, node);
await wakuRelayNode.publish(message);
await nimWaku.waitForLog('WakuMessage received');
const msgs = await nimWaku.messages();
t.is(msgs[0].contentTopic, message.contentTopic);
t.is(msgs[0].version, message.version);
const payload = Buffer.from(msgs[0].payload);
t.is(Buffer.compare(payload, message.payload), 0);
});
test('Nim-interop: nim node sends message to js node', async (t) => {
const message = Message.fromUtf8String('Here is another message.');
const node = await createNode();
const wakuRelayNode = new WakuRelay(node.pubsub);
const peerId = node.peerId.toB58String();
const localMultiaddr = node.multiaddrs.find((addr) =>
addr.toString().match(/127\.0\.0\.1/)
);
const multiAddrWithId = localMultiaddr + '/p2p/' + peerId;
const nimWaku = new NimWaku(t.title);
await nimWaku.start({ staticnode: multiAddrWithId });
await patchPeerStore(nimWaku, node);
await wakuRelayNode.subscribe();
2021-03-16 13:45:18 +11:00
await new Promise((resolve) =>
node.pubsub.once('gossipsub:heartbeat', resolve)
);
const receivedPromise = waitForNextData(node.pubsub);
await nimWaku.sendMessage(message);
const receivedMsg = await receivedPromise;
t.is(receivedMsg.contentTopic, message.contentTopic);
t.is(receivedMsg.version, message.version);
const payload = Buffer.from(receivedMsg.payload);
t.is(Buffer.compare(payload, message.payload), 0);
});
2021-03-10 16:22:49 +11:00
function waitForNextData(pubsub: Pubsub): Promise<Message> {
2021-03-10 14:55:16 +11:00
return new Promise((resolve) => {
pubsub.once(TOPIC, resolve);
2021-03-10 14:56:12 +11:00
}).then((msg: any) => {
2021-03-10 16:22:49 +11:00
return Message.fromBinary(msg.data);
2021-03-10 14:55:16 +11:00
});
}
2021-03-15 17:29:48 +11:00
// TODO: Remove this hack, tracked with https://github.com/status-im/nim-waku/issues/419
async function patchPeerStore(nimWaku: NimWaku, node: Libp2p) {
const nimPeerId = await nimWaku.getPeerId();
node.identifyService!.peerStore.protoBook.set(nimPeerId, [CODEC]);
const peer = node.peerStore.peers.get(nimPeerId.toB58String());
if (!peer) {
throw 'Did not find nim-waku node in peers';
}
peer.protocols = [CODEC];
node.peerStore.peers.set(nimPeerId.toB58String(), peer);
await new Promise((resolve) =>
node.pubsub.once('gossipsub:heartbeat', resolve)
);
}