@libp2p/interface-compliance-tests 2.0.3 → 3.0.0

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.
Files changed (192) hide show
  1. package/README.md +19 -11
  2. package/dist/src/{utils/is-valid-tick.d.ts → is-valid-tick.d.ts} +0 -0
  3. package/dist/src/is-valid-tick.d.ts.map +1 -0
  4. package/dist/src/{utils/is-valid-tick.js → is-valid-tick.js} +0 -0
  5. package/dist/src/is-valid-tick.js.map +1 -0
  6. package/dist/src/{utils/peers.d.ts → peers.d.ts} +0 -0
  7. package/dist/src/peers.d.ts.map +1 -0
  8. package/dist/src/{utils/peers.js → peers.js} +0 -0
  9. package/dist/src/peers.js.map +1 -0
  10. package/package.json +11 -89
  11. package/src/{utils/is-valid-tick.ts → is-valid-tick.ts} +0 -0
  12. package/src/{utils/peers.ts → peers.ts} +0 -0
  13. package/dist/src/connection/connection.d.ts +0 -5
  14. package/dist/src/connection/connection.d.ts.map +0 -1
  15. package/dist/src/connection/connection.js +0 -146
  16. package/dist/src/connection/connection.js.map +0 -1
  17. package/dist/src/connection/index.d.ts +0 -5
  18. package/dist/src/connection/index.d.ts.map +0 -1
  19. package/dist/src/connection/index.js +0 -5
  20. package/dist/src/connection/index.js.map +0 -1
  21. package/dist/src/connection-encrypter/index.d.ts +0 -5
  22. package/dist/src/connection-encrypter/index.d.ts.map +0 -1
  23. package/dist/src/connection-encrypter/index.js +0 -77
  24. package/dist/src/connection-encrypter/index.js.map +0 -1
  25. package/dist/src/connection-encrypter/utils/index.d.ts +0 -3
  26. package/dist/src/connection-encrypter/utils/index.d.ts.map +0 -1
  27. package/dist/src/connection-encrypter/utils/index.js +0 -18
  28. package/dist/src/connection-encrypter/utils/index.js.map +0 -1
  29. package/dist/src/mocks/connection-encrypter.d.ts +0 -3
  30. package/dist/src/mocks/connection-encrypter.d.ts.map +0 -1
  31. package/dist/src/mocks/connection-encrypter.js +0 -93
  32. package/dist/src/mocks/connection-encrypter.js.map +0 -1
  33. package/dist/src/mocks/connection-gater.d.ts +0 -12
  34. package/dist/src/mocks/connection-gater.d.ts.map +0 -1
  35. package/dist/src/mocks/connection-gater.js +0 -14
  36. package/dist/src/mocks/connection-gater.js.map +0 -1
  37. package/dist/src/mocks/connection-manager.d.ts +0 -28
  38. package/dist/src/mocks/connection-manager.d.ts.map +0 -1
  39. package/dist/src/mocks/connection-manager.js +0 -107
  40. package/dist/src/mocks/connection-manager.js.map +0 -1
  41. package/dist/src/mocks/connection.d.ts +0 -18
  42. package/dist/src/mocks/connection.d.ts.map +0 -1
  43. package/dist/src/mocks/connection.js +0 -138
  44. package/dist/src/mocks/connection.js.map +0 -1
  45. package/dist/src/mocks/duplex.d.ts +0 -3
  46. package/dist/src/mocks/duplex.d.ts.map +0 -1
  47. package/dist/src/mocks/duplex.js +0 -7
  48. package/dist/src/mocks/duplex.js.map +0 -1
  49. package/dist/src/mocks/index.d.ts +0 -10
  50. package/dist/src/mocks/index.d.ts.map +0 -1
  51. package/dist/src/mocks/index.js +0 -9
  52. package/dist/src/mocks/index.js.map +0 -1
  53. package/dist/src/mocks/multiaddr-connection.d.ts +0 -17
  54. package/dist/src/mocks/multiaddr-connection.d.ts.map +0 -1
  55. package/dist/src/mocks/multiaddr-connection.js +0 -51
  56. package/dist/src/mocks/multiaddr-connection.js.map +0 -1
  57. package/dist/src/mocks/muxer.d.ts +0 -9
  58. package/dist/src/mocks/muxer.d.ts.map +0 -1
  59. package/dist/src/mocks/muxer.js +0 -302
  60. package/dist/src/mocks/muxer.js.map +0 -1
  61. package/dist/src/mocks/registrar.d.ts +0 -18
  62. package/dist/src/mocks/registrar.d.ts.map +0 -1
  63. package/dist/src/mocks/registrar.js +0 -73
  64. package/dist/src/mocks/registrar.js.map +0 -1
  65. package/dist/src/mocks/upgrader.d.ts +0 -15
  66. package/dist/src/mocks/upgrader.d.ts.map +0 -1
  67. package/dist/src/mocks/upgrader.js +0 -33
  68. package/dist/src/mocks/upgrader.js.map +0 -1
  69. package/dist/src/peer-discovery/index.d.ts +0 -6
  70. package/dist/src/peer-discovery/index.d.ts.map +0 -1
  71. package/dist/src/peer-discovery/index.js +0 -64
  72. package/dist/src/peer-discovery/index.js.map +0 -1
  73. package/dist/src/pubsub/api.d.ts +0 -6
  74. package/dist/src/pubsub/api.d.ts.map +0 -1
  75. package/dist/src/pubsub/api.js +0 -87
  76. package/dist/src/pubsub/api.js.map +0 -1
  77. package/dist/src/pubsub/connection-handlers.d.ts +0 -6
  78. package/dist/src/pubsub/connection-handlers.d.ts.map +0 -1
  79. package/dist/src/pubsub/connection-handlers.js +0 -329
  80. package/dist/src/pubsub/connection-handlers.js.map +0 -1
  81. package/dist/src/pubsub/emit-self.d.ts +0 -6
  82. package/dist/src/pubsub/emit-self.d.ts.map +0 -1
  83. package/dist/src/pubsub/emit-self.js +0 -86
  84. package/dist/src/pubsub/emit-self.js.map +0 -1
  85. package/dist/src/pubsub/index.d.ts +0 -10
  86. package/dist/src/pubsub/index.d.ts.map +0 -1
  87. package/dist/src/pubsub/index.js +0 -17
  88. package/dist/src/pubsub/index.js.map +0 -1
  89. package/dist/src/pubsub/messages.d.ts +0 -6
  90. package/dist/src/pubsub/messages.d.ts.map +0 -1
  91. package/dist/src/pubsub/messages.js +0 -46
  92. package/dist/src/pubsub/messages.js.map +0 -1
  93. package/dist/src/pubsub/multiple-nodes.d.ts +0 -6
  94. package/dist/src/pubsub/multiple-nodes.d.ts.map +0 -1
  95. package/dist/src/pubsub/multiple-nodes.js +0 -350
  96. package/dist/src/pubsub/multiple-nodes.js.map +0 -1
  97. package/dist/src/pubsub/two-nodes.d.ts +0 -6
  98. package/dist/src/pubsub/two-nodes.d.ts.map +0 -1
  99. package/dist/src/pubsub/two-nodes.js +0 -185
  100. package/dist/src/pubsub/two-nodes.js.map +0 -1
  101. package/dist/src/pubsub/utils.d.ts +0 -6
  102. package/dist/src/pubsub/utils.d.ts.map +0 -1
  103. package/dist/src/pubsub/utils.js +0 -22
  104. package/dist/src/pubsub/utils.js.map +0 -1
  105. package/dist/src/record/index.d.ts +0 -5
  106. package/dist/src/record/index.d.ts.map +0 -1
  107. package/dist/src/record/index.js +0 -25
  108. package/dist/src/record/index.js.map +0 -1
  109. package/dist/src/stream-muxer/base-test.d.ts +0 -5
  110. package/dist/src/stream-muxer/base-test.d.ts.map +0 -1
  111. package/dist/src/stream-muxer/base-test.js +0 -147
  112. package/dist/src/stream-muxer/base-test.js.map +0 -1
  113. package/dist/src/stream-muxer/close-test.d.ts +0 -5
  114. package/dist/src/stream-muxer/close-test.d.ts.map +0 -1
  115. package/dist/src/stream-muxer/close-test.js +0 -180
  116. package/dist/src/stream-muxer/close-test.js.map +0 -1
  117. package/dist/src/stream-muxer/index.d.ts +0 -5
  118. package/dist/src/stream-muxer/index.d.ts.map +0 -1
  119. package/dist/src/stream-muxer/index.js +0 -13
  120. package/dist/src/stream-muxer/index.js.map +0 -1
  121. package/dist/src/stream-muxer/mega-stress-test.d.ts +0 -5
  122. package/dist/src/stream-muxer/mega-stress-test.d.ts.map +0 -1
  123. package/dist/src/stream-muxer/mega-stress-test.js +0 -12
  124. package/dist/src/stream-muxer/mega-stress-test.js.map +0 -1
  125. package/dist/src/stream-muxer/spawner.d.ts +0 -4
  126. package/dist/src/stream-muxer/spawner.d.ts.map +0 -1
  127. package/dist/src/stream-muxer/spawner.js +0 -34
  128. package/dist/src/stream-muxer/spawner.js.map +0 -1
  129. package/dist/src/stream-muxer/stress-test.d.ts +0 -5
  130. package/dist/src/stream-muxer/stress-test.d.ts.map +0 -1
  131. package/dist/src/stream-muxer/stress-test.js +0 -26
  132. package/dist/src/stream-muxer/stress-test.js.map +0 -1
  133. package/dist/src/topology/topology.d.ts +0 -5
  134. package/dist/src/topology/topology.d.ts.map +0 -1
  135. package/dist/src/topology/topology.js +0 -20
  136. package/dist/src/topology/topology.js.map +0 -1
  137. package/dist/src/transport/dial-test.d.ts +0 -5
  138. package/dist/src/transport/dial-test.d.ts.map +0 -1
  139. package/dist/src/transport/dial-test.js +0 -97
  140. package/dist/src/transport/dial-test.js.map +0 -1
  141. package/dist/src/transport/filter-test.d.ts +0 -5
  142. package/dist/src/transport/filter-test.d.ts.map +0 -1
  143. package/dist/src/transport/filter-test.js +0 -18
  144. package/dist/src/transport/filter-test.js.map +0 -1
  145. package/dist/src/transport/index.d.ts +0 -15
  146. package/dist/src/transport/index.d.ts.map +0 -1
  147. package/dist/src/transport/index.js +0 -11
  148. package/dist/src/transport/index.js.map +0 -1
  149. package/dist/src/transport/listen-test.d.ts +0 -5
  150. package/dist/src/transport/listen-test.d.ts.map +0 -1
  151. package/dist/src/transport/listen-test.js +0 -152
  152. package/dist/src/transport/listen-test.js.map +0 -1
  153. package/dist/src/utils/is-valid-tick.d.ts.map +0 -1
  154. package/dist/src/utils/is-valid-tick.js.map +0 -1
  155. package/dist/src/utils/peers.d.ts.map +0 -1
  156. package/dist/src/utils/peers.js.map +0 -1
  157. package/src/connection/README.md +0 -256
  158. package/src/connection/connection.ts +0 -176
  159. package/src/connection/index.ts +0 -7
  160. package/src/connection-encrypter/index.ts +0 -104
  161. package/src/connection-encrypter/utils/index.ts +0 -23
  162. package/src/mocks/connection-encrypter.ts +0 -110
  163. package/src/mocks/connection-gater.ts +0 -14
  164. package/src/mocks/connection-manager.ts +0 -141
  165. package/src/mocks/connection.ts +0 -205
  166. package/src/mocks/duplex.ts +0 -8
  167. package/src/mocks/index.ts +0 -10
  168. package/src/mocks/multiaddr-connection.ts +0 -66
  169. package/src/mocks/muxer.ts +0 -424
  170. package/src/mocks/registrar.ts +0 -96
  171. package/src/mocks/upgrader.ts +0 -46
  172. package/src/peer-discovery/index.ts +0 -89
  173. package/src/pubsub/api.ts +0 -115
  174. package/src/pubsub/connection-handlers.ts +0 -413
  175. package/src/pubsub/emit-self.ts +0 -105
  176. package/src/pubsub/index.ts +0 -25
  177. package/src/pubsub/messages.ts +0 -58
  178. package/src/pubsub/multiple-nodes.ts +0 -429
  179. package/src/pubsub/two-nodes.ts +0 -235
  180. package/src/pubsub/utils.ts +0 -28
  181. package/src/record/index.ts +0 -32
  182. package/src/stream-muxer/base-test.ts +0 -190
  183. package/src/stream-muxer/close-test.ts +0 -227
  184. package/src/stream-muxer/index.ts +0 -15
  185. package/src/stream-muxer/mega-stress-test.ts +0 -15
  186. package/src/stream-muxer/spawner.ts +0 -52
  187. package/src/stream-muxer/stress-test.ts +0 -29
  188. package/src/topology/topology.ts +0 -25
  189. package/src/transport/dial-test.ts +0 -123
  190. package/src/transport/filter-test.ts +0 -25
  191. package/src/transport/index.ts +0 -25
  192. package/src/transport/listen-test.ts +0 -191
