@libp2p/interface-compliance-tests 1.1.6 → 1.1.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/mocks/connection.d.ts +13 -2
- package/dist/src/mocks/connection.d.ts.map +1 -1
- package/dist/src/mocks/connection.js +56 -24
- package/dist/src/mocks/connection.js.map +1 -1
- package/dist/src/mocks/multiaddr-connection.d.ts +2 -1
- package/dist/src/mocks/multiaddr-connection.d.ts.map +1 -1
- package/dist/src/mocks/multiaddr-connection.js +2 -2
- package/dist/src/mocks/multiaddr-connection.js.map +1 -1
- package/dist/src/mocks/muxer.d.ts +2 -2
- package/dist/src/mocks/muxer.d.ts.map +1 -1
- package/dist/src/mocks/muxer.js +175 -26
- package/dist/src/mocks/muxer.js.map +1 -1
- package/dist/src/mocks/registrar.d.ts +11 -2
- package/dist/src/mocks/registrar.d.ts.map +1 -1
- package/dist/src/mocks/registrar.js +47 -5
- package/dist/src/mocks/registrar.js.map +1 -1
- package/dist/src/mocks/upgrader.d.ts.map +1 -1
- package/dist/src/mocks/upgrader.js +8 -4
- package/dist/src/mocks/upgrader.js.map +1 -1
- package/dist/src/pubsub/api.d.ts +3 -2
- package/dist/src/pubsub/api.d.ts.map +1 -1
- package/dist/src/pubsub/api.js +23 -13
- package/dist/src/pubsub/api.js.map +1 -1
- package/dist/src/pubsub/connection-handlers.d.ts +3 -2
- package/dist/src/pubsub/connection-handlers.d.ts.map +1 -1
- package/dist/src/pubsub/connection-handlers.js +165 -69
- package/dist/src/pubsub/connection-handlers.js.map +1 -1
- package/dist/src/pubsub/emit-self.d.ts +3 -2
- package/dist/src/pubsub/emit-self.d.ts.map +1 -1
- package/dist/src/pubsub/emit-self.js +15 -4
- package/dist/src/pubsub/emit-self.js.map +1 -1
- package/dist/src/pubsub/index.d.ts +6 -3
- package/dist/src/pubsub/index.d.ts.map +1 -1
- package/dist/src/pubsub/index.js.map +1 -1
- package/dist/src/pubsub/messages.d.ts +3 -2
- package/dist/src/pubsub/messages.d.ts.map +1 -1
- package/dist/src/pubsub/messages.js +42 -39
- package/dist/src/pubsub/messages.js.map +1 -1
- package/dist/src/pubsub/multiple-nodes.d.ts +3 -2
- package/dist/src/pubsub/multiple-nodes.d.ts.map +1 -1
- package/dist/src/pubsub/multiple-nodes.js +163 -65
- package/dist/src/pubsub/multiple-nodes.js.map +1 -1
- package/dist/src/pubsub/two-nodes.d.ts +3 -2
- package/dist/src/pubsub/two-nodes.d.ts.map +1 -1
- package/dist/src/pubsub/two-nodes.js +80 -38
- package/dist/src/pubsub/two-nodes.js.map +1 -1
- package/dist/src/stream-muxer/base-test.js +1 -1
- package/dist/src/stream-muxer/base-test.js.map +1 -1
- package/dist/src/stream-muxer/close-test.d.ts.map +1 -1
- package/dist/src/stream-muxer/close-test.js +12 -10
- package/dist/src/stream-muxer/close-test.js.map +1 -1
- package/dist/src/transport/dial-test.d.ts.map +1 -1
- package/dist/src/transport/dial-test.js +2 -1
- package/dist/src/transport/dial-test.js.map +1 -1
- package/dist/src/transport/filter-test.js +1 -1
- package/dist/src/transport/filter-test.js.map +1 -1
- package/dist/src/transport/listen-test.d.ts.map +1 -1
- package/dist/src/transport/listen-test.js +2 -1
- package/dist/src/transport/listen-test.js.map +1 -1
- package/dist/src/utils/is-valid-tick.d.ts +6 -0
- package/dist/src/utils/is-valid-tick.d.ts.map +1 -0
- package/dist/src/utils/is-valid-tick.js +15 -0
- package/dist/src/utils/is-valid-tick.js.map +1 -0
- package/package.json +7 -5
- package/src/mocks/connection.ts +80 -24
- package/src/mocks/multiaddr-connection.ts +3 -2
- package/src/mocks/muxer.ts +230 -28
- package/src/mocks/registrar.ts +65 -7
- package/src/mocks/upgrader.ts +8 -5
- package/src/pubsub/api.ts +29 -15
- package/src/pubsub/connection-handlers.ts +186 -75
- package/src/pubsub/emit-self.ts +19 -7
- package/src/pubsub/index.ts +6 -3
- package/src/pubsub/messages.ts +59 -44
- package/src/pubsub/multiple-nodes.ts +189 -76
- package/src/pubsub/two-nodes.ts +94 -46
- package/src/stream-muxer/base-test.ts +1 -1
- package/src/stream-muxer/close-test.ts +13 -12
- package/src/transport/dial-test.ts +2 -1
- package/src/transport/filter-test.ts +1 -1
- package/src/transport/listen-test.ts +2 -1
- package/src/utils/is-valid-tick.ts +18 -0
- package/dist/src/pubsub/utils.d.ts +0 -3
- package/dist/src/pubsub/utils.d.ts.map +0 -1
- package/dist/src/pubsub/utils.js +0 -11
- package/dist/src/pubsub/utils.js.map +0 -1
- package/dist/src/transport/utils/index.d.ts +0 -15
- package/dist/src/transport/utils/index.d.ts.map +0 -1
- package/dist/src/transport/utils/index.js +0 -137
- package/dist/src/transport/utils/index.js.map +0 -1
- package/src/pubsub/utils.ts +0 -13
- package/src/transport/utils/index.ts +0 -172
|
@@ -1,172 +0,0 @@
|
|
|
1
|
-
import { expect } from 'aegir/utils/chai.js'
|
|
2
|
-
import { pair } from 'it-pair'
|
|
3
|
-
import { peerIdFromString } from '@libp2p/peer-id'
|
|
4
|
-
import * as PeerIdFactory from '@libp2p/peer-id-factory'
|
|
5
|
-
import { pushable } from 'it-pushable'
|
|
6
|
-
import drain from 'it-drain'
|
|
7
|
-
import { Multiaddr } from '@multiformats/multiaddr'
|
|
8
|
-
import { pipe } from 'it-pipe'
|
|
9
|
-
import type { Upgrader, MultiaddrConnection } from '@libp2p/interfaces/transport'
|
|
10
|
-
import type { Connection, Stream, Metadata, ProtocolStream } from '@libp2p/interfaces/connection'
|
|
11
|
-
import type { Muxer } from '@libp2p/interfaces/stream-muxer'
|
|
12
|
-
import type { Duplex } from 'it-stream-types'
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
* A tick is considered valid if it happened between now
|
|
16
|
-
* and `ms` milliseconds ago
|
|
17
|
-
*/
|
|
18
|
-
export function isValidTick (date?: number, ms: number = 5000) {
|
|
19
|
-
if (date == null) {
|
|
20
|
-
throw new Error('date must be a number')
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
const now = Date.now()
|
|
24
|
-
|
|
25
|
-
if (date > now - ms && date <= now) {
|
|
26
|
-
return true
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
return false
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
export function mockMultiaddrConnection (source: Duplex<Uint8Array>): MultiaddrConnection {
|
|
33
|
-
const maConn: MultiaddrConnection = {
|
|
34
|
-
...source,
|
|
35
|
-
async close () {
|
|
36
|
-
|
|
37
|
-
},
|
|
38
|
-
timeline: {
|
|
39
|
-
open: Date.now()
|
|
40
|
-
},
|
|
41
|
-
remoteAddr: new Multiaddr('/ip4/127.0.0.1/tcp/4001')
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
return maConn
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
export function mockMuxer (): Muxer {
|
|
48
|
-
let streamId = 0
|
|
49
|
-
let streams: Stream[] = []
|
|
50
|
-
const p = pushable<Uint8Array>()
|
|
51
|
-
|
|
52
|
-
const muxer: Muxer = {
|
|
53
|
-
source: p,
|
|
54
|
-
sink: async (source) => {
|
|
55
|
-
await drain(source)
|
|
56
|
-
},
|
|
57
|
-
get streams () {
|
|
58
|
-
return streams
|
|
59
|
-
},
|
|
60
|
-
newStream: (name?: string) => {
|
|
61
|
-
const echo = pair<Uint8Array>()
|
|
62
|
-
|
|
63
|
-
const id = `${streamId++}`
|
|
64
|
-
const stream: Stream = {
|
|
65
|
-
id,
|
|
66
|
-
sink: echo.sink,
|
|
67
|
-
source: echo.source,
|
|
68
|
-
close: () => {
|
|
69
|
-
streams = streams.filter(s => s !== stream)
|
|
70
|
-
},
|
|
71
|
-
abort: () => {},
|
|
72
|
-
reset: () => {},
|
|
73
|
-
timeline: {
|
|
74
|
-
open: 0
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
return stream
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
return muxer
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
export interface MockUpgraderOptions {
|
|
86
|
-
muxer?: Muxer
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
export function mockUpgrader (options: MockUpgraderOptions = {}) {
|
|
90
|
-
const ensureProps = (multiaddrConnection: MultiaddrConnection) => {
|
|
91
|
-
['sink', 'source', 'remoteAddr', 'timeline', 'close'].forEach(prop => {
|
|
92
|
-
expect(multiaddrConnection).to.have.property(prop)
|
|
93
|
-
})
|
|
94
|
-
expect(isValidTick(multiaddrConnection.timeline.open)).to.equal(true)
|
|
95
|
-
return multiaddrConnection
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
const muxer = options.muxer ?? mockMuxer()
|
|
99
|
-
|
|
100
|
-
const upgrader: Upgrader = {
|
|
101
|
-
async upgradeOutbound (multiaddrConnection) {
|
|
102
|
-
ensureProps(multiaddrConnection)
|
|
103
|
-
return await createConnection(multiaddrConnection, 'outbound', muxer)
|
|
104
|
-
},
|
|
105
|
-
async upgradeInbound (multiaddrConnection) {
|
|
106
|
-
ensureProps(multiaddrConnection)
|
|
107
|
-
return await createConnection(multiaddrConnection, 'inbound', muxer)
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
return upgrader
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
async function createConnection (maConn: MultiaddrConnection, direction: 'inbound' | 'outbound', muxer: Muxer): Promise<Connection> {
|
|
115
|
-
const remoteAddr = maConn.remoteAddr
|
|
116
|
-
const remotePeerIdStr = remoteAddr.getPeerId()
|
|
117
|
-
const remotePeer = remotePeerIdStr != null ? peerIdFromString(remotePeerIdStr) : await PeerIdFactory.createEd25519PeerId()
|
|
118
|
-
|
|
119
|
-
const streams: Stream[] = []
|
|
120
|
-
let streamId = 0
|
|
121
|
-
|
|
122
|
-
const registry = new Map()
|
|
123
|
-
|
|
124
|
-
void pipe(
|
|
125
|
-
maConn, muxer, maConn
|
|
126
|
-
)
|
|
127
|
-
|
|
128
|
-
return {
|
|
129
|
-
id: 'mock-connection',
|
|
130
|
-
remoteAddr,
|
|
131
|
-
remotePeer,
|
|
132
|
-
stat: {
|
|
133
|
-
status: 'OPEN',
|
|
134
|
-
direction,
|
|
135
|
-
timeline: maConn.timeline,
|
|
136
|
-
multiplexer: 'test-multiplexer',
|
|
137
|
-
encryption: 'yes-yes-very-secure'
|
|
138
|
-
},
|
|
139
|
-
registry,
|
|
140
|
-
tags: [],
|
|
141
|
-
streams,
|
|
142
|
-
newStream: async (protocols) => {
|
|
143
|
-
if (!Array.isArray(protocols)) {
|
|
144
|
-
protocols = [protocols]
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
if (protocols.length === 0) {
|
|
148
|
-
throw new Error('protocols must have a length')
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
const id = `${streamId++}`
|
|
152
|
-
const stream: Stream = muxer.newStream(id)
|
|
153
|
-
const streamData: ProtocolStream = {
|
|
154
|
-
protocol: protocols[0],
|
|
155
|
-
stream
|
|
156
|
-
}
|
|
157
|
-
|
|
158
|
-
registry.set(id, streamData)
|
|
159
|
-
|
|
160
|
-
return streamData
|
|
161
|
-
},
|
|
162
|
-
addStream: (stream: Stream, metadata: Metadata) => {
|
|
163
|
-
|
|
164
|
-
},
|
|
165
|
-
removeStream: (id: string) => {
|
|
166
|
-
registry.delete(id)
|
|
167
|
-
},
|
|
168
|
-
close: async () => {
|
|
169
|
-
await maConn.close()
|
|
170
|
-
}
|
|
171
|
-
}
|
|
172
|
-
}
|