@libp2p/interface-compliance-tests 3.0.7 → 4.0.0-e66f4891
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/README.md +12 -3
- package/dist/src/connection/index.d.ts +5 -0
- package/dist/src/connection/index.d.ts.map +1 -0
- package/dist/src/connection/index.js +150 -0
- package/dist/src/connection/index.js.map +1 -0
- package/dist/src/connection-encryption/index.d.ts +5 -0
- package/dist/src/connection-encryption/index.d.ts.map +1 -0
- package/dist/src/connection-encryption/index.js +71 -0
- package/dist/src/connection-encryption/index.js.map +1 -0
- package/dist/src/connection-encryption/utils/index.d.ts +3 -0
- package/dist/src/connection-encryption/utils/index.d.ts.map +1 -0
- package/dist/src/connection-encryption/utils/index.js +19 -0
- package/dist/src/connection-encryption/utils/index.js.map +1 -0
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/is-valid-tick.d.ts.map +1 -1
- package/dist/src/is-valid-tick.js.map +1 -1
- package/dist/src/mocks/connection-encrypter.d.ts +3 -0
- package/dist/src/mocks/connection-encrypter.d.ts.map +1 -0
- package/dist/src/mocks/connection-encrypter.js +98 -0
- package/dist/src/mocks/connection-encrypter.js.map +1 -0
- package/dist/src/mocks/connection-gater.d.ts +3 -0
- package/dist/src/mocks/connection-gater.d.ts.map +1 -0
- package/dist/src/mocks/connection-gater.js +17 -0
- package/dist/src/mocks/connection-gater.js.map +1 -0
- package/dist/src/mocks/connection-manager.d.ts +29 -0
- package/dist/src/mocks/connection-manager.d.ts.map +1 -0
- package/dist/src/mocks/connection-manager.js +145 -0
- package/dist/src/mocks/connection-manager.js.map +1 -0
- package/dist/src/mocks/connection.d.ts +32 -0
- package/dist/src/mocks/connection.d.ts.map +1 -0
- package/dist/src/mocks/connection.js +167 -0
- package/dist/src/mocks/connection.js.map +1 -0
- package/dist/src/mocks/duplex.d.ts +3 -0
- package/dist/src/mocks/duplex.d.ts.map +1 -0
- package/dist/src/mocks/duplex.js +9 -0
- package/dist/src/mocks/duplex.js.map +1 -0
- package/dist/src/mocks/index.d.ts +13 -0
- package/dist/src/mocks/index.d.ts.map +1 -0
- package/dist/src/mocks/index.js +11 -0
- package/dist/src/mocks/index.js.map +1 -0
- package/dist/src/mocks/metrics.d.ts +3 -0
- package/dist/src/mocks/metrics.d.ts.map +1 -0
- package/dist/src/mocks/metrics.js +115 -0
- package/dist/src/mocks/metrics.js.map +1 -0
- package/dist/src/mocks/multiaddr-connection.d.ts +17 -0
- package/dist/src/mocks/multiaddr-connection.d.ts.map +1 -0
- package/dist/src/mocks/multiaddr-connection.js +60 -0
- package/dist/src/mocks/multiaddr-connection.js.map +1 -0
- package/dist/src/mocks/muxer.d.ts +36 -0
- package/dist/src/mocks/muxer.d.ts.map +1 -0
- package/dist/src/mocks/muxer.js +213 -0
- package/dist/src/mocks/muxer.js.map +1 -0
- package/dist/src/mocks/peer-discovery.d.ts +22 -0
- package/dist/src/mocks/peer-discovery.d.ts.map +1 -0
- package/dist/src/mocks/peer-discovery.js +47 -0
- package/dist/src/mocks/peer-discovery.js.map +1 -0
- package/dist/src/mocks/registrar.d.ts +18 -0
- package/dist/src/mocks/registrar.d.ts.map +1 -0
- package/dist/src/mocks/registrar.js +66 -0
- package/dist/src/mocks/registrar.js.map +1 -0
- package/dist/src/mocks/upgrader.d.ts +10 -0
- package/dist/src/mocks/upgrader.d.ts.map +1 -0
- package/dist/src/mocks/upgrader.js +31 -0
- package/dist/src/mocks/upgrader.js.map +1 -0
- package/dist/src/peer-discovery/index.d.ts +5 -0
- package/dist/src/peer-discovery/index.d.ts.map +1 -0
- package/dist/src/peer-discovery/index.js +66 -0
- package/dist/src/peer-discovery/index.js.map +1 -0
- package/dist/src/pubsub/api.d.ts +6 -0
- package/dist/src/pubsub/api.d.ts.map +1 -0
- package/dist/src/pubsub/api.js +87 -0
- package/dist/src/pubsub/api.js.map +1 -0
- package/dist/src/pubsub/connection-handlers.d.ts +6 -0
- package/dist/src/pubsub/connection-handlers.d.ts.map +1 -0
- package/dist/src/pubsub/connection-handlers.js +329 -0
- package/dist/src/pubsub/connection-handlers.js.map +1 -0
- package/dist/src/pubsub/emit-self.d.ts +6 -0
- package/dist/src/pubsub/emit-self.d.ts.map +1 -0
- package/dist/src/pubsub/emit-self.js +80 -0
- package/dist/src/pubsub/emit-self.js.map +1 -0
- package/dist/src/pubsub/index.d.ts +18 -0
- package/dist/src/pubsub/index.d.ts.map +1 -0
- package/dist/src/pubsub/index.js +17 -0
- package/dist/src/pubsub/index.js.map +1 -0
- package/dist/src/pubsub/messages.d.ts +6 -0
- package/dist/src/pubsub/messages.d.ts.map +1 -0
- package/dist/src/pubsub/messages.js +48 -0
- package/dist/src/pubsub/messages.js.map +1 -0
- package/dist/src/pubsub/multiple-nodes.d.ts +6 -0
- package/dist/src/pubsub/multiple-nodes.d.ts.map +1 -0
- package/dist/src/pubsub/multiple-nodes.js +350 -0
- package/dist/src/pubsub/multiple-nodes.js.map +1 -0
- package/dist/src/pubsub/two-nodes.d.ts +6 -0
- package/dist/src/pubsub/two-nodes.d.ts.map +1 -0
- package/dist/src/pubsub/two-nodes.js +217 -0
- package/dist/src/pubsub/two-nodes.js.map +1 -0
- package/dist/src/pubsub/utils.d.ts +6 -0
- package/dist/src/pubsub/utils.d.ts.map +1 -0
- package/dist/src/pubsub/utils.js +22 -0
- package/dist/src/pubsub/utils.js.map +1 -0
- package/dist/src/stream-muxer/base-test.d.ts +5 -0
- package/dist/src/stream-muxer/base-test.d.ts.map +1 -0
- package/dist/src/stream-muxer/base-test.js +153 -0
- package/dist/src/stream-muxer/base-test.js.map +1 -0
- package/dist/src/stream-muxer/close-test.d.ts +5 -0
- package/dist/src/stream-muxer/close-test.d.ts.map +1 -0
- package/dist/src/stream-muxer/close-test.js +357 -0
- package/dist/src/stream-muxer/close-test.js.map +1 -0
- package/dist/src/stream-muxer/fixtures/pb/message.d.ts +13 -0
- package/dist/src/stream-muxer/fixtures/pb/message.d.ts.map +1 -0
- package/dist/src/stream-muxer/fixtures/pb/message.js +67 -0
- package/dist/src/stream-muxer/fixtures/pb/message.js.map +1 -0
- package/dist/src/stream-muxer/index.d.ts +5 -0
- package/dist/src/stream-muxer/index.d.ts.map +1 -0
- package/dist/src/stream-muxer/index.js +13 -0
- package/dist/src/stream-muxer/index.js.map +1 -0
- package/dist/src/stream-muxer/mega-stress-test.d.ts +5 -0
- package/dist/src/stream-muxer/mega-stress-test.d.ts.map +1 -0
- package/dist/src/stream-muxer/mega-stress-test.js +11 -0
- package/dist/src/stream-muxer/mega-stress-test.js.map +1 -0
- package/dist/src/stream-muxer/spawner.d.ts +4 -0
- package/dist/src/stream-muxer/spawner.d.ts.map +1 -0
- package/dist/src/stream-muxer/spawner.js +37 -0
- package/dist/src/stream-muxer/spawner.js.map +1 -0
- package/dist/src/stream-muxer/stress-test.d.ts +5 -0
- package/dist/src/stream-muxer/stress-test.d.ts.map +1 -0
- package/dist/src/stream-muxer/stress-test.js +23 -0
- package/dist/src/stream-muxer/stress-test.js.map +1 -0
- package/dist/src/transport/dial-test.d.ts +5 -0
- package/dist/src/transport/dial-test.d.ts.map +1 -0
- package/dist/src/transport/dial-test.js +98 -0
- package/dist/src/transport/dial-test.js.map +1 -0
- package/dist/src/transport/filter-test.d.ts +5 -0
- package/dist/src/transport/filter-test.d.ts.map +1 -0
- package/dist/src/transport/filter-test.js +18 -0
- package/dist/src/transport/filter-test.js.map +1 -0
- package/dist/src/transport/index.d.ts +15 -0
- package/dist/src/transport/index.d.ts.map +1 -0
- package/dist/src/transport/index.js +11 -0
- package/dist/src/transport/index.js.map +1 -0
- package/dist/src/transport/listen-test.d.ts +5 -0
- package/dist/src/transport/listen-test.d.ts.map +1 -0
- package/dist/src/transport/listen-test.js +152 -0
- package/dist/src/transport/listen-test.js.map +1 -0
- package/package.json +74 -97
- package/src/connection/index.ts +182 -0
- package/src/connection-encryption/index.ts +97 -0
- package/src/connection-encryption/utils/index.ts +24 -0
- package/src/index.ts +0 -1
- package/src/is-valid-tick.ts +0 -1
- package/src/mocks/connection-encrypter.ts +113 -0
- package/src/mocks/connection-gater.ts +18 -0
- package/src/mocks/connection-manager.ts +211 -0
- package/src/mocks/connection.ts +226 -0
- package/src/mocks/duplex.ts +10 -0
- package/src/mocks/index.ts +12 -0
- package/src/mocks/metrics.ts +162 -0
- package/src/mocks/multiaddr-connection.ts +76 -0
- package/src/mocks/muxer.ts +303 -0
- package/src/mocks/peer-discovery.ts +60 -0
- package/src/mocks/registrar.ts +88 -0
- package/src/mocks/upgrader.ts +49 -0
- package/src/peer-discovery/index.ts +90 -0
- package/src/pubsub/api.ts +114 -0
- package/src/pubsub/connection-handlers.ts +413 -0
- package/src/pubsub/emit-self.ts +99 -0
- package/src/pubsub/index.ts +34 -0
- package/src/pubsub/messages.ts +59 -0
- package/src/pubsub/multiple-nodes.ts +440 -0
- package/src/pubsub/two-nodes.ts +273 -0
- package/src/pubsub/utils.ts +29 -0
- package/src/stream-muxer/base-test.ts +196 -0
- package/src/stream-muxer/close-test.ts +442 -0
- package/src/stream-muxer/fixtures/pb/message.proto +7 -0
- package/src/stream-muxer/fixtures/pb/message.ts +87 -0
- package/src/stream-muxer/index.ts +15 -0
- package/src/stream-muxer/mega-stress-test.ts +14 -0
- package/src/stream-muxer/spawner.ts +55 -0
- package/src/stream-muxer/stress-test.ts +27 -0
- package/src/transport/dial-test.ts +124 -0
- package/src/transport/filter-test.ts +25 -0
- package/src/transport/index.ts +25 -0
- package/src/transport/listen-test.ts +191 -0
- package/dist/typedoc-urls.json +0 -3
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { type AbstractStreamInit } from '@libp2p/interface/stream-muxer/stream';
|
|
2
|
+
import { type Pushable } from 'it-pushable';
|
|
3
|
+
import type { Direction } from '@libp2p/interface/connection';
|
|
4
|
+
import type { StreamMuxer, StreamMuxerFactory, StreamMuxerInit } from '@libp2p/interface/stream-muxer';
|
|
5
|
+
interface DataMessage {
|
|
6
|
+
id: string;
|
|
7
|
+
type: 'data';
|
|
8
|
+
direction: Direction;
|
|
9
|
+
chunk: string;
|
|
10
|
+
}
|
|
11
|
+
interface ResetMessage {
|
|
12
|
+
id: string;
|
|
13
|
+
type: 'reset';
|
|
14
|
+
direction: Direction;
|
|
15
|
+
}
|
|
16
|
+
interface CloseMessage {
|
|
17
|
+
id: string;
|
|
18
|
+
type: 'close';
|
|
19
|
+
direction: Direction;
|
|
20
|
+
}
|
|
21
|
+
interface CreateMessage {
|
|
22
|
+
id: string;
|
|
23
|
+
type: 'create';
|
|
24
|
+
direction: 'outbound';
|
|
25
|
+
}
|
|
26
|
+
type StreamMessage = DataMessage | ResetMessage | CloseMessage | CreateMessage;
|
|
27
|
+
export interface MockMuxedStreamInit extends AbstractStreamInit {
|
|
28
|
+
push: Pushable<StreamMessage>;
|
|
29
|
+
}
|
|
30
|
+
declare class MockMuxerFactory implements StreamMuxerFactory {
|
|
31
|
+
protocol: string;
|
|
32
|
+
createStreamMuxer(init?: StreamMuxerInit): StreamMuxer;
|
|
33
|
+
}
|
|
34
|
+
export declare function mockMuxer(): MockMuxerFactory;
|
|
35
|
+
export {};
|
|
36
|
+
//# sourceMappingURL=muxer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"muxer.d.ts","sourceRoot":"","sources":["../../../src/mocks/muxer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,KAAK,kBAAkB,EAAE,MAAM,uCAAuC,CAAA;AAM/F,OAAO,EAAE,KAAK,QAAQ,EAAY,MAAM,aAAa,CAAA;AAKrD,OAAO,KAAK,EAAE,SAAS,EAAU,MAAM,8BAA8B,CAAA;AACrE,OAAO,KAAK,EAAE,WAAW,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAA;AAMtG,UAAU,WAAW;IACnB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,EAAE,MAAM,CAAA;IACZ,SAAS,EAAE,SAAS,CAAA;IACpB,KAAK,EAAE,MAAM,CAAA;CACd;AAED,UAAU,YAAY;IACpB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,EAAE,OAAO,CAAA;IACb,SAAS,EAAE,SAAS,CAAA;CACrB;AAED,UAAU,YAAY;IACpB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,EAAE,OAAO,CAAA;IACb,SAAS,EAAE,SAAS,CAAA;CACrB;AAED,UAAU,aAAa;IACrB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,EAAE,QAAQ,CAAA;IACd,SAAS,EAAE,UAAU,CAAA;CACtB;AAED,KAAK,aAAa,GAAG,WAAW,GAAG,YAAY,GAAG,YAAY,GAAG,aAAa,CAAA;AAE9E,MAAM,WAAW,mBAAoB,SAAQ,kBAAkB;IAC7D,IAAI,EAAE,QAAQ,CAAC,aAAa,CAAC,CAAA;CAC9B;AAsOD,cAAM,gBAAiB,YAAW,kBAAkB;IAC3C,QAAQ,EAAE,MAAM,CAAsB;IAE7C,iBAAiB,CAAE,IAAI,CAAC,EAAE,eAAe,GAAG,WAAW;CAkBxD;AAED,wBAAgB,SAAS,IAAK,gBAAgB,CAE7C"}
|
|
@@ -0,0 +1,213 @@
|
|
|
1
|
+
import { AbstractStream } from '@libp2p/interface/stream-muxer/stream';
|
|
2
|
+
import { logger } from '@libp2p/logger';
|
|
3
|
+
import { abortableSource } from 'abortable-iterator';
|
|
4
|
+
import map from 'it-map';
|
|
5
|
+
import * as ndjson from 'it-ndjson';
|
|
6
|
+
import { pipe } from 'it-pipe';
|
|
7
|
+
import { pushable } from 'it-pushable';
|
|
8
|
+
import { Uint8ArrayList } from 'uint8arraylist';
|
|
9
|
+
import { fromString as uint8ArrayFromString } from 'uint8arrays/from-string';
|
|
10
|
+
import { toString as uint8ArrayToString } from 'uint8arrays/to-string';
|
|
11
|
+
let muxers = 0;
|
|
12
|
+
let streams = 0;
|
|
13
|
+
class MuxedStream extends AbstractStream {
|
|
14
|
+
push;
|
|
15
|
+
constructor(init) {
|
|
16
|
+
super(init);
|
|
17
|
+
this.push = init.push;
|
|
18
|
+
}
|
|
19
|
+
sendNewStream() {
|
|
20
|
+
// If initiator, open a new stream
|
|
21
|
+
const createMsg = {
|
|
22
|
+
id: this.id,
|
|
23
|
+
type: 'create',
|
|
24
|
+
direction: 'outbound'
|
|
25
|
+
};
|
|
26
|
+
this.push.push(createMsg);
|
|
27
|
+
}
|
|
28
|
+
sendData(data) {
|
|
29
|
+
const dataMsg = {
|
|
30
|
+
id: this.id,
|
|
31
|
+
type: 'data',
|
|
32
|
+
chunk: uint8ArrayToString(data.subarray(), 'base64pad'),
|
|
33
|
+
direction: this.direction
|
|
34
|
+
};
|
|
35
|
+
this.push.push(dataMsg);
|
|
36
|
+
}
|
|
37
|
+
sendReset() {
|
|
38
|
+
const resetMsg = {
|
|
39
|
+
id: this.id,
|
|
40
|
+
type: 'reset',
|
|
41
|
+
direction: this.direction
|
|
42
|
+
};
|
|
43
|
+
this.push.push(resetMsg);
|
|
44
|
+
}
|
|
45
|
+
sendCloseWrite() {
|
|
46
|
+
const closeMsg = {
|
|
47
|
+
id: this.id,
|
|
48
|
+
type: 'close',
|
|
49
|
+
direction: this.direction
|
|
50
|
+
};
|
|
51
|
+
this.push.push(closeMsg);
|
|
52
|
+
}
|
|
53
|
+
sendCloseRead() {
|
|
54
|
+
// does not support close read, only close write
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
class MockMuxer {
|
|
58
|
+
source;
|
|
59
|
+
input;
|
|
60
|
+
streamInput;
|
|
61
|
+
name;
|
|
62
|
+
protocol = '/mock-muxer/1.0.0';
|
|
63
|
+
closeController;
|
|
64
|
+
registryInitiatorStreams;
|
|
65
|
+
registryRecipientStreams;
|
|
66
|
+
options;
|
|
67
|
+
log;
|
|
68
|
+
constructor(init) {
|
|
69
|
+
this.name = `muxer:${muxers++}`;
|
|
70
|
+
this.log = logger(`libp2p:mock-muxer:${this.name}`);
|
|
71
|
+
this.registryInitiatorStreams = new Map();
|
|
72
|
+
this.registryRecipientStreams = new Map();
|
|
73
|
+
this.log('create muxer');
|
|
74
|
+
this.options = init ?? { direction: 'inbound' };
|
|
75
|
+
this.closeController = new AbortController();
|
|
76
|
+
// receives data from the muxer at the other end of the stream
|
|
77
|
+
this.source = this.input = pushable({
|
|
78
|
+
onEnd: () => {
|
|
79
|
+
for (const stream of this.registryInitiatorStreams.values()) {
|
|
80
|
+
stream.destroy();
|
|
81
|
+
}
|
|
82
|
+
for (const stream of this.registryRecipientStreams.values()) {
|
|
83
|
+
stream.destroy();
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
});
|
|
87
|
+
// receives messages from all of the muxed streams
|
|
88
|
+
this.streamInput = pushable({
|
|
89
|
+
objectMode: true
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
// receive incoming messages
|
|
93
|
+
async sink(source) {
|
|
94
|
+
try {
|
|
95
|
+
await pipe(abortableSource(source, this.closeController.signal), (source) => map(source, buf => uint8ArrayToString(buf.subarray())), (ndjson.parse), async (source) => {
|
|
96
|
+
for await (const message of source) {
|
|
97
|
+
this.log.trace('-> %s %s %s', message.type, message.direction, message.id);
|
|
98
|
+
this.handleMessage(message);
|
|
99
|
+
}
|
|
100
|
+
});
|
|
101
|
+
this.log('muxed stream ended');
|
|
102
|
+
this.input.end();
|
|
103
|
+
}
|
|
104
|
+
catch (err) {
|
|
105
|
+
this.log('muxed stream errored', err);
|
|
106
|
+
this.input.end(err);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
handleMessage(message) {
|
|
110
|
+
let muxedStream;
|
|
111
|
+
const registry = message.direction === 'outbound' ? this.registryRecipientStreams : this.registryInitiatorStreams;
|
|
112
|
+
if (message.type === 'create') {
|
|
113
|
+
if (registry.has(message.id)) {
|
|
114
|
+
throw new Error(`Already had stream for ${message.id}`);
|
|
115
|
+
}
|
|
116
|
+
muxedStream = this.createStream(message.id, 'inbound');
|
|
117
|
+
registry.set(muxedStream.id, muxedStream);
|
|
118
|
+
if (this.options.onIncomingStream != null) {
|
|
119
|
+
this.options.onIncomingStream(muxedStream);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
muxedStream = registry.get(message.id);
|
|
123
|
+
if (muxedStream == null) {
|
|
124
|
+
this.log.error(`No stream found for ${message.id}`);
|
|
125
|
+
return;
|
|
126
|
+
}
|
|
127
|
+
if (message.type === 'data') {
|
|
128
|
+
muxedStream.sourcePush(new Uint8ArrayList(uint8ArrayFromString(message.chunk, 'base64pad')));
|
|
129
|
+
}
|
|
130
|
+
else if (message.type === 'reset') {
|
|
131
|
+
this.log('-> reset stream %s %s', muxedStream.direction, muxedStream.id);
|
|
132
|
+
muxedStream.reset();
|
|
133
|
+
}
|
|
134
|
+
else if (message.type === 'close') {
|
|
135
|
+
this.log('-> closing stream %s %s', muxedStream.direction, muxedStream.id);
|
|
136
|
+
muxedStream.remoteCloseWrite();
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
get streams() {
|
|
140
|
+
return Array.from(this.registryRecipientStreams.values())
|
|
141
|
+
.concat(Array.from(this.registryInitiatorStreams.values()));
|
|
142
|
+
}
|
|
143
|
+
newStream(name) {
|
|
144
|
+
if (this.closeController.signal.aborted) {
|
|
145
|
+
throw new Error('Muxer already closed');
|
|
146
|
+
}
|
|
147
|
+
this.log('newStream %s', name);
|
|
148
|
+
const storedStream = this.createStream(name, 'outbound');
|
|
149
|
+
this.registryInitiatorStreams.set(storedStream.id, storedStream);
|
|
150
|
+
return storedStream;
|
|
151
|
+
}
|
|
152
|
+
createStream(name, direction = 'outbound') {
|
|
153
|
+
const id = name ?? `${streams++}`;
|
|
154
|
+
this.log('createStream %s %s', direction, id);
|
|
155
|
+
const muxedStream = new MuxedStream({
|
|
156
|
+
id,
|
|
157
|
+
direction,
|
|
158
|
+
push: this.streamInput,
|
|
159
|
+
onEnd: () => {
|
|
160
|
+
this.log('stream ended');
|
|
161
|
+
if (direction === 'outbound') {
|
|
162
|
+
this.registryInitiatorStreams.delete(muxedStream.id);
|
|
163
|
+
}
|
|
164
|
+
else {
|
|
165
|
+
this.registryRecipientStreams.delete(muxedStream.id);
|
|
166
|
+
}
|
|
167
|
+
if (this.options.onStreamEnd != null) {
|
|
168
|
+
this.options.onStreamEnd(muxedStream);
|
|
169
|
+
}
|
|
170
|
+
},
|
|
171
|
+
log: logger(`libp2p:mock-muxer:stream:${direction}:${id}`)
|
|
172
|
+
});
|
|
173
|
+
return muxedStream;
|
|
174
|
+
}
|
|
175
|
+
async close(options) {
|
|
176
|
+
if (this.closeController.signal.aborted) {
|
|
177
|
+
return;
|
|
178
|
+
}
|
|
179
|
+
this.log('closing muxed streams');
|
|
180
|
+
await Promise.all(this.streams.map(async (s) => s.close()));
|
|
181
|
+
this.closeController.abort();
|
|
182
|
+
this.input.end();
|
|
183
|
+
}
|
|
184
|
+
abort(err) {
|
|
185
|
+
if (this.closeController.signal.aborted) {
|
|
186
|
+
return;
|
|
187
|
+
}
|
|
188
|
+
this.log('aborting muxed streams');
|
|
189
|
+
this.streams.forEach(s => {
|
|
190
|
+
s.abort(err);
|
|
191
|
+
});
|
|
192
|
+
this.closeController.abort(err);
|
|
193
|
+
this.input.end(err);
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
class MockMuxerFactory {
|
|
197
|
+
protocol = '/mock-muxer/1.0.0';
|
|
198
|
+
createStreamMuxer(init) {
|
|
199
|
+
const mockMuxer = new MockMuxer(init);
|
|
200
|
+
void Promise.resolve().then(async () => {
|
|
201
|
+
void pipe(mockMuxer.streamInput, ndjson.stringify, (source) => map(source, str => new Uint8ArrayList(uint8ArrayFromString(str))), async (source) => {
|
|
202
|
+
for await (const buf of source) {
|
|
203
|
+
mockMuxer.input.push(buf.subarray());
|
|
204
|
+
}
|
|
205
|
+
});
|
|
206
|
+
});
|
|
207
|
+
return mockMuxer;
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
export function mockMuxer() {
|
|
211
|
+
return new MockMuxerFactory();
|
|
212
|
+
}
|
|
213
|
+
//# sourceMappingURL=muxer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"muxer.js","sourceRoot":"","sources":["../../../src/mocks/muxer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { EventEmitter } from '@libp2p/interface/events';
|
|
2
|
+
import { peerDiscovery } from '@libp2p/interface/peer-discovery';
|
|
3
|
+
import type { PeerDiscovery, PeerDiscoveryEvents } from '@libp2p/interface/peer-discovery';
|
|
4
|
+
interface MockDiscoveryInit {
|
|
5
|
+
discoveryDelay?: number;
|
|
6
|
+
}
|
|
7
|
+
/**
|
|
8
|
+
* Emits 'peer' events on discovery.
|
|
9
|
+
*/
|
|
10
|
+
export declare class MockDiscovery extends EventEmitter<PeerDiscoveryEvents> implements PeerDiscovery {
|
|
11
|
+
readonly options: MockDiscoveryInit;
|
|
12
|
+
private _isRunning;
|
|
13
|
+
private _timer;
|
|
14
|
+
constructor(init?: {});
|
|
15
|
+
readonly [peerDiscovery]: this;
|
|
16
|
+
start(): void;
|
|
17
|
+
stop(): void;
|
|
18
|
+
isStarted(): boolean;
|
|
19
|
+
_discoverPeer(): void;
|
|
20
|
+
}
|
|
21
|
+
export {};
|
|
22
|
+
//# sourceMappingURL=peer-discovery.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"peer-discovery.d.ts","sourceRoot":"","sources":["../../../src/mocks/peer-discovery.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAA;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAA;AAGhE,OAAO,KAAK,EAAE,aAAa,EAAE,mBAAmB,EAAE,MAAM,kCAAkC,CAAA;AAG1F,UAAU,iBAAiB;IACzB,cAAc,CAAC,EAAE,MAAM,CAAA;CACxB;AAED;;GAEG;AACH,qBAAa,aAAc,SAAQ,YAAY,CAAC,mBAAmB,CAAE,YAAW,aAAa;IAC3F,SAAgB,OAAO,EAAE,iBAAiB,CAAA;IAC1C,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,MAAM,CAAK;gBAEN,IAAI,KAAK;IAOtB,QAAQ,CAAC,CAAC,aAAa,CAAC,OAAO;IAE/B,KAAK,IAAK,IAAI;IAKd,IAAI,IAAK,IAAI;IAKb,SAAS,IAAK,OAAO;IAIrB,aAAa,IAAK,IAAI;CAiBvB"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { EventEmitter } from '@libp2p/interface/events';
|
|
2
|
+
import { peerDiscovery } from '@libp2p/interface/peer-discovery';
|
|
3
|
+
import * as PeerIdFactory from '@libp2p/peer-id-factory';
|
|
4
|
+
import { multiaddr } from '@multiformats/multiaddr';
|
|
5
|
+
/**
|
|
6
|
+
* Emits 'peer' events on discovery.
|
|
7
|
+
*/
|
|
8
|
+
export class MockDiscovery extends EventEmitter {
|
|
9
|
+
options;
|
|
10
|
+
_isRunning;
|
|
11
|
+
_timer;
|
|
12
|
+
constructor(init = {}) {
|
|
13
|
+
super();
|
|
14
|
+
this.options = init;
|
|
15
|
+
this._isRunning = false;
|
|
16
|
+
}
|
|
17
|
+
[peerDiscovery] = this;
|
|
18
|
+
start() {
|
|
19
|
+
this._isRunning = true;
|
|
20
|
+
this._discoverPeer();
|
|
21
|
+
}
|
|
22
|
+
stop() {
|
|
23
|
+
clearTimeout(this._timer);
|
|
24
|
+
this._isRunning = false;
|
|
25
|
+
}
|
|
26
|
+
isStarted() {
|
|
27
|
+
return this._isRunning;
|
|
28
|
+
}
|
|
29
|
+
_discoverPeer() {
|
|
30
|
+
if (!this._isRunning)
|
|
31
|
+
return;
|
|
32
|
+
PeerIdFactory.createEd25519PeerId()
|
|
33
|
+
.then(peerId => {
|
|
34
|
+
this._timer = setTimeout(() => {
|
|
35
|
+
this.safeDispatchEvent('peer', {
|
|
36
|
+
detail: {
|
|
37
|
+
id: peerId,
|
|
38
|
+
multiaddrs: [multiaddr('/ip4/127.0.0.1/tcp/8000')],
|
|
39
|
+
protocols: []
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
}, this.options.discoveryDelay ?? 1000);
|
|
43
|
+
})
|
|
44
|
+
.catch(() => { });
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=peer-discovery.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"peer-discovery.js","sourceRoot":"","sources":["../../../src/mocks/peer-discovery.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAA;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAA;AAChE,OAAO,KAAK,aAAa,MAAM,yBAAyB,CAAA;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAA;AAQnD;;GAEG;AACH,MAAM,OAAO,aAAc,SAAQ,YAAiC;IAClD,OAAO,CAAmB;IAClC,UAAU,CAAS;IACnB,MAAM,CAAK;IAEnB,YAAa,IAAI,GAAG,EAAE;QACpB,KAAK,EAAE,CAAA;QAEP,IAAI,CAAC,OAAO,GAAG,IAAI,CAAA;QACnB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAA;IACzB,CAAC;IAEQ,CAAC,aAAa,CAAC,GAAG,IAAI,CAAA;IAE/B,KAAK;QACH,IAAI,CAAC,UAAU,GAAG,IAAI,CAAA;QACtB,IAAI,CAAC,aAAa,EAAE,CAAA;IACtB,CAAC;IAED,IAAI;QACF,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;QACzB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAA;IACzB,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,UAAU,CAAA;IACxB,CAAC;IAED,aAAa;QACX,IAAI,CAAC,IAAI,CAAC,UAAU;YAAE,OAAM;QAE5B,aAAa,CAAC,mBAAmB,EAAE;aAChC,IAAI,CAAC,MAAM,CAAC,EAAE;YACb,IAAI,CAAC,MAAM,GAAG,UAAU,CAAC,GAAG,EAAE;gBAC5B,IAAI,CAAC,iBAAiB,CAAW,MAAM,EAAE;oBACvC,MAAM,EAAE;wBACN,EAAE,EAAE,MAAM;wBACV,UAAU,EAAE,CAAC,SAAS,CAAC,yBAAyB,CAAC,CAAC;wBAClD,SAAS,EAAE,EAAE;qBACd;iBACF,CAAC,CAAA;YACJ,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,cAAc,IAAI,IAAI,CAAC,CAAA;QACzC,CAAC,CAAC;aACD,KAAK,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAA;IACpB,CAAC;CACF"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { Connection } from '@libp2p/interface/connection';
|
|
2
|
+
import type { PeerId } from '@libp2p/interface/peer-id';
|
|
3
|
+
import type { Topology } from '@libp2p/interface/topology';
|
|
4
|
+
import type { IncomingStreamData, Registrar, StreamHandler, StreamHandlerOptions, StreamHandlerRecord } from '@libp2p/interface-internal/registrar';
|
|
5
|
+
export declare class MockRegistrar implements Registrar {
|
|
6
|
+
private readonly topologies;
|
|
7
|
+
private readonly handlers;
|
|
8
|
+
getProtocols(): string[];
|
|
9
|
+
handle(protocol: string, handler: StreamHandler, opts?: StreamHandlerOptions): Promise<void>;
|
|
10
|
+
unhandle(protocol: string): Promise<void>;
|
|
11
|
+
getHandler(protocol: string): StreamHandlerRecord;
|
|
12
|
+
register(protocol: string, topology: Topology): Promise<string>;
|
|
13
|
+
unregister(id: string | string[]): void;
|
|
14
|
+
getTopologies(protocol: string): Topology[];
|
|
15
|
+
}
|
|
16
|
+
export declare function mockRegistrar(): Registrar;
|
|
17
|
+
export declare function mockIncomingStreamEvent(protocol: string, conn: Connection, remotePeer: PeerId): Promise<IncomingStreamData>;
|
|
18
|
+
//# sourceMappingURL=registrar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registrar.d.ts","sourceRoot":"","sources":["../../../src/mocks/registrar.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAA;AAC9D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,2BAA2B,CAAA;AACvD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAC1D,OAAO,KAAK,EAAE,kBAAkB,EAAE,SAAS,EAAE,aAAa,EAAE,oBAAoB,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAA;AAEnJ,qBAAa,aAAc,YAAW,SAAS;IAC7C,OAAO,CAAC,QAAQ,CAAC,UAAU,CAA+D;IAC1F,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAyC;IAElE,YAAY,IAAK,MAAM,EAAE;IAInB,MAAM,CAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,aAAa,EAAE,IAAI,CAAC,EAAE,oBAAoB,GAAG,OAAO,CAAC,IAAI,CAAC;IAgB7F,QAAQ,CAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIhD,UAAU,CAAE,QAAQ,EAAE,MAAM,GAAG,mBAAmB;IAU5C,QAAQ,CAAE,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,OAAO,CAAC,MAAM,CAAC;IAkBtE,UAAU,CAAE,EAAE,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,IAAI;IAQxC,aAAa,CAAE,QAAQ,EAAE,MAAM,GAAG,QAAQ,EAAE;CAG7C;AAED,wBAAgB,aAAa,IAAK,SAAS,CAE1C;AAED,wBAAsB,uBAAuB,CAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAQlI"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import merge from 'merge-options';
|
|
2
|
+
export class MockRegistrar {
|
|
3
|
+
topologies = new Map();
|
|
4
|
+
handlers = new Map();
|
|
5
|
+
getProtocols() {
|
|
6
|
+
return Array.from(this.handlers.keys()).sort();
|
|
7
|
+
}
|
|
8
|
+
async handle(protocol, handler, opts) {
|
|
9
|
+
const options = merge.bind({ ignoreUndefined: true })({
|
|
10
|
+
maxInboundStreams: 1,
|
|
11
|
+
maxOutboundStreams: 1
|
|
12
|
+
}, opts);
|
|
13
|
+
if (this.handlers.has(protocol)) {
|
|
14
|
+
throw new Error(`Handler already registered for protocol ${protocol}`);
|
|
15
|
+
}
|
|
16
|
+
this.handlers.set(protocol, {
|
|
17
|
+
handler,
|
|
18
|
+
options
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
async unhandle(protocol) {
|
|
22
|
+
this.handlers.delete(protocol);
|
|
23
|
+
}
|
|
24
|
+
getHandler(protocol) {
|
|
25
|
+
const handler = this.handlers.get(protocol);
|
|
26
|
+
if (handler == null) {
|
|
27
|
+
throw new Error(`No handler registered for protocol ${protocol}`);
|
|
28
|
+
}
|
|
29
|
+
return handler;
|
|
30
|
+
}
|
|
31
|
+
async register(protocol, topology) {
|
|
32
|
+
const id = `topology-id-${Math.random()}`;
|
|
33
|
+
let topologies = this.topologies.get(protocol);
|
|
34
|
+
if (topologies == null) {
|
|
35
|
+
topologies = [];
|
|
36
|
+
}
|
|
37
|
+
topologies.push({
|
|
38
|
+
id,
|
|
39
|
+
topology
|
|
40
|
+
});
|
|
41
|
+
this.topologies.set(protocol, topologies);
|
|
42
|
+
return id;
|
|
43
|
+
}
|
|
44
|
+
unregister(id) {
|
|
45
|
+
if (!Array.isArray(id)) {
|
|
46
|
+
id = [id];
|
|
47
|
+
}
|
|
48
|
+
id.forEach(id => this.topologies.delete(id));
|
|
49
|
+
}
|
|
50
|
+
getTopologies(protocol) {
|
|
51
|
+
return (this.topologies.get(protocol) ?? []).map(t => t.topology);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
export function mockRegistrar() {
|
|
55
|
+
return new MockRegistrar();
|
|
56
|
+
}
|
|
57
|
+
export async function mockIncomingStreamEvent(protocol, conn, remotePeer) {
|
|
58
|
+
return {
|
|
59
|
+
...await conn.newStream([protocol]),
|
|
60
|
+
// @ts-expect-error incomplete implementation
|
|
61
|
+
connection: {
|
|
62
|
+
remotePeer
|
|
63
|
+
}
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
//# sourceMappingURL=registrar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registrar.js","sourceRoot":"","sources":["../../../src/mocks/registrar.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,eAAe,CAAA;AAMjC,MAAM,OAAO,aAAa;IACP,UAAU,GAAG,IAAI,GAAG,EAAqD,CAAA;IACzE,QAAQ,GAAG,IAAI,GAAG,EAA+B,CAAA;IAElE,YAAY;QACV,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAA;IAChD,CAAC;IAED,KAAK,CAAC,MAAM,CAAE,QAAgB,EAAE,OAAsB,EAAE,IAA2B;QACjF,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,eAAe,EAAE,IAAI,EAAE,CAAC,CAAC;YACpD,iBAAiB,EAAE,CAAC;YACpB,kBAAkB,EAAE,CAAC;SACtB,EAAE,IAAI,CAAC,CAAA;QAER,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;YAC/B,MAAM,IAAI,KAAK,CAAC,2CAA2C,QAAQ,EAAE,CAAC,CAAA;SACvE;QAED,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,EAAE;YAC1B,OAAO;YACP,OAAO;SACR,CAAC,CAAA;IACJ,CAAC;IAED,KAAK,CAAC,QAAQ,CAAE,QAAgB;QAC9B,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAA;IAChC,CAAC;IAED,UAAU,CAAE,QAAgB;QAC1B,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;QAE3C,IAAI,OAAO,IAAI,IAAI,EAAE;YACnB,MAAM,IAAI,KAAK,CAAC,sCAAsC,QAAQ,EAAE,CAAC,CAAA;SAClE;QAED,OAAO,OAAO,CAAA;IAChB,CAAC;IAED,KAAK,CAAC,QAAQ,CAAE,QAAgB,EAAE,QAAkB;QAClD,MAAM,EAAE,GAAG,eAAe,IAAI,CAAC,MAAM,EAAE,EAAE,CAAA;QACzC,IAAI,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;QAE9C,IAAI,UAAU,IAAI,IAAI,EAAE;YACtB,UAAU,GAAG,EAAE,CAAA;SAChB;QAED,UAAU,CAAC,IAAI,CAAC;YACd,EAAE;YACF,QAAQ;SACT,CAAC,CAAA;QAEF,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAA;QAEzC,OAAO,EAAE,CAAA;IACX,CAAC;IAED,UAAU,CAAE,EAAqB;QAC/B,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE;YACtB,EAAE,GAAG,CAAC,EAAE,CAAC,CAAA;SACV;QAED,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAA;IAC9C,CAAC;IAED,aAAa,CAAE,QAAgB;QAC7B,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAA;IACnE,CAAC;CACF;AAED,MAAM,UAAU,aAAa;IAC3B,OAAO,IAAI,aAAa,EAAE,CAAA;AAC5B,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,uBAAuB,CAAE,QAAgB,EAAE,IAAgB,EAAE,UAAkB;IACnG,OAAO;QACL,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,CAAC,QAAQ,CAAC,CAAC;QACnC,6CAA6C;QAC7C,UAAU,EAAE;YACV,UAAU;SACX;KACF,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { Libp2pEvents } from '@libp2p/interface';
|
|
2
|
+
import type { EventEmitter } from '@libp2p/interface/events';
|
|
3
|
+
import type { Upgrader } from '@libp2p/interface/transport';
|
|
4
|
+
import type { Registrar } from '@libp2p/interface-internal/registrar';
|
|
5
|
+
export interface MockUpgraderInit {
|
|
6
|
+
registrar?: Registrar;
|
|
7
|
+
events?: EventEmitter<Libp2pEvents>;
|
|
8
|
+
}
|
|
9
|
+
export declare function mockUpgrader(init?: MockUpgraderInit): Upgrader;
|
|
10
|
+
//# sourceMappingURL=upgrader.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"upgrader.d.ts","sourceRoot":"","sources":["../../../src/mocks/upgrader.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAA;AAErD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAA;AAC5D,OAAO,KAAK,EAAE,QAAQ,EAAmB,MAAM,6BAA6B,CAAA;AAC5E,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sCAAsC,CAAA;AAErE,MAAM,WAAW,gBAAgB;IAC/B,SAAS,CAAC,EAAE,SAAS,CAAA;IACrB,MAAM,CAAC,EAAE,YAAY,CAAC,YAAY,CAAC,CAAA;CACpC;AAoCD,wBAAgB,YAAY,CAAE,IAAI,GAAE,gBAAqB,GAAG,QAAQ,CAEnE"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { mockConnection } from './connection.js';
|
|
2
|
+
class MockUpgrader {
|
|
3
|
+
registrar;
|
|
4
|
+
events;
|
|
5
|
+
constructor(init) {
|
|
6
|
+
this.registrar = init.registrar;
|
|
7
|
+
this.events = init.events;
|
|
8
|
+
}
|
|
9
|
+
async upgradeOutbound(multiaddrConnection, opts = {}) {
|
|
10
|
+
const connection = mockConnection(multiaddrConnection, {
|
|
11
|
+
direction: 'outbound',
|
|
12
|
+
registrar: this.registrar,
|
|
13
|
+
...opts
|
|
14
|
+
});
|
|
15
|
+
this.events?.safeDispatchEvent('connection:open', { detail: connection });
|
|
16
|
+
return connection;
|
|
17
|
+
}
|
|
18
|
+
async upgradeInbound(multiaddrConnection, opts = {}) {
|
|
19
|
+
const connection = mockConnection(multiaddrConnection, {
|
|
20
|
+
direction: 'inbound',
|
|
21
|
+
registrar: this.registrar,
|
|
22
|
+
...opts
|
|
23
|
+
});
|
|
24
|
+
this.events?.safeDispatchEvent('connection:open', { detail: connection });
|
|
25
|
+
return connection;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
export function mockUpgrader(init = {}) {
|
|
29
|
+
return new MockUpgrader(init);
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=upgrader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"upgrader.js","sourceRoot":"","sources":["../../../src/mocks/upgrader.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAA;AAYhD,MAAM,YAAY;IACC,SAAS,CAAY;IACrB,MAAM,CAA6B;IAEpD,YAAa,IAAsB;QACjC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAA;QAC/B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAA;IAC3B,CAAC;IAED,KAAK,CAAC,eAAe,CAAE,mBAAwC,EAAE,OAAwB,EAAE;QACzF,MAAM,UAAU,GAAG,cAAc,CAAC,mBAAmB,EAAE;YACrD,SAAS,EAAE,UAAU;YACrB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,GAAG,IAAI;SACR,CAAC,CAAA;QAEF,IAAI,CAAC,MAAM,EAAE,iBAAiB,CAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,CAAA;QAEzE,OAAO,UAAU,CAAA;IACnB,CAAC;IAED,KAAK,CAAC,cAAc,CAAE,mBAAwC,EAAE,OAAwB,EAAE;QACxF,MAAM,UAAU,GAAG,cAAc,CAAC,mBAAmB,EAAE;YACrD,SAAS,EAAE,SAAS;YACpB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,GAAG,IAAI;SACR,CAAC,CAAA;QAEF,IAAI,CAAC,MAAM,EAAE,iBAAiB,CAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,CAAA;QAEzE,OAAO,UAAU,CAAA;IACnB,CAAC;CACF;AAED,MAAM,UAAU,YAAY,CAAE,OAAyB,EAAE;IACvD,OAAO,IAAI,YAAY,CAAC,IAAI,CAAC,CAAA;AAC/B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/peer-discovery/index.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AAC5C,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAA;iCAE7C,UAAU,aAAa,CAAC,KAAG,IAAI;AAAvD,wBAiFC"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { start, stop } from '@libp2p/interface/startable';
|
|
2
|
+
import { isMultiaddr } from '@multiformats/multiaddr';
|
|
3
|
+
import { expect } from 'aegir/chai';
|
|
4
|
+
import delay from 'delay';
|
|
5
|
+
import pDefer from 'p-defer';
|
|
6
|
+
export default (common) => {
|
|
7
|
+
describe('interface-peer-discovery compliance tests', () => {
|
|
8
|
+
let discovery;
|
|
9
|
+
beforeEach(async () => {
|
|
10
|
+
discovery = await common.setup();
|
|
11
|
+
});
|
|
12
|
+
afterEach('ensure discovery was stopped', async () => {
|
|
13
|
+
await stop(discovery);
|
|
14
|
+
await common.teardown();
|
|
15
|
+
});
|
|
16
|
+
it('can start the service', async () => {
|
|
17
|
+
await start(discovery);
|
|
18
|
+
});
|
|
19
|
+
it('can start and stop the service', async () => {
|
|
20
|
+
await start(discovery);
|
|
21
|
+
await stop(discovery);
|
|
22
|
+
});
|
|
23
|
+
it('should not fail to stop the service if it was not started', async () => {
|
|
24
|
+
await stop(discovery);
|
|
25
|
+
});
|
|
26
|
+
it('should not fail to start the service if it is already started', async () => {
|
|
27
|
+
await start(discovery);
|
|
28
|
+
await start(discovery);
|
|
29
|
+
});
|
|
30
|
+
it('should emit a peer event after start', async () => {
|
|
31
|
+
const defer = pDefer();
|
|
32
|
+
discovery.addEventListener('peer', (evt) => {
|
|
33
|
+
const { id, multiaddrs } = evt.detail;
|
|
34
|
+
expect(id).to.exist();
|
|
35
|
+
expect(id)
|
|
36
|
+
.to.have.property('type')
|
|
37
|
+
.that.is.oneOf(['RSA', 'Ed25519', 'secp256k1']);
|
|
38
|
+
expect(multiaddrs).to.exist();
|
|
39
|
+
multiaddrs.forEach((m) => expect(isMultiaddr(m)).to.eql(true));
|
|
40
|
+
defer.resolve();
|
|
41
|
+
});
|
|
42
|
+
await start(discovery);
|
|
43
|
+
await defer.promise;
|
|
44
|
+
});
|
|
45
|
+
it('should not receive a peer event before start', async () => {
|
|
46
|
+
discovery.addEventListener('peer', () => {
|
|
47
|
+
throw new Error('should not receive a peer event before start');
|
|
48
|
+
});
|
|
49
|
+
await delay(2000);
|
|
50
|
+
});
|
|
51
|
+
it('should not receive a peer event after stop', async () => {
|
|
52
|
+
const deferStart = pDefer();
|
|
53
|
+
discovery.addEventListener('peer', () => {
|
|
54
|
+
deferStart.resolve();
|
|
55
|
+
});
|
|
56
|
+
await start(discovery);
|
|
57
|
+
await deferStart.promise;
|
|
58
|
+
await stop(discovery);
|
|
59
|
+
discovery.addEventListener('peer', () => {
|
|
60
|
+
throw new Error('should not receive a peer event after stop');
|
|
61
|
+
});
|
|
62
|
+
await delay(2000);
|
|
63
|
+
});
|
|
64
|
+
});
|
|
65
|
+
};
|
|
66
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/peer-discovery/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { PubSubArgs } from './index.js';
|
|
2
|
+
import type { TestSetup } from '../index.js';
|
|
3
|
+
import type { PubSub } from '@libp2p/interface/pubsub';
|
|
4
|
+
declare const _default: (common: TestSetup<PubSub, PubSubArgs>) => void;
|
|
5
|
+
export default _default;
|
|
6
|
+
//# sourceMappingURL=api.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"api.d.ts","sourceRoot":"","sources":["../../../src/pubsub/api.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,UAAU,EAAoB,MAAM,YAAY,CAAA;AAC9D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AAC5C,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,0BAA0B,CAAA;iCAK9B,UAAU,MAAM,EAAE,UAAU,CAAC,KAAG,IAAI;AAA5D,wBAiGC"}
|