@libp2p/interface-compliance-tests 1.1.6 → 1.1.7

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 (43) hide show
  1. package/dist/src/mocks/connection.d.ts +2 -1
  2. package/dist/src/mocks/connection.d.ts.map +1 -1
  3. package/dist/src/mocks/connection.js +18 -12
  4. package/dist/src/mocks/connection.js.map +1 -1
  5. package/dist/src/mocks/muxer.d.ts +2 -2
  6. package/dist/src/mocks/muxer.d.ts.map +1 -1
  7. package/dist/src/mocks/muxer.js +175 -26
  8. package/dist/src/mocks/muxer.js.map +1 -1
  9. package/dist/src/mocks/upgrader.d.ts.map +1 -1
  10. package/dist/src/mocks/upgrader.js +2 -4
  11. package/dist/src/mocks/upgrader.js.map +1 -1
  12. package/dist/src/stream-muxer/base-test.js +1 -1
  13. package/dist/src/stream-muxer/base-test.js.map +1 -1
  14. package/dist/src/stream-muxer/close-test.d.ts.map +1 -1
  15. package/dist/src/stream-muxer/close-test.js +7 -8
  16. package/dist/src/stream-muxer/close-test.js.map +1 -1
  17. package/dist/src/transport/dial-test.d.ts.map +1 -1
  18. package/dist/src/transport/dial-test.js +2 -1
  19. package/dist/src/transport/dial-test.js.map +1 -1
  20. package/dist/src/transport/filter-test.js +1 -1
  21. package/dist/src/transport/filter-test.js.map +1 -1
  22. package/dist/src/transport/listen-test.d.ts.map +1 -1
  23. package/dist/src/transport/listen-test.js +2 -1
  24. package/dist/src/transport/listen-test.js.map +1 -1
  25. package/dist/src/utils/is-valid-tick.d.ts +6 -0
  26. package/dist/src/utils/is-valid-tick.d.ts.map +1 -0
  27. package/dist/src/utils/is-valid-tick.js +15 -0
  28. package/dist/src/utils/is-valid-tick.js.map +1 -0
  29. package/package.json +1 -1
  30. package/src/mocks/connection.ts +27 -20
  31. package/src/mocks/muxer.ts +230 -28
  32. package/src/mocks/upgrader.ts +2 -5
  33. package/src/stream-muxer/base-test.ts +1 -1
  34. package/src/stream-muxer/close-test.ts +8 -10
  35. package/src/transport/dial-test.ts +2 -1
  36. package/src/transport/filter-test.ts +1 -1
  37. package/src/transport/listen-test.ts +2 -1
  38. package/src/utils/is-valid-tick.ts +18 -0
  39. package/dist/src/transport/utils/index.d.ts +0 -15
  40. package/dist/src/transport/utils/index.d.ts.map +0 -1
  41. package/dist/src/transport/utils/index.js +0 -137
  42. package/dist/src/transport/utils/index.js.map +0 -1
  43. 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
- }