@libp2p/interface-compliance-tests 1.1.7 → 1.1.11
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/src/mocks/connection.d.ts +12 -2
- package/dist/src/mocks/connection.d.ts.map +1 -1
- package/dist/src/mocks/connection.js +59 -33
- package/dist/src/mocks/connection.js.map +1 -1
- package/dist/src/mocks/multiaddr-connection.d.ts +2 -1
- package/dist/src/mocks/multiaddr-connection.d.ts.map +1 -1
- package/dist/src/mocks/multiaddr-connection.js +2 -2
- package/dist/src/mocks/multiaddr-connection.js.map +1 -1
- package/dist/src/mocks/registrar.d.ts +11 -2
- package/dist/src/mocks/registrar.d.ts.map +1 -1
- package/dist/src/mocks/registrar.js +47 -5
- package/dist/src/mocks/registrar.js.map +1 -1
- package/dist/src/mocks/upgrader.d.ts.map +1 -1
- package/dist/src/mocks/upgrader.js +8 -2
- package/dist/src/mocks/upgrader.js.map +1 -1
- package/dist/src/pubsub/api.d.ts +3 -2
- package/dist/src/pubsub/api.d.ts.map +1 -1
- package/dist/src/pubsub/api.js +23 -13
- package/dist/src/pubsub/api.js.map +1 -1
- package/dist/src/pubsub/connection-handlers.d.ts +3 -2
- package/dist/src/pubsub/connection-handlers.d.ts.map +1 -1
- package/dist/src/pubsub/connection-handlers.js +165 -69
- package/dist/src/pubsub/connection-handlers.js.map +1 -1
- package/dist/src/pubsub/emit-self.d.ts +3 -2
- package/dist/src/pubsub/emit-self.d.ts.map +1 -1
- package/dist/src/pubsub/emit-self.js +15 -4
- package/dist/src/pubsub/emit-self.js.map +1 -1
- package/dist/src/pubsub/index.d.ts +6 -3
- package/dist/src/pubsub/index.d.ts.map +1 -1
- package/dist/src/pubsub/index.js.map +1 -1
- package/dist/src/pubsub/messages.d.ts +3 -2
- package/dist/src/pubsub/messages.d.ts.map +1 -1
- package/dist/src/pubsub/messages.js +42 -39
- package/dist/src/pubsub/messages.js.map +1 -1
- package/dist/src/pubsub/multiple-nodes.d.ts +3 -2
- package/dist/src/pubsub/multiple-nodes.d.ts.map +1 -1
- package/dist/src/pubsub/multiple-nodes.js +172 -89
- package/dist/src/pubsub/multiple-nodes.js.map +1 -1
- package/dist/src/pubsub/two-nodes.d.ts +3 -2
- package/dist/src/pubsub/two-nodes.d.ts.map +1 -1
- package/dist/src/pubsub/two-nodes.js +96 -40
- package/dist/src/pubsub/two-nodes.js.map +1 -1
- package/dist/src/pubsub/utils.d.ts +2 -2
- package/dist/src/pubsub/utils.d.ts.map +1 -1
- package/dist/src/pubsub/utils.js +7 -9
- package/dist/src/pubsub/utils.js.map +1 -1
- package/dist/src/stream-muxer/close-test.d.ts.map +1 -1
- package/dist/src/stream-muxer/close-test.js +5 -2
- package/dist/src/stream-muxer/close-test.js.map +1 -1
- package/package.json +8 -5
- package/src/mocks/connection.ts +83 -34
- package/src/mocks/multiaddr-connection.ts +3 -2
- package/src/mocks/registrar.ts +65 -7
- package/src/mocks/upgrader.ts +8 -2
- package/src/pubsub/api.ts +29 -15
- package/src/pubsub/connection-handlers.ts +186 -75
- package/src/pubsub/emit-self.ts +19 -7
- package/src/pubsub/index.ts +6 -3
- package/src/pubsub/messages.ts +59 -44
- package/src/pubsub/multiple-nodes.ts +197 -102
- package/src/pubsub/two-nodes.ts +111 -48
- package/src/pubsub/utils.ts +9 -10
- package/src/stream-muxer/close-test.ts +5 -2
|
@@ -5,7 +5,10 @@ import pDefer from 'p-defer';
|
|
|
5
5
|
import pWaitFor from 'p-wait-for';
|
|
6
6
|
import { toString as uint8ArrayToString } from 'uint8arrays/to-string';
|
|
7
7
|
import { fromString as uint8ArrayFromString } from 'uint8arrays/from-string';
|
|
8
|
-
import {
|
|
8
|
+
import { connectPeers, mockRegistrar } from '../mocks/registrar.js';
|
|
9
|
+
import { createEd25519PeerId } from '@libp2p/peer-id-factory';
|
|
10
|
+
import { CustomEvent } from '@libp2p/interfaces';
|
|
11
|
+
import { waitForSubscriptionUpdate } from './utils.js';
|
|
9
12
|
const topic = 'foo';
|
|
10
13
|
function shouldNotHappen() {
|
|
11
14
|
expect.fail();
|
|
@@ -14,21 +17,42 @@ export default (common) => {
|
|
|
14
17
|
describe('pubsub with two nodes', () => {
|
|
15
18
|
let psA;
|
|
16
19
|
let psB;
|
|
20
|
+
let peerIdA;
|
|
21
|
+
let peerIdB;
|
|
22
|
+
let registrarA;
|
|
23
|
+
let registrarB;
|
|
17
24
|
// Create pubsub nodes and connect them
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
25
|
+
beforeEach(async () => {
|
|
26
|
+
peerIdA = await createEd25519PeerId();
|
|
27
|
+
peerIdB = await createEd25519PeerId();
|
|
28
|
+
registrarA = mockRegistrar();
|
|
29
|
+
registrarB = mockRegistrar();
|
|
30
|
+
psA = await common.setup({
|
|
31
|
+
peerId: peerIdA,
|
|
32
|
+
registrar: registrarA,
|
|
33
|
+
emitSelf: true
|
|
34
|
+
});
|
|
35
|
+
psB = await common.setup({
|
|
36
|
+
peerId: peerIdB,
|
|
37
|
+
registrar: registrarB,
|
|
38
|
+
emitSelf: false
|
|
39
|
+
});
|
|
23
40
|
// Start pubsub and connect nodes
|
|
24
41
|
await psA.start();
|
|
25
42
|
await psB.start();
|
|
26
|
-
|
|
27
|
-
|
|
43
|
+
expect(psA.getPeers()).to.be.empty();
|
|
44
|
+
expect(psB.getPeers()).to.be.empty();
|
|
45
|
+
await connectPeers(psA.multicodecs[0], {
|
|
46
|
+
peerId: peerIdA,
|
|
47
|
+
registrar: registrarA
|
|
48
|
+
}, {
|
|
49
|
+
peerId: peerIdB,
|
|
50
|
+
registrar: registrarB
|
|
51
|
+
});
|
|
28
52
|
// Wait for peers to be ready in pubsub
|
|
29
|
-
await pWaitFor(() => psA.
|
|
53
|
+
await pWaitFor(() => psA.getPeers().length === 1 && psB.getPeers().length === 1);
|
|
30
54
|
});
|
|
31
|
-
|
|
55
|
+
afterEach(async () => {
|
|
32
56
|
sinon.restore();
|
|
33
57
|
await psA.stop();
|
|
34
58
|
await psB.stop();
|
|
@@ -38,12 +62,12 @@ export default (common) => {
|
|
|
38
62
|
const defer = pDefer();
|
|
39
63
|
psB.addEventListener('pubsub:subscription-change', (evt) => {
|
|
40
64
|
const { peerId: changedPeerId, subscriptions: changedSubs } = evt.detail;
|
|
41
|
-
|
|
42
|
-
expect(psB.
|
|
43
|
-
|
|
44
|
-
expect(changedPeerId
|
|
65
|
+
expect(psA.getTopics()).to.deep.equal([topic]);
|
|
66
|
+
expect(psB.getPeers()).to.have.lengthOf(1);
|
|
67
|
+
expect(psB.getSubscribers(topic).map(p => p.toString())).to.deep.equal([peerIdA.toString()]);
|
|
68
|
+
expect(changedPeerId).to.deep.equal(psB.getPeers()[0]);
|
|
45
69
|
expect(changedSubs).to.have.lengthOf(1);
|
|
46
|
-
expect(changedSubs[0].
|
|
70
|
+
expect(changedSubs[0].topic).to.equal(topic);
|
|
47
71
|
expect(changedSubs[0].subscribe).to.equal(true);
|
|
48
72
|
defer.resolve();
|
|
49
73
|
}, {
|
|
@@ -65,7 +89,11 @@ export default (common) => {
|
|
|
65
89
|
psB.addEventListener(topic, shouldNotHappen, {
|
|
66
90
|
once: true
|
|
67
91
|
});
|
|
68
|
-
|
|
92
|
+
await Promise.all([
|
|
93
|
+
waitForSubscriptionUpdate(psA, psB),
|
|
94
|
+
waitForSubscriptionUpdate(psB, psA)
|
|
95
|
+
]);
|
|
96
|
+
void psA.dispatchEvent(new CustomEvent(topic, { detail: uint8ArrayFromString('hey') }));
|
|
69
97
|
return await defer.promise;
|
|
70
98
|
});
|
|
71
99
|
it('Publish to a topic in nodeB', async () => {
|
|
@@ -87,7 +115,11 @@ export default (common) => {
|
|
|
87
115
|
psB.addEventListener(topic, shouldNotHappen, {
|
|
88
116
|
once: true
|
|
89
117
|
});
|
|
90
|
-
|
|
118
|
+
await Promise.all([
|
|
119
|
+
waitForSubscriptionUpdate(psA, psB),
|
|
120
|
+
waitForSubscriptionUpdate(psB, psA)
|
|
121
|
+
]);
|
|
122
|
+
void psB.dispatchEvent(new CustomEvent(topic, { detail: uint8ArrayFromString('banana') }));
|
|
91
123
|
return await defer.promise;
|
|
92
124
|
});
|
|
93
125
|
it('Publish 10 msg to a topic in nodeB', async () => {
|
|
@@ -100,51 +132,75 @@ export default (common) => {
|
|
|
100
132
|
function receivedMsg(evt) {
|
|
101
133
|
const msg = evt.detail;
|
|
102
134
|
expect(uint8ArrayToString(msg.data)).to.equal('banana');
|
|
103
|
-
expect(msg.from).to.
|
|
104
|
-
expect(msg.seqno).to.be.a('
|
|
105
|
-
expect(msg.
|
|
135
|
+
expect(msg.from.toString()).to.equal(peerIdB.toString());
|
|
136
|
+
expect(msg.seqno).to.be.a('BigInt');
|
|
137
|
+
expect(msg.topic).to.be.equal(topic);
|
|
106
138
|
if (++counter === 10) {
|
|
107
139
|
psA.removeEventListener(topic, receivedMsg);
|
|
108
140
|
psB.removeEventListener(topic, shouldNotHappen);
|
|
109
141
|
defer.resolve();
|
|
110
142
|
}
|
|
111
143
|
}
|
|
112
|
-
|
|
144
|
+
await Promise.all([
|
|
145
|
+
waitForSubscriptionUpdate(psA, psB),
|
|
146
|
+
waitForSubscriptionUpdate(psB, psA)
|
|
147
|
+
]);
|
|
148
|
+
Array.from({ length: 10 }, (_, i) => psB.dispatchEvent(new CustomEvent(topic, { detail: uint8ArrayFromString('banana') })));
|
|
113
149
|
return await defer.promise;
|
|
114
150
|
});
|
|
115
151
|
it('Unsubscribe from topic in nodeA', async () => {
|
|
116
152
|
const defer = pDefer();
|
|
117
|
-
|
|
118
|
-
expect(psA.subscriptions.size).to.equal(0);
|
|
153
|
+
let callCount = 0;
|
|
119
154
|
psB.addEventListener('pubsub:subscription-change', (evt) => {
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
155
|
+
callCount++;
|
|
156
|
+
if (callCount === 1) {
|
|
157
|
+
// notice subscribe
|
|
158
|
+
const { peerId: changedPeerId, subscriptions: changedSubs } = evt.detail;
|
|
159
|
+
expect(psB.getPeers()).to.have.lengthOf(1);
|
|
160
|
+
expect(psB.getTopics()).to.be.empty();
|
|
161
|
+
expect(changedPeerId).to.deep.equal(psB.getPeers()[0]);
|
|
162
|
+
expect(changedSubs).to.have.lengthOf(1);
|
|
163
|
+
expect(changedSubs[0].topic).to.equal(topic);
|
|
164
|
+
expect(changedSubs[0].subscribe).to.equal(true);
|
|
165
|
+
}
|
|
166
|
+
else {
|
|
167
|
+
// notice unsubscribe
|
|
168
|
+
const { peerId: changedPeerId, subscriptions: changedSubs } = evt.detail;
|
|
169
|
+
expect(psB.getPeers()).to.have.lengthOf(1);
|
|
170
|
+
expect(psB.getTopics()).to.be.empty();
|
|
171
|
+
expect(changedPeerId).to.deep.equal(psB.getPeers()[0]);
|
|
172
|
+
expect(changedSubs).to.have.lengthOf(1);
|
|
173
|
+
expect(changedSubs[0].topic).to.equal(topic);
|
|
174
|
+
expect(changedSubs[0].subscribe).to.equal(false);
|
|
175
|
+
defer.resolve();
|
|
176
|
+
}
|
|
130
177
|
});
|
|
178
|
+
psA.subscribe(topic);
|
|
179
|
+
expect(psA.getTopics()).to.not.be.empty();
|
|
180
|
+
psA.unsubscribe(topic);
|
|
181
|
+
expect(psA.getTopics()).to.be.empty();
|
|
131
182
|
return await defer.promise;
|
|
132
183
|
});
|
|
133
|
-
it('Publish to a topic:Z in nodeA nodeB', async () => {
|
|
184
|
+
it.skip('Publish to a topic:Z in nodeA nodeB', async () => {
|
|
134
185
|
const defer = pDefer();
|
|
135
|
-
|
|
186
|
+
const topic = 'Z';
|
|
187
|
+
psA.addEventListener(topic, shouldNotHappen, {
|
|
136
188
|
once: true
|
|
137
189
|
});
|
|
138
|
-
psB.addEventListener(
|
|
190
|
+
psB.addEventListener(topic, shouldNotHappen, {
|
|
139
191
|
once: true
|
|
140
192
|
});
|
|
193
|
+
await Promise.all([
|
|
194
|
+
waitForSubscriptionUpdate(psA, psB),
|
|
195
|
+
waitForSubscriptionUpdate(psB, psA)
|
|
196
|
+
]);
|
|
141
197
|
setTimeout(() => {
|
|
142
|
-
psA.removeEventListener(
|
|
143
|
-
psB.removeEventListener(
|
|
198
|
+
psA.removeEventListener(topic, shouldNotHappen);
|
|
199
|
+
psB.removeEventListener(topic, shouldNotHappen);
|
|
144
200
|
defer.resolve();
|
|
145
201
|
}, 100);
|
|
146
|
-
void psB.
|
|
147
|
-
void psA.
|
|
202
|
+
void psB.dispatchEvent(new CustomEvent(topic, { detail: uint8ArrayFromString('banana') }));
|
|
203
|
+
void psA.dispatchEvent(new CustomEvent(topic, { detail: uint8ArrayFromString('banana') }));
|
|
148
204
|
return await defer.promise;
|
|
149
205
|
});
|
|
150
206
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"two-nodes.js","sourceRoot":"","sources":["../../../src/pubsub/two-nodes.ts"],"names":[],"mappings":"AAAA,+CAA+C;AAC/C,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAA;AAC5C,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,MAAM,MAAM,SAAS,CAAA;AAC5B,OAAO,QAAQ,MAAM,YAAY,CAAA;AACjC,OAAO,EAAE,QAAQ,IAAI,kBAAkB,EAAE,MAAM,uBAAuB,CAAA;AACtE,OAAO,EAAE,UAAU,IAAI,oBAAoB,EAAE,MAAM,yBAAyB,CAAA;
|
|
1
|
+
{"version":3,"file":"two-nodes.js","sourceRoot":"","sources":["../../../src/pubsub/two-nodes.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
|
|
2
|
-
export declare function
|
|
1
|
+
import type { PubsubBaseProtocol } from '@libp2p/pubsub';
|
|
2
|
+
export declare function waitForSubscriptionUpdate(a: PubsubBaseProtocol, b: PubsubBaseProtocol): Promise<void>;
|
|
3
3
|
//# sourceMappingURL=utils.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/pubsub/utils.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/pubsub/utils.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAA;AAExD,wBAAsB,yBAAyB,CAAE,CAAC,EAAE,kBAAkB,EAAE,CAAC,EAAE,kBAAkB,iBAM5F"}
|
package/dist/src/pubsub/utils.js
CHANGED
|
@@ -1,11 +1,9 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
}
|
|
9
|
-
expect(Array.from(set.values())).to.eql(subs);
|
|
1
|
+
import { pEvent } from 'p-event';
|
|
2
|
+
import pWaitFor from 'p-wait-for';
|
|
3
|
+
export async function waitForSubscriptionUpdate(a, b) {
|
|
4
|
+
await pWaitFor(async () => {
|
|
5
|
+
const event = await pEvent(a, 'pubsub:subscription-change');
|
|
6
|
+
return event.detail.peerId.equals(b.peerId);
|
|
7
|
+
});
|
|
10
8
|
}
|
|
11
9
|
//# sourceMappingURL=utils.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/pubsub/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/pubsub/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAA;AAChC,OAAO,QAAQ,MAAM,YAAY,CAAA;AAIjC,MAAM,CAAC,KAAK,UAAU,yBAAyB,CAAE,CAAqB,EAAE,CAAqB;IAC3F,MAAM,QAAQ,CAAC,KAAK,IAAI,EAAE;QACxB,MAAM,KAAK,GAAG,MAAM,MAAM,CAAoE,CAAC,EAAE,4BAA4B,CAAC,CAAA;QAE9H,OAAO,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAA;IAC7C,CAAC,CAAC,CAAA;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"close-test.d.ts","sourceRoot":"","sources":["../../../src/stream-muxer/close-test.ts"],"names":[],"mappings":"AAUA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AAC5C,OAAO,KAAK,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;
|
|
1
|
+
{"version":3,"file":"close-test.d.ts","sourceRoot":"","sources":["../../../src/stream-muxer/close-test.ts"],"names":[],"mappings":"AAUA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AAC5C,OAAO,KAAK,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;iCAgBlD,UAAU,KAAK,EAAE,YAAY,CAAC;AAAtD,wBAiFC"}
|
|
@@ -8,6 +8,7 @@ import { mockUpgrader } from '../mocks/upgrader.js';
|
|
|
8
8
|
import { mockMultiaddrConnection } from '../mocks/multiaddr-connection.js';
|
|
9
9
|
import { expect } from 'aegir/utils/chai.js';
|
|
10
10
|
import delay from 'delay';
|
|
11
|
+
import { createEd25519PeerId } from '@libp2p/peer-id-factory';
|
|
11
12
|
function randomBuffer() {
|
|
12
13
|
return uint8ArrayFromString(Math.random().toString());
|
|
13
14
|
}
|
|
@@ -22,6 +23,8 @@ const infiniteRandom = {
|
|
|
22
23
|
export default (common) => {
|
|
23
24
|
describe('close', () => {
|
|
24
25
|
it('closing underlying socket closes streams', async () => {
|
|
26
|
+
const localPeer = await createEd25519PeerId();
|
|
27
|
+
const remotePeer = await createEd25519PeerId();
|
|
25
28
|
const muxer = await common.setup({
|
|
26
29
|
onStream: (stream) => {
|
|
27
30
|
void pipe(stream, drain);
|
|
@@ -33,8 +36,8 @@ export default (common) => {
|
|
|
33
36
|
const abortableRemote = abortableDuplex(remote, controller.signal, {
|
|
34
37
|
returnOnAbort: true
|
|
35
38
|
});
|
|
36
|
-
await upgrader.upgradeInbound(mockMultiaddrConnection(abortableRemote));
|
|
37
|
-
const dialerConn = await upgrader.upgradeOutbound(mockMultiaddrConnection(local));
|
|
39
|
+
await upgrader.upgradeInbound(mockMultiaddrConnection(abortableRemote, localPeer));
|
|
40
|
+
const dialerConn = await upgrader.upgradeOutbound(mockMultiaddrConnection(local, remotePeer));
|
|
38
41
|
const s1 = await dialerConn.newStream(['']);
|
|
39
42
|
const s2 = await dialerConn.newStream(['']);
|
|
40
43
|
// close the remote in a bit
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"close-test.js","sourceRoot":"","sources":["../../../src/stream-muxer/close-test.ts"],"names":[],"mappings":"AAAA,+CAA+C;AAC/C,OAAO,EAAE,IAAI,EAAE,MAAM,SAAS,CAAA;AAC9B,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAA;AAC3C,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAA;AACrE,OAAO,EAAE,UAAU,IAAI,oBAAoB,EAAE,MAAM,yBAAyB,CAAA;AAC5E,OAAO,KAAK,MAAM,UAAU,CAAA;AAC5B,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAA;AACnD,OAAO,EAAE,uBAAuB,EAAE,MAAM,kCAAkC,CAAA;AAC1E,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAA;AAC5C,OAAO,KAAK,MAAM,OAAO,CAAA;
|
|
1
|
+
{"version":3,"file":"close-test.js","sourceRoot":"","sources":["../../../src/stream-muxer/close-test.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@libp2p/interface-compliance-tests",
|
|
3
|
-
"version": "1.1.
|
|
3
|
+
"version": "1.1.11",
|
|
4
4
|
"description": "Compliance tests for JS libp2p interfaces",
|
|
5
5
|
"license": "Apache-2.0 OR MIT",
|
|
6
6
|
"homepage": "https://github.com/libp2p/js-libp2p-interfaces/tree/master/packages/libp2p-interface-compliance-tests#readme",
|
|
@@ -56,6 +56,10 @@
|
|
|
56
56
|
"import": "./dist/src/crypto/index.js",
|
|
57
57
|
"types": "./dist/src/crypto/index.d.ts"
|
|
58
58
|
},
|
|
59
|
+
"./mocks": {
|
|
60
|
+
"import": "./dist/src/mocks/index.js",
|
|
61
|
+
"types": "./dist/src/mocks/index.d.ts"
|
|
62
|
+
},
|
|
59
63
|
"./peer-discovery": {
|
|
60
64
|
"import": "./dist/src/peer-discovery/index.js",
|
|
61
65
|
"types": "./dist/src/peer-discovery/index.d.ts"
|
|
@@ -88,10 +92,6 @@
|
|
|
88
92
|
"import": "./dist/src/transport/utils/index.js",
|
|
89
93
|
"types": "./dist/src/transport/utils/index.d.ts"
|
|
90
94
|
},
|
|
91
|
-
"./mocks": {
|
|
92
|
-
"import": "./dist/src/mocks/index.js",
|
|
93
|
-
"types": "./dist/src/mocks/index.d.ts"
|
|
94
|
-
},
|
|
95
95
|
"./utils/peers": {
|
|
96
96
|
"import": "./dist/src/utils/peers.js",
|
|
97
97
|
"types": "./dist/src/utils/peers.d.ts"
|
|
@@ -200,6 +200,8 @@
|
|
|
200
200
|
"dependencies": {
|
|
201
201
|
"@libp2p/crypto": "^0.22.2",
|
|
202
202
|
"@libp2p/interfaces": "^1.0.0",
|
|
203
|
+
"@libp2p/logger": "^1.0.3",
|
|
204
|
+
"@libp2p/multistream-select": "^1.0.0",
|
|
203
205
|
"@libp2p/peer-id": "^1.0.0",
|
|
204
206
|
"@libp2p/peer-id-factory": "^1.0.0",
|
|
205
207
|
"@libp2p/pubsub": "^1.1.0",
|
|
@@ -216,6 +218,7 @@
|
|
|
216
218
|
"it-pushable": "^2.0.1",
|
|
217
219
|
"it-stream-types": "^1.0.4",
|
|
218
220
|
"multiformats": "^9.4.10",
|
|
221
|
+
"p-event": "^5.0.1",
|
|
219
222
|
"p-defer": "^4.0.0",
|
|
220
223
|
"p-limit": "^4.0.0",
|
|
221
224
|
"p-wait-for": "^4.1.0",
|
package/src/mocks/connection.ts
CHANGED
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { peerIdFromString } from '@libp2p/peer-id'
|
|
2
|
-
import { createEd25519PeerId } from '@libp2p/peer-id-factory'
|
|
3
2
|
import { pipe } from 'it-pipe'
|
|
4
3
|
import { duplexPair } from 'it-pair/duplex'
|
|
5
4
|
import type { MultiaddrConnection } from '@libp2p/interfaces/transport'
|
|
@@ -9,22 +8,66 @@ import type { Duplex } from 'it-stream-types'
|
|
|
9
8
|
import { mockMuxer } from './muxer.js'
|
|
10
9
|
import type { PeerId } from '@libp2p/interfaces/src/peer-id'
|
|
11
10
|
import { mockMultiaddrConnection } from './multiaddr-connection.js'
|
|
12
|
-
import {
|
|
11
|
+
import type { Registrar } from '@libp2p/interfaces/registrar'
|
|
12
|
+
import { mockRegistrar } from './registrar.js'
|
|
13
|
+
import { Dialer, Listener } from '@libp2p/multistream-select'
|
|
14
|
+
import { logger } from '@libp2p/logger'
|
|
15
|
+
import { CustomEvent } from '@libp2p/interfaces'
|
|
13
16
|
|
|
14
|
-
|
|
17
|
+
const log = logger('libp2p:mock-connection')
|
|
18
|
+
|
|
19
|
+
export interface MockConnectionOptions {
|
|
20
|
+
direction?: 'inbound' | 'outbound'
|
|
21
|
+
muxer?: Muxer
|
|
22
|
+
registrar?: Registrar
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
export function mockConnection (maConn: MultiaddrConnection, opts: MockConnectionOptions = {}): Connection {
|
|
15
26
|
const remoteAddr = maConn.remoteAddr
|
|
16
27
|
const remotePeerIdStr = remoteAddr.getPeerId()
|
|
17
|
-
|
|
28
|
+
|
|
29
|
+
if (remotePeerIdStr == null) {
|
|
30
|
+
throw new Error('Remote multiaddr must contain a peer id')
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
const remotePeer = peerIdFromString(remotePeerIdStr)
|
|
18
34
|
const registry = new Map()
|
|
19
35
|
const streams: Stream[] = []
|
|
20
|
-
|
|
21
|
-
const
|
|
36
|
+
const direction = opts.direction ?? 'inbound'
|
|
37
|
+
const registrar = opts.registrar ?? mockRegistrar()
|
|
38
|
+
|
|
39
|
+
const muxer = opts.muxer ?? mockMuxer({
|
|
40
|
+
onStream: (muxedStream) => {
|
|
41
|
+
const mss = new Listener(muxedStream)
|
|
42
|
+
try {
|
|
43
|
+
mss.handle(registrar.getProtocols())
|
|
44
|
+
.then(({ stream, protocol }) => {
|
|
45
|
+
log('%s: incoming stream opened on %s', direction, protocol)
|
|
46
|
+
muxedStream = { ...muxedStream, ...stream }
|
|
47
|
+
|
|
48
|
+
connection.addStream(muxedStream, { protocol, metadata: {} })
|
|
49
|
+
const handler = registrar.getHandler(protocol)
|
|
50
|
+
|
|
51
|
+
handler(new CustomEvent('incomingStream', {
|
|
52
|
+
detail: { connection, stream: muxedStream, protocol }
|
|
53
|
+
}))
|
|
54
|
+
}).catch(err => {
|
|
55
|
+
log.error(err)
|
|
56
|
+
})
|
|
57
|
+
} catch (err: any) {
|
|
58
|
+
log.error(err)
|
|
59
|
+
}
|
|
60
|
+
},
|
|
61
|
+
onStreamEnd: (stream) => {
|
|
62
|
+
connection.removeStream(stream.id)
|
|
63
|
+
}
|
|
64
|
+
})
|
|
22
65
|
|
|
23
66
|
void pipe(
|
|
24
|
-
maConn,
|
|
67
|
+
maConn, muxer, maConn
|
|
25
68
|
)
|
|
26
69
|
|
|
27
|
-
|
|
70
|
+
const connection: Connection = {
|
|
28
71
|
id: 'mock-connection',
|
|
29
72
|
remoteAddr,
|
|
30
73
|
remotePeer,
|
|
@@ -47,11 +90,17 @@ export async function mockConnection (maConn: MultiaddrConnection, direction: 'i
|
|
|
47
90
|
throw new Error('protocols must have a length')
|
|
48
91
|
}
|
|
49
92
|
|
|
50
|
-
const id = `${
|
|
51
|
-
const stream: Stream =
|
|
93
|
+
const id = `${Math.random()}`
|
|
94
|
+
const stream: Stream = muxer.newStream(id)
|
|
95
|
+
const mss = new Dialer(stream)
|
|
96
|
+
const result = await mss.select(protocols)
|
|
97
|
+
|
|
52
98
|
const streamData: ProtocolStream = {
|
|
53
|
-
protocol:
|
|
54
|
-
stream
|
|
99
|
+
protocol: result.protocol,
|
|
100
|
+
stream: {
|
|
101
|
+
...stream,
|
|
102
|
+
...result.stream
|
|
103
|
+
}
|
|
55
104
|
}
|
|
56
105
|
|
|
57
106
|
registry.set(id, streamData)
|
|
@@ -68,6 +117,8 @@ export async function mockConnection (maConn: MultiaddrConnection, direction: 'i
|
|
|
68
117
|
await maConn.close()
|
|
69
118
|
}
|
|
70
119
|
}
|
|
120
|
+
|
|
121
|
+
return connection
|
|
71
122
|
}
|
|
72
123
|
|
|
73
124
|
export function mockStream (stream: Duplex<Uint8Array>): Stream {
|
|
@@ -83,26 +134,24 @@ export function mockStream (stream: Duplex<Uint8Array>): Stream {
|
|
|
83
134
|
}
|
|
84
135
|
}
|
|
85
136
|
|
|
86
|
-
export
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
})
|
|
107
|
-
}]
|
|
137
|
+
export interface Peer {
|
|
138
|
+
peerId: PeerId
|
|
139
|
+
registrar: Registrar
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
export function connectionPair (a: Peer, b: Peer): [ Connection, Connection ] {
|
|
143
|
+
const [peerBtoPeerA, peerAtoPeerB] = duplexPair<Uint8Array>()
|
|
144
|
+
|
|
145
|
+
return [
|
|
146
|
+
mockConnection(
|
|
147
|
+
mockMultiaddrConnection(peerAtoPeerB, b.peerId), {
|
|
148
|
+
registrar: a.registrar
|
|
149
|
+
}
|
|
150
|
+
),
|
|
151
|
+
mockConnection(
|
|
152
|
+
mockMultiaddrConnection(peerBtoPeerA, a.peerId), {
|
|
153
|
+
registrar: b.registrar
|
|
154
|
+
}
|
|
155
|
+
)
|
|
156
|
+
]
|
|
108
157
|
}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { Multiaddr } from '@multiformats/multiaddr'
|
|
2
2
|
import type { MultiaddrConnection } from '@libp2p/interfaces/transport'
|
|
3
3
|
import type { Duplex } from 'it-stream-types'
|
|
4
|
+
import type { PeerId } from '@libp2p/interfaces/peer-id'
|
|
4
5
|
|
|
5
|
-
export function mockMultiaddrConnection (source: Duplex<Uint8Array> & Partial<MultiaddrConnection
|
|
6
|
+
export function mockMultiaddrConnection (source: Duplex<Uint8Array> & Partial<MultiaddrConnection>, peerId: PeerId): MultiaddrConnection {
|
|
6
7
|
const maConn: MultiaddrConnection = {
|
|
7
8
|
async close () {
|
|
8
9
|
|
|
@@ -10,7 +11,7 @@ export function mockMultiaddrConnection (source: Duplex<Uint8Array> & Partial<Mu
|
|
|
10
11
|
timeline: {
|
|
11
12
|
open: Date.now()
|
|
12
13
|
},
|
|
13
|
-
remoteAddr: new Multiaddr(
|
|
14
|
+
remoteAddr: new Multiaddr(`/ip4/127.0.0.1/tcp/4001/p2p/${peerId.toString()}`),
|
|
14
15
|
...source
|
|
15
16
|
}
|
|
16
17
|
|