@libp2p/interface-compliance-tests 3.0.7-ea8a0637 → 3.0.7-eabf6f36
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 +9 -0
- 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 +72 -5
- 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
|
@@ -0,0 +1,357 @@
|
|
|
1
|
+
/* eslint max-nested-callbacks: ["error", 8] */
|
|
2
|
+
import { abortableSource } from 'abortable-iterator';
|
|
3
|
+
import { expect } from 'aegir/chai';
|
|
4
|
+
import delay from 'delay';
|
|
5
|
+
import all from 'it-all';
|
|
6
|
+
import drain from 'it-drain';
|
|
7
|
+
import { duplexPair } from 'it-pair/duplex';
|
|
8
|
+
import { pipe } from 'it-pipe';
|
|
9
|
+
import { pbStream } from 'it-protobuf-stream';
|
|
10
|
+
import toBuffer from 'it-to-buffer';
|
|
11
|
+
import pDefer from 'p-defer';
|
|
12
|
+
import { Uint8ArrayList } from 'uint8arraylist';
|
|
13
|
+
import { fromString as uint8ArrayFromString } from 'uint8arrays/from-string';
|
|
14
|
+
import { Message } from './fixtures/pb/message.js';
|
|
15
|
+
function randomBuffer() {
|
|
16
|
+
return uint8ArrayFromString(Math.random().toString());
|
|
17
|
+
}
|
|
18
|
+
const infiniteRandom = {
|
|
19
|
+
[Symbol.asyncIterator]: async function* () {
|
|
20
|
+
while (true) {
|
|
21
|
+
yield new Uint8ArrayList(randomBuffer());
|
|
22
|
+
await delay(50);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
export default (common) => {
|
|
27
|
+
describe('close', () => {
|
|
28
|
+
it('closing underlying socket closes streams', async () => {
|
|
29
|
+
let openedStreams = 0;
|
|
30
|
+
const expectedStreams = 5;
|
|
31
|
+
const dialerFactory = await common.setup();
|
|
32
|
+
const dialer = dialerFactory.createStreamMuxer({ direction: 'outbound' });
|
|
33
|
+
// Listener is echo server :)
|
|
34
|
+
const listenerFactory = await common.setup();
|
|
35
|
+
const listener = listenerFactory.createStreamMuxer({
|
|
36
|
+
direction: 'inbound',
|
|
37
|
+
onIncomingStream: (stream) => {
|
|
38
|
+
openedStreams++;
|
|
39
|
+
void pipe(stream, stream);
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
const p = duplexPair();
|
|
43
|
+
void pipe(p[0], dialer, p[0]);
|
|
44
|
+
void pipe(p[1], listener, p[1]);
|
|
45
|
+
const streams = await Promise.all(Array(expectedStreams).fill(0).map(async () => dialer.newStream()));
|
|
46
|
+
void Promise.all(streams.map(async (stream) => {
|
|
47
|
+
await pipe(infiniteRandom, stream, drain);
|
|
48
|
+
}));
|
|
49
|
+
expect(dialer.streams).to.have.lengthOf(expectedStreams);
|
|
50
|
+
// Pause, and then close the dialer
|
|
51
|
+
await delay(50);
|
|
52
|
+
await pipe([], dialer, drain);
|
|
53
|
+
expect(openedStreams).to.have.equal(expectedStreams);
|
|
54
|
+
expect(dialer.streams).to.have.lengthOf(0);
|
|
55
|
+
});
|
|
56
|
+
it('calling close closes streams', async () => {
|
|
57
|
+
let openedStreams = 0;
|
|
58
|
+
const expectedStreams = 5;
|
|
59
|
+
const dialerFactory = await common.setup();
|
|
60
|
+
const dialer = dialerFactory.createStreamMuxer({ direction: 'outbound' });
|
|
61
|
+
// Listener is echo server :)
|
|
62
|
+
const listenerFactory = await common.setup();
|
|
63
|
+
const listener = listenerFactory.createStreamMuxer({
|
|
64
|
+
direction: 'inbound',
|
|
65
|
+
onIncomingStream: (stream) => {
|
|
66
|
+
openedStreams++;
|
|
67
|
+
void pipe(stream, stream).catch(() => { });
|
|
68
|
+
}
|
|
69
|
+
});
|
|
70
|
+
const p = duplexPair();
|
|
71
|
+
void pipe(p[0], dialer, p[0]);
|
|
72
|
+
void pipe(p[1], listener, p[1]);
|
|
73
|
+
const streams = await Promise.all(Array(expectedStreams).fill(0).map(async () => dialer.newStream()));
|
|
74
|
+
void Promise.all(streams.map(async (stream) => {
|
|
75
|
+
await pipe(infiniteRandom, stream, drain);
|
|
76
|
+
}));
|
|
77
|
+
expect(dialer.streams, 'dialer - number of opened streams should match number of calls to newStream').to.have.lengthOf(expectedStreams);
|
|
78
|
+
// Pause, and then close the dialer
|
|
79
|
+
await delay(50);
|
|
80
|
+
await dialer.close();
|
|
81
|
+
expect(openedStreams, 'listener - number of opened streams should match number of calls to newStream').to.have.equal(expectedStreams);
|
|
82
|
+
expect(dialer.streams, 'all tracked streams should be deleted after the muxer has called close').to.have.lengthOf(0);
|
|
83
|
+
});
|
|
84
|
+
it('calling close with an error aborts streams', async () => {
|
|
85
|
+
let openedStreams = 0;
|
|
86
|
+
const expectedStreams = 5;
|
|
87
|
+
const dialerFactory = await common.setup();
|
|
88
|
+
const dialer = dialerFactory.createStreamMuxer({ direction: 'outbound' });
|
|
89
|
+
// Listener is echo server :)
|
|
90
|
+
const listenerFactory = await common.setup();
|
|
91
|
+
const listener = listenerFactory.createStreamMuxer({
|
|
92
|
+
direction: 'inbound',
|
|
93
|
+
onIncomingStream: (stream) => {
|
|
94
|
+
openedStreams++;
|
|
95
|
+
void pipe(stream, stream).catch(() => { });
|
|
96
|
+
}
|
|
97
|
+
});
|
|
98
|
+
const p = duplexPair();
|
|
99
|
+
void pipe(p[0], dialer, p[0]);
|
|
100
|
+
void pipe(p[1], listener, p[1]);
|
|
101
|
+
const streams = await Promise.all(Array(expectedStreams).fill(0).map(async () => dialer.newStream()));
|
|
102
|
+
const streamPipes = streams.map(async (stream) => {
|
|
103
|
+
await pipe(infiniteRandom, stream, drain);
|
|
104
|
+
});
|
|
105
|
+
expect(dialer.streams, 'dialer - number of opened streams should match number of calls to newStream').to.have.lengthOf(expectedStreams);
|
|
106
|
+
// Pause, and then close the dialer
|
|
107
|
+
await delay(50);
|
|
108
|
+
// close _with an error_
|
|
109
|
+
dialer.abort(new Error('Oh no!'));
|
|
110
|
+
const timeoutError = new Error('timeout');
|
|
111
|
+
for (const pipe of streamPipes) {
|
|
112
|
+
try {
|
|
113
|
+
await Promise.race([
|
|
114
|
+
pipe,
|
|
115
|
+
new Promise((_resolve, reject) => setTimeout(() => { reject(timeoutError); }, 20))
|
|
116
|
+
]);
|
|
117
|
+
expect.fail('stream pipe with infinite source should never return');
|
|
118
|
+
}
|
|
119
|
+
catch (e) {
|
|
120
|
+
if (e === timeoutError) {
|
|
121
|
+
expect.fail('expected stream pipe to throw an error after muxer closed with error');
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
expect(openedStreams, 'listener - number of opened streams should match number of calls to newStream').to.have.equal(expectedStreams);
|
|
126
|
+
expect(dialer.streams, 'all tracked streams should be deleted after the muxer has called close').to.have.lengthOf(0);
|
|
127
|
+
});
|
|
128
|
+
it('calling newStream after close throws an error', async () => {
|
|
129
|
+
const dialerFactory = await common.setup();
|
|
130
|
+
const dialer = dialerFactory.createStreamMuxer({ direction: 'outbound' });
|
|
131
|
+
await dialer.close();
|
|
132
|
+
try {
|
|
133
|
+
await dialer.newStream();
|
|
134
|
+
expect.fail('newStream should throw if called after close');
|
|
135
|
+
}
|
|
136
|
+
catch (e) {
|
|
137
|
+
expect(dialer.streams, 'closed muxer should have no streams').to.have.lengthOf(0);
|
|
138
|
+
}
|
|
139
|
+
});
|
|
140
|
+
it('closing one of the muxed streams doesn\'t close others', async () => {
|
|
141
|
+
const p = duplexPair();
|
|
142
|
+
const dialerFactory = await common.setup();
|
|
143
|
+
const dialer = dialerFactory.createStreamMuxer({ direction: 'outbound' });
|
|
144
|
+
// Listener is echo server :)
|
|
145
|
+
const listenerFactory = await common.setup();
|
|
146
|
+
const listener = listenerFactory.createStreamMuxer({
|
|
147
|
+
direction: 'inbound',
|
|
148
|
+
onIncomingStream: (stream) => {
|
|
149
|
+
void pipe(stream, stream).catch(() => { });
|
|
150
|
+
}
|
|
151
|
+
});
|
|
152
|
+
void pipe(p[0], dialer, p[0]);
|
|
153
|
+
void pipe(p[1], listener, p[1]);
|
|
154
|
+
const stream = await dialer.newStream();
|
|
155
|
+
const streams = await Promise.all(Array.from(Array(5), async () => dialer.newStream()));
|
|
156
|
+
let closed = false;
|
|
157
|
+
const controllers = [];
|
|
158
|
+
const streamResults = streams.map(async (stream) => {
|
|
159
|
+
const controller = new AbortController();
|
|
160
|
+
controllers.push(controller);
|
|
161
|
+
try {
|
|
162
|
+
const abortableRand = abortableSource(infiniteRandom, controller.signal, { abortCode: 'ERR_TEST_ABORT' });
|
|
163
|
+
await pipe(abortableRand, stream, drain);
|
|
164
|
+
}
|
|
165
|
+
catch (err) {
|
|
166
|
+
if (err.code !== 'ERR_TEST_ABORT')
|
|
167
|
+
throw err;
|
|
168
|
+
}
|
|
169
|
+
if (!closed)
|
|
170
|
+
throw new Error('stream should not have ended yet!');
|
|
171
|
+
});
|
|
172
|
+
// Pause, and then send some data and close the first stream
|
|
173
|
+
await delay(50);
|
|
174
|
+
await pipe([new Uint8ArrayList(randomBuffer())], stream, drain);
|
|
175
|
+
closed = true;
|
|
176
|
+
// Abort all the other streams later
|
|
177
|
+
await delay(50);
|
|
178
|
+
controllers.forEach(c => { c.abort(); });
|
|
179
|
+
// These should now all resolve without error
|
|
180
|
+
await Promise.all(streamResults);
|
|
181
|
+
});
|
|
182
|
+
it('can close a stream for writing', async () => {
|
|
183
|
+
const deferred = pDefer();
|
|
184
|
+
const p = duplexPair();
|
|
185
|
+
const dialerFactory = await common.setup();
|
|
186
|
+
const dialer = dialerFactory.createStreamMuxer({ direction: 'outbound' });
|
|
187
|
+
const data = [randomBuffer(), randomBuffer()];
|
|
188
|
+
const listenerFactory = await common.setup();
|
|
189
|
+
const listener = listenerFactory.createStreamMuxer({
|
|
190
|
+
direction: 'inbound',
|
|
191
|
+
onIncomingStream: (stream) => {
|
|
192
|
+
void Promise.resolve().then(async () => {
|
|
193
|
+
// Immediate close for write
|
|
194
|
+
await stream.closeWrite();
|
|
195
|
+
const results = await pipe(stream, async (source) => {
|
|
196
|
+
const data = [];
|
|
197
|
+
for await (const chunk of source) {
|
|
198
|
+
data.push(chunk.slice());
|
|
199
|
+
}
|
|
200
|
+
return data;
|
|
201
|
+
});
|
|
202
|
+
expect(results).to.eql(data);
|
|
203
|
+
try {
|
|
204
|
+
await stream.sink([new Uint8ArrayList(randomBuffer())]);
|
|
205
|
+
}
|
|
206
|
+
catch (err) {
|
|
207
|
+
deferred.resolve(err);
|
|
208
|
+
}
|
|
209
|
+
deferred.reject(new Error('should not support writing to closed writer'));
|
|
210
|
+
});
|
|
211
|
+
}
|
|
212
|
+
});
|
|
213
|
+
void pipe(p[0], dialer, p[0]);
|
|
214
|
+
void pipe(p[1], listener, p[1]);
|
|
215
|
+
const stream = await dialer.newStream();
|
|
216
|
+
await stream.sink(data);
|
|
217
|
+
const err = await deferred.promise;
|
|
218
|
+
expect(err).to.have.property('code', 'ERR_SINK_INVALID_STATE');
|
|
219
|
+
});
|
|
220
|
+
it('can close a stream for reading', async () => {
|
|
221
|
+
const deferred = pDefer();
|
|
222
|
+
const p = duplexPair();
|
|
223
|
+
const dialerFactory = await common.setup();
|
|
224
|
+
const dialer = dialerFactory.createStreamMuxer({ direction: 'outbound' });
|
|
225
|
+
const data = [randomBuffer(), randomBuffer()].map(d => new Uint8ArrayList(d));
|
|
226
|
+
const expected = toBuffer(data.map(d => d.subarray()));
|
|
227
|
+
const listenerFactory = await common.setup();
|
|
228
|
+
const listener = listenerFactory.createStreamMuxer({
|
|
229
|
+
direction: 'inbound',
|
|
230
|
+
onIncomingStream: (stream) => {
|
|
231
|
+
void all(stream.source).then(deferred.resolve, deferred.reject);
|
|
232
|
+
}
|
|
233
|
+
});
|
|
234
|
+
void pipe(p[0], dialer, p[0]);
|
|
235
|
+
void pipe(p[1], listener, p[1]);
|
|
236
|
+
const stream = await dialer.newStream();
|
|
237
|
+
await stream.closeRead();
|
|
238
|
+
// Source should be done
|
|
239
|
+
void Promise.resolve().then(async () => {
|
|
240
|
+
expect(await stream.source.next()).to.have.property('done', true);
|
|
241
|
+
await stream.sink(data);
|
|
242
|
+
});
|
|
243
|
+
const results = await deferred.promise;
|
|
244
|
+
expect(toBuffer(results.map(b => b.subarray()))).to.equalBytes(expected);
|
|
245
|
+
});
|
|
246
|
+
it('calls onStreamEnd for closed streams not previously written', async () => {
|
|
247
|
+
const deferred = pDefer();
|
|
248
|
+
const onStreamEnd = () => { deferred.resolve(); };
|
|
249
|
+
const dialerFactory = await common.setup();
|
|
250
|
+
const dialer = dialerFactory.createStreamMuxer({
|
|
251
|
+
direction: 'outbound',
|
|
252
|
+
onStreamEnd
|
|
253
|
+
});
|
|
254
|
+
const stream = await dialer.newStream();
|
|
255
|
+
await stream.close();
|
|
256
|
+
await deferred.promise;
|
|
257
|
+
});
|
|
258
|
+
it('calls onStreamEnd for read and write closed streams not previously written', async () => {
|
|
259
|
+
const deferred = pDefer();
|
|
260
|
+
const onStreamEnd = () => { deferred.resolve(); };
|
|
261
|
+
const dialerFactory = await common.setup();
|
|
262
|
+
const dialer = dialerFactory.createStreamMuxer({
|
|
263
|
+
direction: 'outbound',
|
|
264
|
+
onStreamEnd
|
|
265
|
+
});
|
|
266
|
+
const stream = await dialer.newStream();
|
|
267
|
+
await stream.closeWrite();
|
|
268
|
+
await stream.closeRead();
|
|
269
|
+
await deferred.promise;
|
|
270
|
+
});
|
|
271
|
+
it('should wait for all data to be sent when closing streams', async () => {
|
|
272
|
+
const deferred = pDefer();
|
|
273
|
+
const p = duplexPair();
|
|
274
|
+
const dialerFactory = await common.setup();
|
|
275
|
+
const dialer = dialerFactory.createStreamMuxer({ direction: 'outbound' });
|
|
276
|
+
const listenerFactory = await common.setup();
|
|
277
|
+
const listener = listenerFactory.createStreamMuxer({
|
|
278
|
+
direction: 'inbound',
|
|
279
|
+
onIncomingStream: (stream) => {
|
|
280
|
+
const pb = pbStream(stream);
|
|
281
|
+
void pb.read(Message)
|
|
282
|
+
.then(async (message) => {
|
|
283
|
+
deferred.resolve(message);
|
|
284
|
+
await pb.unwrap().close();
|
|
285
|
+
})
|
|
286
|
+
.catch(err => {
|
|
287
|
+
deferred.reject(err);
|
|
288
|
+
});
|
|
289
|
+
}
|
|
290
|
+
});
|
|
291
|
+
void pipe(p[0], dialer, p[0]);
|
|
292
|
+
void pipe(p[1], listener, p[1]);
|
|
293
|
+
const message = {
|
|
294
|
+
message: 'hello world',
|
|
295
|
+
value: 5,
|
|
296
|
+
flag: true
|
|
297
|
+
};
|
|
298
|
+
const stream = await dialer.newStream();
|
|
299
|
+
const pb = pbStream(stream);
|
|
300
|
+
await pb.write(message, Message);
|
|
301
|
+
await pb.unwrap().close();
|
|
302
|
+
await expect(deferred.promise).to.eventually.deep.equal(message);
|
|
303
|
+
});
|
|
304
|
+
/*
|
|
305
|
+
it('should abort closing a stream with outstanding data to read', async () => {
|
|
306
|
+
const deferred = pDefer<Message>()
|
|
307
|
+
|
|
308
|
+
const p = duplexPair<Uint8Array>()
|
|
309
|
+
const dialerFactory = await common.setup()
|
|
310
|
+
const dialer = dialerFactory.createStreamMuxer({ direction: 'outbound' })
|
|
311
|
+
|
|
312
|
+
const listenerFactory = await common.setup()
|
|
313
|
+
const listener = listenerFactory.createStreamMuxer({
|
|
314
|
+
direction: 'inbound',
|
|
315
|
+
onIncomingStream: (stream) => {
|
|
316
|
+
const pb = pbStream(stream)
|
|
317
|
+
|
|
318
|
+
void pb.read(Message)
|
|
319
|
+
.then(async message => {
|
|
320
|
+
await pb.write(message, Message)
|
|
321
|
+
await pb.unwrap().close()
|
|
322
|
+
deferred.resolve(message)
|
|
323
|
+
})
|
|
324
|
+
.catch(err => {
|
|
325
|
+
deferred.reject(err)
|
|
326
|
+
})
|
|
327
|
+
}
|
|
328
|
+
})
|
|
329
|
+
|
|
330
|
+
void pipe(p[0], dialer, p[0])
|
|
331
|
+
void pipe(p[1], listener, p[1])
|
|
332
|
+
|
|
333
|
+
const message = {
|
|
334
|
+
message: 'hello world',
|
|
335
|
+
value: 5,
|
|
336
|
+
flag: true
|
|
337
|
+
}
|
|
338
|
+
|
|
339
|
+
const stream = await dialer.newStream()
|
|
340
|
+
|
|
341
|
+
const pb = pbStream(stream)
|
|
342
|
+
await pb.write(message, Message)
|
|
343
|
+
|
|
344
|
+
console.info('await write back')
|
|
345
|
+
await deferred.promise
|
|
346
|
+
|
|
347
|
+
// let message arrive
|
|
348
|
+
await delay(100)
|
|
349
|
+
|
|
350
|
+
// close should time out as message is never read
|
|
351
|
+
await expect(pb.unwrap().close()).to.eventually.be.rejected
|
|
352
|
+
.with.property('code', 'ERR_CLOSE_READ_ABORTED')
|
|
353
|
+
})
|
|
354
|
+
*/
|
|
355
|
+
});
|
|
356
|
+
};
|
|
357
|
+
//# sourceMappingURL=close-test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"close-test.js","sourceRoot":"","sources":["../../../src/stream-muxer/close-test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { Codec } from 'protons-runtime';
|
|
2
|
+
import type { Uint8ArrayList } from 'uint8arraylist';
|
|
3
|
+
export interface Message {
|
|
4
|
+
message: string;
|
|
5
|
+
value: number;
|
|
6
|
+
flag: boolean;
|
|
7
|
+
}
|
|
8
|
+
export declare namespace Message {
|
|
9
|
+
const codec: () => Codec<Message>;
|
|
10
|
+
const encode: (obj: Partial<Message>) => Uint8Array;
|
|
11
|
+
const decode: (buf: Uint8Array | Uint8ArrayList) => Message;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=message.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"message.d.ts","sourceRoot":"","sources":["../../../../../src/stream-muxer/fixtures/pb/message.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAA;AAC5C,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAEpD,MAAM,WAAW,OAAO;IACtB,OAAO,EAAE,MAAM,CAAA;IACf,KAAK,EAAE,MAAM,CAAA;IACb,IAAI,EAAE,OAAO,CAAA;CACd;AAED,yBAAiB,OAAO,CAAC;IAGhB,MAAM,KAAK,QAAO,MAAM,OAAO,CA0DrC,CAAA;IAEM,MAAM,MAAM,QAAS,QAAQ,OAAO,CAAC,KAAG,UAE9C,CAAA;IAEM,MAAM,MAAM,QAAS,UAAU,GAAG,cAAc,KAAG,OAEzD,CAAA;CACF"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
/* eslint-disable import/export */
|
|
2
|
+
/* eslint-disable complexity */
|
|
3
|
+
/* eslint-disable @typescript-eslint/no-namespace */
|
|
4
|
+
/* eslint-disable @typescript-eslint/no-unnecessary-boolean-literal-compare */
|
|
5
|
+
/* eslint-disable @typescript-eslint/no-empty-interface */
|
|
6
|
+
import { encodeMessage, decodeMessage, message } from 'protons-runtime';
|
|
7
|
+
export var Message;
|
|
8
|
+
(function (Message) {
|
|
9
|
+
let _codec;
|
|
10
|
+
Message.codec = () => {
|
|
11
|
+
if (_codec == null) {
|
|
12
|
+
_codec = message((obj, w, opts = {}) => {
|
|
13
|
+
if (opts.lengthDelimited !== false) {
|
|
14
|
+
w.fork();
|
|
15
|
+
}
|
|
16
|
+
if ((obj.message != null && obj.message !== '')) {
|
|
17
|
+
w.uint32(10);
|
|
18
|
+
w.string(obj.message);
|
|
19
|
+
}
|
|
20
|
+
if ((obj.value != null && obj.value !== 0)) {
|
|
21
|
+
w.uint32(16);
|
|
22
|
+
w.uint32(obj.value);
|
|
23
|
+
}
|
|
24
|
+
if ((obj.flag != null && obj.flag !== false)) {
|
|
25
|
+
w.uint32(24);
|
|
26
|
+
w.bool(obj.flag);
|
|
27
|
+
}
|
|
28
|
+
if (opts.lengthDelimited !== false) {
|
|
29
|
+
w.ldelim();
|
|
30
|
+
}
|
|
31
|
+
}, (reader, length) => {
|
|
32
|
+
const obj = {
|
|
33
|
+
message: '',
|
|
34
|
+
value: 0,
|
|
35
|
+
flag: false
|
|
36
|
+
};
|
|
37
|
+
const end = length == null ? reader.len : reader.pos + length;
|
|
38
|
+
while (reader.pos < end) {
|
|
39
|
+
const tag = reader.uint32();
|
|
40
|
+
switch (tag >>> 3) {
|
|
41
|
+
case 1:
|
|
42
|
+
obj.message = reader.string();
|
|
43
|
+
break;
|
|
44
|
+
case 2:
|
|
45
|
+
obj.value = reader.uint32();
|
|
46
|
+
break;
|
|
47
|
+
case 3:
|
|
48
|
+
obj.flag = reader.bool();
|
|
49
|
+
break;
|
|
50
|
+
default:
|
|
51
|
+
reader.skipType(tag & 7);
|
|
52
|
+
break;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
return obj;
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
return _codec;
|
|
59
|
+
};
|
|
60
|
+
Message.encode = (obj) => {
|
|
61
|
+
return encodeMessage(obj, Message.codec());
|
|
62
|
+
};
|
|
63
|
+
Message.decode = (buf) => {
|
|
64
|
+
return decodeMessage(buf, Message.codec());
|
|
65
|
+
};
|
|
66
|
+
})(Message || (Message = {}));
|
|
67
|
+
//# sourceMappingURL=message.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"message.js","sourceRoot":"","sources":["../../../../../src/stream-muxer/fixtures/pb/message.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/stream-muxer/index.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AAC5C,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAA;iCAEhD,UAAU,kBAAkB,CAAC,KAAG,IAAI;AAA5D,wBAOC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import baseTest from './base-test.js';
|
|
2
|
+
import closeTest from './close-test.js';
|
|
3
|
+
import megaStressTest from './mega-stress-test.js';
|
|
4
|
+
import stressTest from './stress-test.js';
|
|
5
|
+
export default (common) => {
|
|
6
|
+
describe('interface-stream-muxer', () => {
|
|
7
|
+
baseTest(common);
|
|
8
|
+
closeTest(common);
|
|
9
|
+
stressTest(common);
|
|
10
|
+
megaStressTest(common);
|
|
11
|
+
});
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/stream-muxer/index.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,gBAAgB,CAAA;AACrC,OAAO,SAAS,MAAM,iBAAiB,CAAA;AACvC,OAAO,cAAc,MAAM,uBAAuB,CAAA;AAClD,OAAO,UAAU,MAAM,kBAAkB,CAAA;AAIzC,eAAe,CAAC,MAAqC,EAAQ,EAAE;IAC7D,QAAQ,CAAC,wBAAwB,EAAE,GAAG,EAAE;QACtC,QAAQ,CAAC,MAAM,CAAC,CAAA;QAChB,SAAS,CAAC,MAAM,CAAC,CAAA;QACjB,UAAU,CAAC,MAAM,CAAC,CAAA;QAClB,cAAc,CAAC,MAAM,CAAC,CAAA;IACxB,CAAC,CAAC,CAAA;AACJ,CAAC,CAAA"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { TestSetup } from '../index.js';
|
|
2
|
+
import type { StreamMuxerFactory } from '@libp2p/interface/stream-muxer';
|
|
3
|
+
declare const _default: (common: TestSetup<StreamMuxerFactory>) => void;
|
|
4
|
+
export default _default;
|
|
5
|
+
//# sourceMappingURL=mega-stress-test.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mega-stress-test.d.ts","sourceRoot":"","sources":["../../../src/stream-muxer/mega-stress-test.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AAC5C,OAAO,KAAK,EAAe,kBAAkB,EAAmB,MAAM,gCAAgC,CAAA;iCAE9E,UAAU,kBAAkB,CAAC,KAAG,IAAI;AAA5D,wBASC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import spawn from './spawner.js';
|
|
2
|
+
export default (common) => {
|
|
3
|
+
const createMuxer = async (init) => {
|
|
4
|
+
const factory = await common.setup();
|
|
5
|
+
return factory.createStreamMuxer(init);
|
|
6
|
+
};
|
|
7
|
+
describe.skip('mega stress test', function () {
|
|
8
|
+
it('10,000 streams with 10,000 msg', async () => { await spawn(createMuxer, 10000, 10000, 5000); });
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
//# sourceMappingURL=mega-stress-test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mega-stress-test.js","sourceRoot":"","sources":["../../../src/stream-muxer/mega-stress-test.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,cAAc,CAAA;AAIhC,eAAe,CAAC,MAAqC,EAAQ,EAAE;IAC7D,MAAM,WAAW,GAAG,KAAK,EAAE,IAAsB,EAAwB,EAAE;QACzE,MAAM,OAAO,GAAG,MAAM,MAAM,CAAC,KAAK,EAAE,CAAA;QACpC,OAAO,OAAO,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAA;IACxC,CAAC,CAAA;IAED,QAAQ,CAAC,IAAI,CAAC,kBAAkB,EAAE;QAChC,EAAE,CAAC,gCAAgC,EAAE,KAAK,IAAI,EAAE,GAAG,MAAM,KAAK,CAAC,WAAW,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;IACpG,CAAC,CAAC,CAAA;AACJ,CAAC,CAAA"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { StreamMuxer, StreamMuxerInit } from '@libp2p/interface/stream-muxer';
|
|
2
|
+
declare const _default: (createMuxer: (init?: StreamMuxerInit) => Promise<StreamMuxer>, nStreams: number, nMsg: number, limit?: number) => Promise<void>;
|
|
3
|
+
export default _default;
|
|
4
|
+
//# sourceMappingURL=spawner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spawner.d.ts","sourceRoot":"","sources":["../../../src/stream-muxer/spawner.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAA;8CAEvC,eAAe,KAAK,QAAQ,WAAW,CAAC,YAAY,MAAM,QAAQ,MAAM,UAAU,MAAM,KAAG,QAAQ,IAAI,CAAC;AAAnJ,wBA4CC"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { expect } from 'aegir/chai';
|
|
2
|
+
import all from 'it-all';
|
|
3
|
+
import drain from 'it-drain';
|
|
4
|
+
import { duplexPair } from 'it-pair/duplex';
|
|
5
|
+
import { pipe } from 'it-pipe';
|
|
6
|
+
import pLimit from 'p-limit';
|
|
7
|
+
import { Uint8ArrayList } from 'uint8arraylist';
|
|
8
|
+
import { fromString as uint8ArrayFromString } from 'uint8arrays/from-string';
|
|
9
|
+
export default async (createMuxer, nStreams, nMsg, limit) => {
|
|
10
|
+
const [dialerSocket, listenerSocket] = duplexPair();
|
|
11
|
+
const msg = new Uint8ArrayList(uint8ArrayFromString('simple msg'));
|
|
12
|
+
const listener = await createMuxer({
|
|
13
|
+
direction: 'inbound',
|
|
14
|
+
onIncomingStream: (stream) => {
|
|
15
|
+
void pipe(stream, drain).then(async () => {
|
|
16
|
+
await stream.close();
|
|
17
|
+
})
|
|
18
|
+
.catch(err => { stream.abort(err); });
|
|
19
|
+
}
|
|
20
|
+
});
|
|
21
|
+
const dialer = await createMuxer({ direction: 'outbound' });
|
|
22
|
+
void pipe(listenerSocket, listener, listenerSocket);
|
|
23
|
+
void pipe(dialerSocket, dialer, dialerSocket);
|
|
24
|
+
const spawnStream = async () => {
|
|
25
|
+
const stream = await dialer.newStream();
|
|
26
|
+
expect(stream).to.exist; // eslint-disable-line
|
|
27
|
+
const res = await pipe((async function* () {
|
|
28
|
+
for (let i = 0; i < nMsg; i++) {
|
|
29
|
+
yield msg;
|
|
30
|
+
}
|
|
31
|
+
}()), stream, async (source) => all(source));
|
|
32
|
+
expect(res).to.be.eql([]);
|
|
33
|
+
};
|
|
34
|
+
const limiter = pLimit(limit ?? Infinity);
|
|
35
|
+
await Promise.all(Array.from(Array(nStreams), async () => { await limiter(async () => { await spawnStream(); }); }));
|
|
36
|
+
};
|
|
37
|
+
//# sourceMappingURL=spawner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spawner.js","sourceRoot":"","sources":["../../../src/stream-muxer/spawner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,YAAY,CAAA;AACnC,OAAO,GAAG,MAAM,QAAQ,CAAA;AACxB,OAAO,KAAK,MAAM,UAAU,CAAA;AAC5B,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAA;AAC3C,OAAO,EAAE,IAAI,EAAE,MAAM,SAAS,CAAA;AAC9B,OAAO,MAAM,MAAM,SAAS,CAAA;AAC5B,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,UAAU,IAAI,oBAAoB,EAAE,MAAM,yBAAyB,CAAA;AAG5E,eAAe,KAAK,EAAE,WAA6D,EAAE,QAAgB,EAAE,IAAY,EAAE,KAAc,EAAiB,EAAE;IACpJ,MAAM,CAAC,YAAY,EAAE,cAAc,CAAC,GAAG,UAAU,EAAc,CAAA;IAE/D,MAAM,GAAG,GAAG,IAAI,cAAc,CAAC,oBAAoB,CAAC,YAAY,CAAC,CAAC,CAAA;IAElE,MAAM,QAAQ,GAAG,MAAM,WAAW,CAAC;QACjC,SAAS,EAAE,SAAS;QACpB,gBAAgB,EAAE,CAAC,MAAM,EAAE,EAAE;YAC3B,KAAK,IAAI,CACP,MAAM,EACN,KAAK,CACN,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE;gBAChB,MAAM,MAAM,CAAC,KAAK,EAAE,CAAA;YACtB,CAAC,CAAC;iBACC,KAAK,CAAC,GAAG,CAAC,EAAE,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;QACxC,CAAC;KACF,CAAC,CAAA;IACF,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,EAAE,SAAS,EAAE,UAAU,EAAE,CAAC,CAAA;IAE3D,KAAK,IAAI,CAAC,cAAc,EAAE,QAAQ,EAAE,cAAc,CAAC,CAAA;IACnD,KAAK,IAAI,CAAC,YAAY,EAAE,MAAM,EAAE,YAAY,CAAC,CAAA;IAE7C,MAAM,WAAW,GAAG,KAAK,IAAmB,EAAE;QAC5C,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,SAAS,EAAE,CAAA;QACvC,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,KAAK,CAAA,CAAC,sBAAsB;QAE9C,MAAM,GAAG,GAAG,MAAM,IAAI,CACpB,CAAC,KAAK,SAAU,CAAC;YACf,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;gBAC7B,MAAM,GAAG,CAAA;aACV;QACH,CAAC,EAAE,CAAC,EACJ,MAAM,EACN,KAAK,EAAE,MAAM,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,CAC9B,CAAA;QAED,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;IAC3B,CAAC,CAAA;IAED,MAAM,OAAO,GAAG,MAAM,CAAC,KAAK,IAAI,QAAQ,CAAC,CAAA;IAEzC,MAAM,OAAO,CAAC,GAAG,CACf,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,KAAK,IAAI,EAAE,GAAG,MAAM,OAAO,CAAC,KAAK,IAAI,EAAE,GAAG,MAAM,WAAW,EAAE,CAAA,CAAC,CAAC,CAAC,CAAA,CAAC,CAAC,CAAC,CAChG,CAAA;AACH,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stress-test.d.ts","sourceRoot":"","sources":["../../../src/stream-muxer/stress-test.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AAC5C,OAAO,KAAK,EAAE,kBAAkB,EAAgC,MAAM,gCAAgC,CAAA;iCAE9E,UAAU,kBAAkB,CAAC,KAAG,IAAI;AAA5D,wBAsBC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import spawn from './spawner.js';
|
|
2
|
+
export default (common) => {
|
|
3
|
+
const createMuxer = async (init) => {
|
|
4
|
+
const factory = await common.setup();
|
|
5
|
+
return factory.createStreamMuxer(init);
|
|
6
|
+
};
|
|
7
|
+
describe('stress test', function () {
|
|
8
|
+
this.timeout(1600000);
|
|
9
|
+
it('1 stream with 1 msg', async () => { await spawn(createMuxer, 1, 1); });
|
|
10
|
+
it('1 stream with 10 msg', async () => { await spawn(createMuxer, 1, 10); });
|
|
11
|
+
it('1 stream with 100 msg', async () => { await spawn(createMuxer, 1, 100); });
|
|
12
|
+
it('10 streams with 1 msg', async () => { await spawn(createMuxer, 10, 1); });
|
|
13
|
+
it('10 streams with 10 msg', async () => { await spawn(createMuxer, 10, 10); });
|
|
14
|
+
it('10 streams with 100 msg', async () => { await spawn(createMuxer, 10, 100); });
|
|
15
|
+
it('100 streams with 1 msg', async () => { await spawn(createMuxer, 100, 1); });
|
|
16
|
+
it('100 streams with 10 msg', async () => { await spawn(createMuxer, 100, 10); });
|
|
17
|
+
it('100 streams with 100 msg', async () => { await spawn(createMuxer, 100, 100); });
|
|
18
|
+
it('1000 streams with 1 msg', async () => { await spawn(createMuxer, 1000, 1); });
|
|
19
|
+
it('1000 streams with 10 msg', async () => { await spawn(createMuxer, 1000, 10); });
|
|
20
|
+
it('1000 streams with 100 msg', async () => { await spawn(createMuxer, 1000, 100); });
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
//# sourceMappingURL=stress-test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stress-test.js","sourceRoot":"","sources":["../../../src/stream-muxer/stress-test.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,cAAc,CAAA;AAIhC,eAAe,CAAC,MAAqC,EAAQ,EAAE;IAC7D,MAAM,WAAW,GAAG,KAAK,EAAE,IAAsB,EAAwB,EAAE;QACzE,MAAM,OAAO,GAAG,MAAM,MAAM,CAAC,KAAK,EAAE,CAAA;QACpC,OAAO,OAAO,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAA;IACxC,CAAC,CAAA;IAED,QAAQ,CAAC,aAAa,EAAE;QACtB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAA;QAErB,EAAE,CAAC,qBAAqB,EAAE,KAAK,IAAI,EAAE,GAAG,MAAM,KAAK,CAAC,WAAW,EAAE,CAAC,EAAE,CAAC,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;QACzE,EAAE,CAAC,sBAAsB,EAAE,KAAK,IAAI,EAAE,GAAG,MAAM,KAAK,CAAC,WAAW,EAAE,CAAC,EAAE,EAAE,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;QAC3E,EAAE,CAAC,uBAAuB,EAAE,KAAK,IAAI,EAAE,GAAG,MAAM,KAAK,CAAC,WAAW,EAAE,CAAC,EAAE,GAAG,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;QAC7E,EAAE,CAAC,uBAAuB,EAAE,KAAK,IAAI,EAAE,GAAG,MAAM,KAAK,CAAC,WAAW,EAAE,EAAE,EAAE,CAAC,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;QAC5E,EAAE,CAAC,wBAAwB,EAAE,KAAK,IAAI,EAAE,GAAG,MAAM,KAAK,CAAC,WAAW,EAAE,EAAE,EAAE,EAAE,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;QAC9E,EAAE,CAAC,yBAAyB,EAAE,KAAK,IAAI,EAAE,GAAG,MAAM,KAAK,CAAC,WAAW,EAAE,EAAE,EAAE,GAAG,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;QAChF,EAAE,CAAC,wBAAwB,EAAE,KAAK,IAAI,EAAE,GAAG,MAAM,KAAK,CAAC,WAAW,EAAE,GAAG,EAAE,CAAC,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;QAC9E,EAAE,CAAC,yBAAyB,EAAE,KAAK,IAAI,EAAE,GAAG,MAAM,KAAK,CAAC,WAAW,EAAE,GAAG,EAAE,EAAE,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;QAChF,EAAE,CAAC,0BAA0B,EAAE,KAAK,IAAI,EAAE,GAAG,MAAM,KAAK,CAAC,WAAW,EAAE,GAAG,EAAE,GAAG,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;QAClF,EAAE,CAAC,yBAAyB,EAAE,KAAK,IAAI,EAAE,GAAG,MAAM,KAAK,CAAC,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;QAChF,EAAE,CAAC,0BAA0B,EAAE,KAAK,IAAI,EAAE,GAAG,MAAM,KAAK,CAAC,WAAW,EAAE,IAAI,EAAE,EAAE,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;QAClF,EAAE,CAAC,2BAA2B,EAAE,KAAK,IAAI,EAAE,GAAG,MAAM,KAAK,CAAC,WAAW,EAAE,IAAI,EAAE,GAAG,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;IACtF,CAAC,CAAC,CAAA;AACJ,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dial-test.d.ts","sourceRoot":"","sources":["../../../src/transport/dial-test.ts"],"names":[],"mappings":"AAUA,OAAO,KAAK,EAAE,qBAAqB,EAAa,MAAM,YAAY,CAAA;AAClE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;iCAKpB,UAAU,qBAAqB,CAAC,KAAG,IAAI;AAA/D,wBA2GC"}
|