@@ -1,32 +0,0 @@
1
- import { expect } from 'aegir/chai'
2
- import type { TestSetup } from '../index.js'
3
- import type { Record } from '@libp2p/interfaces/record'
4
-
5
- export default (test: TestSetup<Record>) => {
6
- describe('record', () => {
7
- let record: Record
8
-
9
- beforeEach(async () => {
10
- record = await test.setup()
11
- })
12
-
13
- afterEach(async () => {
14
- await test.teardown()
15
- })
16
-
17
- it('has domain and codec', () => {
18
- expect(record.domain).to.exist()
19
- expect(record.codec).to.exist()
20
- })
21
-
22
- it('is able to marshal', () => {
23
- const rawData = record.marshal()
24
- expect(rawData).to.be.an.instanceof(Uint8Array)
25
- })
26
-
27
- it('is able to compare two records', () => {
28
- const equals = record.equals(record)
29
- expect(equals).to.eql(true)
30
- })
31
- })
32
- }
@@ -1,190 +0,0 @@
1
- import { expect } from 'aegir/chai'
2
- import { duplexPair } from 'it-pair/duplex'
3
- import { pipe } from 'it-pipe'
4
- import drain from 'it-drain'
5
- import map from 'it-map'
6
- import all from 'it-all'
7
- import defer from 'p-defer'
8
- import { toString as uint8ArrayToString } from 'uint8arrays/to-string'
9
- import { fromString as uint8ArrayFromString } from 'uint8arrays/from-string'
10
- import { isValidTick } from '../utils/is-valid-tick.js'
11
- import type { DeferredPromise } from 'p-defer'
12
- import type { TestSetup } from '../index.js'
13
- import type { Stream } from '@libp2p/interfaces/connection'
14
- import type { StreamMuxerFactory } from '@libp2p/interfaces/stream-muxer'
15
- import type { Source, Duplex } from 'it-stream-types'
16
- import { Components } from '@libp2p/interfaces/components'
17
-
18
- async function drainAndClose (stream: Duplex<Uint8Array>) {
19
- return await pipe([], stream, drain)
20
- }
21
-
22
- export default (common: TestSetup<StreamMuxerFactory>) => {
23
- describe('base', () => {
24
- it('Open a stream from the dialer', async () => {
25
- const p = duplexPair<Uint8Array>()
26
- const dialerFactory = await common.setup()
27
- const dialer = dialerFactory.createStreamMuxer(new Components())
28
- const onStreamPromise: DeferredPromise<Stream> = defer()
29
- const onStreamEndPromise: DeferredPromise<Stream> = defer()
30
-
31
- const listenerFactory = await common.setup()
32
- const listener = listenerFactory.createStreamMuxer(new Components(), {
33
- onIncomingStream: (stream) => {
34
- onStreamPromise.resolve(stream)
35
- },
36
- onStreamEnd: (stream) => {
37
- onStreamEndPromise.resolve(stream)
38
- }
39
- })
40
-
41
- void pipe(p[0], dialer, p[0])
42
- void pipe(p[1], listener, p[1])
43
-
44
- const conn = dialer.newStream()
45
- expect(dialer.streams).to.include(conn)
46
- expect(isValidTick(conn.timeline.open)).to.equal(true)
47
-
48
- void drainAndClose(conn)
49
-
50
- const stream = await onStreamPromise.promise
51
- expect(isValidTick(stream.timeline.open)).to.equal(true)
52
- // Make sure the stream is being tracked
53
- expect(listener.streams).to.include(stream)
54
-
55
- void drainAndClose(stream)
56
-
57
- // Make sure stream is closed properly
58
- const endedStream = await onStreamEndPromise.promise
59
- expect(listener.streams).to.not.include(endedStream)
60
-
61
- if (endedStream.timeline.close == null) {
62
- throw new Error('timeline had no close time')
63
- }
64
-
65
- // Make sure the stream is removed from tracking
66
- expect(isValidTick(endedStream.timeline.close)).to.equal(true)
67
-
68
- await drainAndClose(dialer)
69
- await drainAndClose(listener)
70
-
71
- // ensure we have no streams left
72
- expect(dialer.streams).to.have.length(0)
73
- expect(listener.streams).to.have.length(0)
74
- })
75
-
76
- it('Open a stream from the listener', async () => {
77
- const p = duplexPair<Uint8Array>()
78
- const onStreamPromise: DeferredPromise<Stream> = defer()
79
- const dialerFactory = await common.setup()
80
- const dialer = dialerFactory.createStreamMuxer(new Components(), {
81
- onIncomingStream: (stream: Stream) => {
82
- onStreamPromise.resolve(stream)
83
- }
84
- })
85
-
86
- const listenerFactory = await common.setup()
87
- const listener = listenerFactory.createStreamMuxer(new Components())
88
-
89
- void pipe(p[0], dialer, p[0])
90
- void pipe(p[1], listener, p[1])
91
-
92
- const conn = listener.newStream()
93
-
94
- void drainAndClose(conn)
95
-
96
- const stream = await onStreamPromise.promise
97
- expect(isValidTick(stream.timeline.open)).to.equal(true)
98
- expect(listener.streams).to.include(conn)
99
- expect(isValidTick(conn.timeline.open)).to.equal(true)
100
- void drainAndClose(stream)
101
-
102
- await drainAndClose(dialer)
103
- await drainAndClose(listener)
104
- })
105
-
106
- it('Open a stream on both sides', async () => {
107
- const p = duplexPair<Uint8Array>()
108
- const onDialerStreamPromise: DeferredPromise<Stream> = defer()
109
- const onListenerStreamPromise: DeferredPromise<Stream> = defer()
110
- const dialerFactory = await common.setup()
111
- const dialer = dialerFactory.createStreamMuxer(new Components(), {
112
- onIncomingStream: (stream) => {
113
- onDialerStreamPromise.resolve(stream)
114
- }
115
- })
116
-
117
- const listenerFactory = await common.setup()
118
- const listener = listenerFactory.createStreamMuxer(new Components(), {
119
- onIncomingStream: (stream) => {
120
- onListenerStreamPromise.resolve(stream)
121
- }
122
- })
123
-
124
- void pipe(p[0], dialer, p[0])
125
- void pipe(p[1], listener, p[1])
126
-
127
- const dialerInitiatorStream = dialer.newStream()
128
- const listenerInitiatorStream = listener.newStream()
129
-
130
- await Promise.all([
131
- drainAndClose(dialerInitiatorStream),
132
- drainAndClose(listenerInitiatorStream),
133
- onDialerStreamPromise.promise.then(async stream => await drainAndClose(stream)),
134
- onListenerStreamPromise.promise.then(async stream => await drainAndClose(stream))
135
- ])
136
-
137
- await Promise.all([
138
- drainAndClose(dialer),
139
- drainAndClose(listener)
140
- ])
141
- })
142
-
143
- it('Open a stream on one side, write, open a stream on the other side', async () => {
144
- const toString = (source: Source<Uint8Array>) => map(source, (u) => uint8ArrayToString(u))
145
- const p = duplexPair<Uint8Array>()
146
- const onDialerStreamPromise: DeferredPromise<Stream> = defer()
147
- const onListenerStreamPromise: DeferredPromise<Stream> = defer()
148
- const dialerFactory = await common.setup()
149
- const dialer = dialerFactory.createStreamMuxer(new Components(), {
150
- onIncomingStream: (stream) => {
151
- onDialerStreamPromise.resolve(stream)
152
- }
153
- })
154
- const listenerFactory = await common.setup()
155
- const listener = listenerFactory.createStreamMuxer(new Components(), {
156
- onIncomingStream: (stream) => {
157
- onListenerStreamPromise.resolve(stream)
158
- }
159
- })
160
-
161
- void pipe(p[0], dialer, p[0])
162
- void pipe(p[1], listener, p[1])
163
-
164
- const dialerConn = dialer.newStream()
165
- const listenerConn = listener.newStream()
166
-
167
- void pipe([uint8ArrayFromString('hey')], dialerConn)
168
- void pipe([uint8ArrayFromString('hello')], listenerConn)
169
-
170
- const [
171
- dialerStream,
172
- listenerStream
173
- ] = await Promise.all([
174
- onDialerStreamPromise.promise,
175
- onListenerStreamPromise.promise
176
- ])
177
-
178
- const [
179
- listenerChunks,
180
- dialerChunks
181
- ] = await Promise.all([
182
- pipe(listenerStream, toString, async (source) => await all(source)),
183
- pipe(dialerStream, toString, async (source) => await all(source))
184
- ])
185
-
186
- expect(listenerChunks).to.be.eql(['hey'])
187
- expect(dialerChunks).to.be.eql(['hello'])
188
- })
189
- })
190
- }
@@ -1,227 +0,0 @@
1
- /* eslint max-nested-callbacks: ["error", 8] */
2
- import { pipe } from 'it-pipe'
3
- import { duplexPair } from 'it-pair/duplex'
4
- import { abortableSource } from 'abortable-iterator'
5
- import { fromString as uint8ArrayFromString } from 'uint8arrays/from-string'
6
- import drain from 'it-drain'
7
- import { expect } from 'aegir/chai'
8
- import delay from 'delay'
9
- import type { TestSetup } from '../index.js'
10
- import type { StreamMuxerFactory } from '@libp2p/interfaces/stream-muxer'
11
- import { Components } from '@libp2p/interfaces/components'
12
- import pDefer from 'p-defer'
13
- import all from 'it-all'
14
-
15
- function randomBuffer () {
16
- return uint8ArrayFromString(Math.random().toString())
17
- }
18
-
19
- const infiniteRandom = {
20
- [Symbol.asyncIterator]: async function * () {
21
- while (true) {
22
- yield randomBuffer()
23
- await delay(50)
24
- }
25
- }
26
- }
27
-
28
- export default (common: TestSetup<StreamMuxerFactory>) => {
29
- describe('close', () => {
30
- it('closing underlying socket closes streams', async () => {
31
- let openedStreams = 0
32
- const expectedStreams = 5
33
- const dialerFactory = await common.setup()
34
- const dialer = dialerFactory.createStreamMuxer(new Components())
35
-
36
- // Listener is echo server :)
37
- const listenerFactory = await common.setup()
38
- const listener = listenerFactory.createStreamMuxer(new Components(), {
39
- onIncomingStream: (stream) => {
40
- openedStreams++
41
- void pipe(stream, stream)
42
- }
43
- })
44
-
45
- const p = duplexPair<Uint8Array>()
46
- void pipe(p[0], dialer, p[0])
47
- void pipe(p[1], listener, p[1])
48
-
49
- const streams = Array(expectedStreams).fill(0).map(() => dialer.newStream())
50
-
51
- void Promise.all(
52
- streams.map(async stream => {
53
- return await pipe(
54
- infiniteRandom,
55
- stream,
56
- drain
57
- )
58
- })
59
- )
60
-
61
- expect(dialer.streams).to.have.lengthOf(expectedStreams)
62
-
63
- // Pause, and then send some data and close the dialer
64
- await delay(50)
65
- await pipe([randomBuffer()], dialer, drain)
66
-
67
- expect(openedStreams).to.have.equal(expectedStreams)
68
- expect(dialer.streams).to.have.lengthOf(0)
69
- })
70
-
71
- it('closing one of the muxed streams doesn\'t close others', async () => {
72
- const p = duplexPair<Uint8Array>()
73
- const dialerFactory = await common.setup()
74
- const dialer = dialerFactory.createStreamMuxer(new Components())
75
-
76
- // Listener is echo server :)
77
- const listenerFactory = await common.setup()
78
- const listener = listenerFactory.createStreamMuxer(new Components(), {
79
- onIncomingStream: (stream) => {
80
- void pipe(stream, stream)
81
- }
82
- })
83
-
84
- void pipe(p[0], dialer, p[0])
85
- void pipe(p[1], listener, p[1])
86
-
87
- const stream = dialer.newStream()
88
- const streams = Array.from(Array(5), () => dialer.newStream())
89
- let closed = false
90
- const controllers: AbortController[] = []
91
-
92
- const streamResults = streams.map(async stream => {
93
- const controller = new AbortController()
94
- controllers.push(controller)
95
-
96
- try {
97
- const abortableRand = abortableSource(infiniteRandom, controller.signal, { abortCode: 'ERR_TEST_ABORT' })
98
- await pipe(abortableRand, stream, drain)
99
- } catch (err: any) {
100
- if (err.code !== 'ERR_TEST_ABORT') throw err
101
- }
102
-
103
- if (!closed) throw new Error('stream should not have ended yet!')
104
- })
105
-
106
- // Pause, and then send some data and close the first stream
107
- await delay(50)
108
- await pipe([randomBuffer()], stream, drain)
109
- closed = true
110
-
111
- // Abort all the other streams later
112
- await delay(50)
113
- controllers.forEach(c => c.abort())
114
-
115
- // These should now all resolve without error
116
- await Promise.all(streamResults)
117
- })
118
-
119
- it('can close a stream for writing', async () => {
120
- const deferred = pDefer<any>()
121
-
122
- const p = duplexPair<Uint8Array>()
123
- const dialerFactory = await common.setup()
124
- const dialer = dialerFactory.createStreamMuxer(new Components())
125
- const data = [randomBuffer(), randomBuffer()]
126
-
127
- const listenerFactory = await common.setup()
128
- const listener = listenerFactory.createStreamMuxer(new Components(), {
129
- onIncomingStream: (stream) => {
130
- void Promise.resolve().then(async () => {
131
- // Immediate close for write
132
- await stream.closeWrite()
133
-
134
- const results = await pipe(stream, async (source) => {
135
- const data = []
136
- for await (const chunk of source) {
137
- data.push(chunk.slice())
138
- }
139
- return data
140
- })
141
- expect(results).to.eql(data)
142
-
143
- try {
144
- await stream.sink([randomBuffer()])
145
- } catch (err) {
146
- deferred.resolve(err)
147
- }
148
-
149
- deferred.reject(new Error('should not support writing to closed writer'))
150
- })
151
- }
152
- })
153
-
154
- void pipe(p[0], dialer, p[0])
155
- void pipe(p[1], listener, p[1])
156
-
157
- const stream = dialer.newStream()
158
- await stream.sink(data)
159
-
160
- const err = await deferred.promise
161
- expect(err).to.have.property('message').that.matches(/stream closed for writing/)
162
- })
163
-
164
- it('can close a stream for reading', async () => {
165
- const deferred = pDefer<any>()
166
-
167
- const p = duplexPair<Uint8Array>()
168
- const dialerFactory = await common.setup()
169
- const dialer = dialerFactory.createStreamMuxer(new Components())
170
- const data = [randomBuffer(), randomBuffer()]
171
-
172
- const listenerFactory = await common.setup()
173
- const listener = listenerFactory.createStreamMuxer(new Components(), {
174
- onIncomingStream: (stream) => {
175
- void all(stream.source).then(deferred.resolve, deferred.reject)
176
- }
177
- })
178
-
179
- void pipe(p[0], dialer, p[0])
180
- void pipe(p[1], listener, p[1])
181
-
182
- const stream = dialer.newStream()
183
- await stream.closeRead()
184
-
185
- // Source should be done
186
- void Promise.resolve().then(async () => {
187
- // @ts-expect-error next is part of the iterable protocol
188
- expect(await stream.source.next()).to.have.property('done', true)
189
- await stream.sink(data)
190
- })
191
-
192
- const results = await deferred.promise
193
- expect(results).to.eql(data)
194
- })
195
-
196
- it('calls onStreamEnd for closed streams not previously written', async () => {
197
- const deferred = pDefer()
198
-
199
- const onStreamEnd = () => deferred.resolve()
200
- const dialerFactory = await common.setup()
201
- const dialer = dialerFactory.createStreamMuxer(new Components(), {
202
- onStreamEnd
203
- })
204
-
205
- const stream = await dialer.newStream()
206
-
207
- await stream.close()
208
- await deferred.promise
209
- })
210
-
211
- it('calls onStreamEnd for read and write closed streams not previously written', async () => {
212
- const deferred = pDefer()
213
-
214
- const onStreamEnd = () => deferred.resolve()
215
- const dialerFactory = await common.setup()
216
- const dialer = dialerFactory.createStreamMuxer(new Components(), {
217
- onStreamEnd
218
- })
219
-
220
- const stream = await dialer.newStream()
221
-
222
- await stream.closeWrite()
223
- await stream.closeRead()
224
- await deferred.promise
225
- })
226
- })
227
- }
@@ -1,15 +0,0 @@
1
- import baseTest from './base-test.js'
2
- import closeTest from './close-test.js'
3
- import stressTest from './stress-test.js'
4
- import megaStressTest from './mega-stress-test.js'
5
- import type { TestSetup } from '../index.js'
6
- import type { StreamMuxerFactory } from '@libp2p/interfaces/stream-muxer'
7
-
8
- export default (common: TestSetup<StreamMuxerFactory>) => {
9
- describe('interface-stream-muxer', () => {
10
- baseTest(common)
11
- closeTest(common)
12
- stressTest(common)
13
- megaStressTest(common)
14
- })
15
- }
@@ -1,15 +0,0 @@
1
- import spawn from './spawner.js'
2
- import type { TestSetup } from '../index.js'
3
- import type { StreamMuxer, StreamMuxerFactory, StreamMuxerInit } from '@libp2p/interfaces/stream-muxer'
4
- import { Components } from '@libp2p/interfaces/components'
5
-
6
- export default (common: TestSetup<StreamMuxerFactory>) => {
7
- const createMuxer = async (init?: StreamMuxerInit): Promise<StreamMuxer> => {
8
- const factory = await common.setup()
9
- return factory.createStreamMuxer(new Components(), init)
10
- }
11
-
12
- describe.skip('mega stress test', function () {
13
- it('10,000 streams with 10,000 msg', async () => await spawn(createMuxer, 10000, 10000, 5000))
14
- })
15
- }
@@ -1,52 +0,0 @@
1
- import { expect } from 'aegir/chai'
2
- import { duplexPair } from 'it-pair/duplex'
3
- import { pipe } from 'it-pipe'
4
- import pLimit from 'p-limit'
5
- import { fromString as uint8ArrayFromString } from 'uint8arrays/from-string'
6
- import drain from 'it-drain'
7
- import all from 'it-all'
8
- import type { StreamMuxer, StreamMuxerInit } from '@libp2p/interfaces/stream-muxer'
9
-
10
- export default async (createMuxer: (init?: StreamMuxerInit) => Promise<StreamMuxer>, nStreams: number, nMsg: number, limit?: number) => {
11
- const [dialerSocket, listenerSocket] = duplexPair<Uint8Array>()
12
-
13
- const msg = uint8ArrayFromString('simple msg')
14
-
15
- const listener = await createMuxer({
16
- onIncomingStream: (stream) => {
17
- void pipe(
18
- stream,
19
- drain
20
- ).then(() => {
21
- stream.close()
22
- })
23
- }
24
- })
25
- const dialer = await createMuxer()
26
-
27
- void pipe(listenerSocket, listener, listenerSocket)
28
- void pipe(dialerSocket, dialer, dialerSocket)
29
-
30
- const spawnStream = async () => {
31
- const stream = dialer.newStream()
32
- expect(stream).to.exist // eslint-disable-line
33
-
34
- const res = await pipe(
35
- (async function * () {
36
- for (let i = 0; i < nMsg; i++) {
37
- yield msg
38
- }
39
- }()),
40
- stream,
41
- async (source) => await all(source)
42
- )
43
-
44
- expect(res).to.be.eql([])
45
- }
46
-
47
- const limiter = pLimit(limit ?? Infinity)
48
-
49
- await Promise.all(
50
- Array.from(Array(nStreams), async () => await limiter(async () => await spawnStream()))
51
- )
52
- }
@@ -1,29 +0,0 @@
1
- import spawn from './spawner.js'
2
- import type { TestSetup } from '../index.js'
3
- import type { StreamMuxerFactory, StreamMuxerInit, StreamMuxer } from '@libp2p/interfaces/stream-muxer'
4
- import { Components } from '@libp2p/interfaces/components'
5
-
6
- export default (common: TestSetup<StreamMuxerFactory>) => {
7
- const createMuxer = async (init?: StreamMuxerInit): Promise<StreamMuxer> => {
8
- const factory = await common.setup()
9
- return factory.createStreamMuxer(new Components(), init)
10
- }
11
-
12
- describe('stress test', () => {
13
- it('1 stream with 1 msg', async () => await spawn(createMuxer, 1, 1))
14
- it('1 stream with 10 msg', async () => await spawn(createMuxer, 1, 10))
15
- it('1 stream with 100 msg', async () => await spawn(createMuxer, 1, 100))
16
- it('10 streams with 1 msg', async () => await spawn(createMuxer, 10, 1))
17
- it('10 streams with 10 msg', async () => await spawn(createMuxer, 10, 10))
18
- it('10 streams with 100 msg', async () => await spawn(createMuxer, 10, 100))
19
- it('100 streams with 1 msg', async () => await spawn(createMuxer, 100, 1))
20
- it('100 streams with 10 msg', async () => await spawn(createMuxer, 100, 10))
21
- it('100 streams with 100 msg', async () => await spawn(createMuxer, 100, 100))
22
- it('1000 streams with 1 msg', async () => await spawn(createMuxer, 1000, 1))
23
- it('1000 streams with 10 msg', async () => await spawn(createMuxer, 1000, 10))
24
- it('1000 streams with 100 msg', async function () {
25
- this.timeout(120000)
26
- await spawn(createMuxer, 1000, 100)
27
- })
28
- })
29
- }
@@ -1,25 +0,0 @@
1
- import { expect } from 'aegir/chai'
2
- import sinon from 'sinon'
3
- import type { TestSetup } from '../index.js'
4
- import type { Topology } from '@libp2p/interfaces/topology'
5
-
6
- export default (test: TestSetup<Topology>) => {
7
- describe('topology', () => {
8
- let topology: Topology
9
-
10
- beforeEach(async () => {
11
- topology = await test.setup()
12
- })
13
-
14
- afterEach(async () => {
15
- sinon.restore()
16
- await test.teardown()
17
- })
18
-
19
- it('should have properties set', () => {
20
- expect(topology.min).to.exist()
21
- expect(topology.max).to.exist()
22
- expect(topology.peers).to.exist()
23
- })
24
- })
25
- }