@libp2p/interface-compliance-tests 6.5.0 → 7.0.0-049bfa0fa
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/connection-encryption/index.d.ts.map +1 -1
- package/dist/src/connection-encryption/index.js +24 -15
- package/dist/src/connection-encryption/index.js.map +1 -1
- package/dist/src/stream-muxer/base-test.d.ts.map +1 -1
- package/dist/src/stream-muxer/base-test.js +62 -345
- 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 +254 -320
- package/dist/src/stream-muxer/close-test.js.map +1 -1
- package/dist/src/stream-muxer/index.js +2 -2
- package/dist/src/stream-muxer/index.js.map +1 -1
- package/dist/src/stream-muxer/{mega-stress-test.d.ts → stream-test.d.ts} +2 -2
- package/dist/src/stream-muxer/stream-test.d.ts.map +1 -0
- package/dist/src/stream-muxer/stream-test.js +290 -0
- package/dist/src/stream-muxer/stream-test.js.map +1 -0
- package/dist/src/stream-muxer/stress-test.d.ts.map +1 -1
- package/dist/src/stream-muxer/stress-test.js +70 -16
- package/dist/src/stream-muxer/stress-test.js.map +1 -1
- package/dist/src/transport/index.d.ts.map +1 -1
- package/dist/src/transport/index.js +235 -205
- package/dist/src/transport/index.js.map +1 -1
- package/dist/src/transport/utils.d.ts.map +1 -1
- package/dist/src/transport/utils.js +3 -2
- package/dist/src/transport/utils.js.map +1 -1
- package/package.json +23 -51
- package/src/connection-encryption/index.ts +27 -20
- package/src/stream-muxer/base-test.ts +75 -413
- package/src/stream-muxer/close-test.ts +305 -343
- package/src/stream-muxer/index.ts +2 -2
- package/src/stream-muxer/stream-test.ts +381 -0
- package/src/stream-muxer/stress-test.ts +92 -18
- package/src/transport/index.ts +281 -241
- package/src/transport/utils.ts +3 -2
- package/dist/src/connection-encryption/utils/index.d.ts +0 -3
- package/dist/src/connection-encryption/utils/index.d.ts.map +0 -1
- package/dist/src/connection-encryption/utils/index.js +0 -21
- package/dist/src/connection-encryption/utils/index.js.map +0 -1
- package/dist/src/matchers.d.ts +0 -12
- package/dist/src/matchers.d.ts.map +0 -1
- package/dist/src/matchers.js +0 -14
- package/dist/src/matchers.js.map +0 -1
- package/dist/src/mocks/connection-manager.d.ts +0 -27
- package/dist/src/mocks/connection-manager.d.ts.map +0 -1
- package/dist/src/mocks/connection-manager.js +0 -147
- package/dist/src/mocks/connection-manager.js.map +0 -1
- package/dist/src/mocks/connection.d.ts +0 -41
- package/dist/src/mocks/connection.d.ts.map +0 -1
- package/dist/src/mocks/connection.js +0 -236
- package/dist/src/mocks/connection.js.map +0 -1
- package/dist/src/mocks/duplex.d.ts +0 -4
- package/dist/src/mocks/duplex.d.ts.map +0 -1
- package/dist/src/mocks/duplex.js +0 -9
- package/dist/src/mocks/duplex.js.map +0 -1
- package/dist/src/mocks/index.d.ts +0 -12
- package/dist/src/mocks/index.d.ts.map +0 -1
- package/dist/src/mocks/index.js +0 -8
- package/dist/src/mocks/index.js.map +0 -1
- package/dist/src/mocks/multiaddr-connection.d.ts +0 -17
- package/dist/src/mocks/multiaddr-connection.d.ts.map +0 -1
- package/dist/src/mocks/multiaddr-connection.js +0 -64
- package/dist/src/mocks/multiaddr-connection.js.map +0 -1
- package/dist/src/mocks/muxer.d.ts +0 -36
- package/dist/src/mocks/muxer.d.ts.map +0 -1
- package/dist/src/mocks/muxer.js +0 -234
- package/dist/src/mocks/muxer.js.map +0 -1
- package/dist/src/mocks/registrar.d.ts +0 -16
- package/dist/src/mocks/registrar.d.ts.map +0 -1
- package/dist/src/mocks/registrar.js +0 -66
- package/dist/src/mocks/registrar.js.map +0 -1
- package/dist/src/mocks/upgrader.d.ts +0 -9
- package/dist/src/mocks/upgrader.d.ts.map +0 -1
- package/dist/src/mocks/upgrader.js +0 -46
- package/dist/src/mocks/upgrader.js.map +0 -1
- package/dist/src/pubsub/api.d.ts +0 -6
- package/dist/src/pubsub/api.d.ts.map +0 -1
- package/dist/src/pubsub/api.js +0 -88
- package/dist/src/pubsub/api.js.map +0 -1
- package/dist/src/pubsub/connection-handlers.d.ts +0 -6
- package/dist/src/pubsub/connection-handlers.d.ts.map +0 -1
- package/dist/src/pubsub/connection-handlers.js +0 -329
- package/dist/src/pubsub/connection-handlers.js.map +0 -1
- package/dist/src/pubsub/emit-self.d.ts +0 -6
- package/dist/src/pubsub/emit-self.d.ts.map +0 -1
- package/dist/src/pubsub/emit-self.js +0 -80
- package/dist/src/pubsub/emit-self.js.map +0 -1
- package/dist/src/pubsub/index.d.ts +0 -18
- package/dist/src/pubsub/index.d.ts.map +0 -1
- package/dist/src/pubsub/index.js +0 -17
- package/dist/src/pubsub/index.js.map +0 -1
- package/dist/src/pubsub/messages.d.ts +0 -6
- package/dist/src/pubsub/messages.d.ts.map +0 -1
- package/dist/src/pubsub/messages.js +0 -48
- package/dist/src/pubsub/messages.js.map +0 -1
- package/dist/src/pubsub/multiple-nodes.d.ts +0 -6
- package/dist/src/pubsub/multiple-nodes.d.ts.map +0 -1
- package/dist/src/pubsub/multiple-nodes.js +0 -350
- package/dist/src/pubsub/multiple-nodes.js.map +0 -1
- package/dist/src/pubsub/two-nodes.d.ts +0 -6
- package/dist/src/pubsub/two-nodes.d.ts.map +0 -1
- package/dist/src/pubsub/two-nodes.js +0 -216
- package/dist/src/pubsub/two-nodes.js.map +0 -1
- package/dist/src/pubsub/utils.d.ts +0 -5
- package/dist/src/pubsub/utils.d.ts.map +0 -1
- package/dist/src/pubsub/utils.js +0 -27
- package/dist/src/pubsub/utils.js.map +0 -1
- package/dist/src/stream-muxer/mega-stress-test.d.ts.map +0 -1
- package/dist/src/stream-muxer/mega-stress-test.js +0 -11
- package/dist/src/stream-muxer/mega-stress-test.js.map +0 -1
- package/dist/src/stream-muxer/spawner.d.ts +0 -4
- package/dist/src/stream-muxer/spawner.d.ts.map +0 -1
- package/dist/src/stream-muxer/spawner.js +0 -39
- package/dist/src/stream-muxer/spawner.js.map +0 -1
- package/dist/typedoc-urls.json +0 -44
- package/src/connection-encryption/utils/index.ts +0 -27
- package/src/matchers.ts +0 -18
- package/src/mocks/connection-manager.ts +0 -216
- package/src/mocks/connection.ts +0 -309
- package/src/mocks/duplex.ts +0 -11
- package/src/mocks/index.ts +0 -11
- package/src/mocks/multiaddr-connection.ts +0 -80
- package/src/mocks/muxer.ts +0 -331
- package/src/mocks/registrar.ts +0 -86
- package/src/mocks/upgrader.ts +0 -65
- package/src/pubsub/api.ts +0 -116
- package/src/pubsub/connection-handlers.ts +0 -413
- package/src/pubsub/emit-self.ts +0 -99
- package/src/pubsub/index.ts +0 -34
- package/src/pubsub/messages.ts +0 -59
- package/src/pubsub/multiple-nodes.ts +0 -440
- package/src/pubsub/two-nodes.ts +0 -272
- package/src/pubsub/utils.ts +0 -34
- package/src/stream-muxer/mega-stress-test.ts +0 -14
- package/src/stream-muxer/spawner.ts +0 -57
package/src/transport/utils.ts
CHANGED
|
@@ -3,8 +3,8 @@
|
|
|
3
3
|
import { echo } from '@libp2p/echo'
|
|
4
4
|
import { memory } from '@libp2p/memory'
|
|
5
5
|
import { plaintext } from '@libp2p/plaintext'
|
|
6
|
+
import { mockMuxer } from '@libp2p/utils'
|
|
6
7
|
import { createLibp2p } from 'libp2p'
|
|
7
|
-
import { mockMuxer } from '../mocks/muxer.js'
|
|
8
8
|
import type { Echo } from '@libp2p/echo'
|
|
9
9
|
import type { Libp2p, Upgrader } from '@libp2p/interface'
|
|
10
10
|
import type { TransportManager } from '@libp2p/interface-internal'
|
|
@@ -28,7 +28,8 @@ export async function createPeer (config: Partial<Libp2pOptions> = {}): Promise<
|
|
|
28
28
|
services: {
|
|
29
29
|
...config.services,
|
|
30
30
|
echo: echo({
|
|
31
|
-
maxInboundStreams:
|
|
31
|
+
maxInboundStreams: 5_000,
|
|
32
|
+
timeout: 180_000
|
|
32
33
|
})
|
|
33
34
|
}
|
|
34
35
|
})
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/connection-encryption/utils/index.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAA;AAI5D,wBAAgB,gBAAgB,IAAK,CAAC,mBAAmB,EAAE,mBAAmB,CAAC,CAmB9E"}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { logger } from '@libp2p/logger';
|
|
2
|
-
import { multiaddr } from '@multiformats/multiaddr';
|
|
3
|
-
import { duplexPair } from 'it-pair/duplex';
|
|
4
|
-
export function createMaConnPair() {
|
|
5
|
-
const [local, remote] = duplexPair();
|
|
6
|
-
function duplexToMaConn(duplex) {
|
|
7
|
-
const output = {
|
|
8
|
-
...duplex,
|
|
9
|
-
close: async () => { },
|
|
10
|
-
abort: () => { },
|
|
11
|
-
remoteAddr: multiaddr('/ip4/127.0.0.1/tcp/4001'),
|
|
12
|
-
timeline: {
|
|
13
|
-
open: Date.now()
|
|
14
|
-
},
|
|
15
|
-
log: logger('duplex-maconn')
|
|
16
|
-
};
|
|
17
|
-
return output;
|
|
18
|
-
}
|
|
19
|
-
return [duplexToMaConn(local), duplexToMaConn(remote)];
|
|
20
|
-
}
|
|
21
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/connection-encryption/utils/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAA;AACvC,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAA;AACnD,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAA;AAK3C,MAAM,UAAU,gBAAgB;IAC9B,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,UAAU,EAA+B,CAAA;IAEjE,SAAS,cAAc,CAAE,MAA+G;QACtI,MAAM,MAAM,GAAwB;YAClC,GAAG,MAAM;YACT,KAAK,EAAE,KAAK,IAAI,EAAE,GAAE,CAAC;YACrB,KAAK,EAAE,GAAG,EAAE,GAAE,CAAC;YACf,UAAU,EAAE,SAAS,CAAC,yBAAyB,CAAC;YAChD,QAAQ,EAAE;gBACR,IAAI,EAAE,IAAI,CAAC,GAAG,EAAE;aACjB;YACD,GAAG,EAAE,MAAM,CAAC,eAAe,CAAC;SAC7B,CAAA;QAED,OAAO,MAAM,CAAA;IACf,CAAC;IAED,OAAO,CAAC,cAAc,CAAC,KAAK,CAAC,EAAE,cAAc,CAAC,MAAM,CAAC,CAAC,CAAA;AACxD,CAAC"}
|
package/dist/src/matchers.d.ts
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import type { PeerId } from '@libp2p/interface';
|
|
2
|
-
import type { Multiaddr } from '@multiformats/multiaddr';
|
|
3
|
-
import type { SinonMatcher } from 'sinon';
|
|
4
|
-
/**
|
|
5
|
-
* @deprecated PeerIds can be passed to sinon matchers directly
|
|
6
|
-
*/
|
|
7
|
-
export declare function matchPeerId(peerId: PeerId): SinonMatcher;
|
|
8
|
-
/**
|
|
9
|
-
* @deprecated Multiaddrs can be passed to sinon matchers directly
|
|
10
|
-
*/
|
|
11
|
-
export declare function matchMultiaddr(ma: Multiaddr): SinonMatcher;
|
|
12
|
-
//# sourceMappingURL=matchers.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"matchers.d.ts","sourceRoot":"","sources":["../../src/matchers.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAC/C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAA;AACxD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,OAAO,CAAA;AAEzC;;GAEG;AACH,wBAAgB,WAAW,CAAE,MAAM,EAAE,MAAM,GAAG,YAAY,CAEzD;AAED;;GAEG;AACH,wBAAgB,cAAc,CAAE,EAAE,EAAE,SAAS,GAAG,YAAY,CAE3D"}
|
package/dist/src/matchers.js
DELETED
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import Sinon from 'sinon';
|
|
2
|
-
/**
|
|
3
|
-
* @deprecated PeerIds can be passed to sinon matchers directly
|
|
4
|
-
*/
|
|
5
|
-
export function matchPeerId(peerId) {
|
|
6
|
-
return Sinon.match(p => p.toString() === peerId.toString());
|
|
7
|
-
}
|
|
8
|
-
/**
|
|
9
|
-
* @deprecated Multiaddrs can be passed to sinon matchers directly
|
|
10
|
-
*/
|
|
11
|
-
export function matchMultiaddr(ma) {
|
|
12
|
-
return Sinon.match(m => m.toString() === ma.toString());
|
|
13
|
-
}
|
|
14
|
-
//# sourceMappingURL=matchers.js.map
|
package/dist/src/matchers.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"matchers.js","sourceRoot":"","sources":["../../src/matchers.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAKzB;;GAEG;AACH,MAAM,UAAU,WAAW,CAAE,MAAc;IACzC,OAAO,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE,KAAK,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAA;AAC7D,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,cAAc,CAAE,EAAa;IAC3C,OAAO,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE,KAAK,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAA;AACzD,CAAC"}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import type { PrivateKey, PeerId, ComponentLogger, Libp2pEvents, PubSub } from '@libp2p/interface';
|
|
2
|
-
import type { ConnectionManager, Registrar } from '@libp2p/interface-internal';
|
|
3
|
-
import type { Multiaddr } from '@multiformats/multiaddr';
|
|
4
|
-
import type { TypedEventTarget } from 'main-event';
|
|
5
|
-
export interface MockNetworkComponents {
|
|
6
|
-
peerId: PeerId;
|
|
7
|
-
privateKey: PrivateKey;
|
|
8
|
-
registrar: Registrar;
|
|
9
|
-
connectionManager: ConnectionManager;
|
|
10
|
-
events: TypedEventTarget<Libp2pEvents>;
|
|
11
|
-
pubsub?: PubSub;
|
|
12
|
-
logger: ComponentLogger;
|
|
13
|
-
}
|
|
14
|
-
export declare class MockNetwork {
|
|
15
|
-
private components;
|
|
16
|
-
addNode(components: MockNetworkComponents): void;
|
|
17
|
-
getNode(peerId: PeerId | Multiaddr[]): MockNetworkComponents;
|
|
18
|
-
reset(): void;
|
|
19
|
-
}
|
|
20
|
-
export declare const mockNetwork: MockNetwork;
|
|
21
|
-
export interface MockConnectionManagerComponents {
|
|
22
|
-
peerId: PeerId;
|
|
23
|
-
registrar: Registrar;
|
|
24
|
-
events: TypedEventTarget<Libp2pEvents>;
|
|
25
|
-
}
|
|
26
|
-
export declare function mockConnectionManager(components: MockConnectionManagerComponents): ConnectionManager;
|
|
27
|
-
//# sourceMappingURL=connection-manager.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"connection-manager.d.ts","sourceRoot":"","sources":["../../../src/mocks/connection-manager.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,EAAE,eAAe,EAAE,YAAY,EAA2B,MAAM,EAAa,MAAM,mBAAmB,CAAA;AACtI,OAAO,KAAK,EAAE,iBAAiB,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAA;AAC9E,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAA;AAExD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAA;AAElD,MAAM,WAAW,qBAAqB;IACpC,MAAM,EAAE,MAAM,CAAA;IACd,UAAU,EAAE,UAAU,CAAA;IACtB,SAAS,EAAE,SAAS,CAAA;IACpB,iBAAiB,EAAE,iBAAiB,CAAA;IACpC,MAAM,EAAE,gBAAgB,CAAC,YAAY,CAAC,CAAA;IACtC,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,MAAM,EAAE,eAAe,CAAA;CACxB;AAED,qBAAa,WAAW;IACtB,OAAO,CAAC,UAAU,CAA8B;IAEhD,OAAO,CAAE,UAAU,EAAE,qBAAqB,GAAG,IAAI;IAIjD,OAAO,CAAE,MAAM,EAAE,MAAM,GAAG,SAAS,EAAG,GAAG,qBAAqB;IAc9D,KAAK,IAAK,IAAI;CAGf;AAED,eAAO,MAAM,WAAW,aAAoB,CAAA;AAE5C,MAAM,WAAW,+BAA+B;IAC9C,MAAM,EAAE,MAAM,CAAA;IACd,SAAS,EAAE,SAAS,CAAA;IACpB,MAAM,EAAE,gBAAgB,CAAC,YAAY,CAAC,CAAA;CACvC;AAgKD,wBAAgB,qBAAqB,CAAE,UAAU,EAAE,+BAA+B,GAAG,iBAAiB,CAErG"}
|
|
@@ -1,147 +0,0 @@
|
|
|
1
|
-
import { UnsupportedOperationError, isPeerId } from '@libp2p/interface';
|
|
2
|
-
import { PeerMap } from '@libp2p/peer-collections';
|
|
3
|
-
import { peerIdFromString } from '@libp2p/peer-id';
|
|
4
|
-
import { isMultiaddr } from '@multiformats/multiaddr';
|
|
5
|
-
import { connectionPair } from './connection.js';
|
|
6
|
-
export class MockNetwork {
|
|
7
|
-
components = [];
|
|
8
|
-
addNode(components) {
|
|
9
|
-
this.components.push(components);
|
|
10
|
-
}
|
|
11
|
-
getNode(peerId) {
|
|
12
|
-
if (Array.isArray(peerId) && peerId.length > 0) {
|
|
13
|
-
peerId = peerIdFromString(peerId[0].getPeerId() ?? '');
|
|
14
|
-
}
|
|
15
|
-
else if (isPeerId(peerId)) {
|
|
16
|
-
for (const components of this.components) {
|
|
17
|
-
if (peerId.equals(components.peerId)) {
|
|
18
|
-
return components;
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
throw new Error('Peer not found');
|
|
23
|
-
}
|
|
24
|
-
reset() {
|
|
25
|
-
this.components = [];
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
export const mockNetwork = new MockNetwork();
|
|
29
|
-
class MockConnectionManager {
|
|
30
|
-
connections = [];
|
|
31
|
-
components;
|
|
32
|
-
started = false;
|
|
33
|
-
constructor(components) {
|
|
34
|
-
this.components = components;
|
|
35
|
-
}
|
|
36
|
-
isStarted() {
|
|
37
|
-
return this.started;
|
|
38
|
-
}
|
|
39
|
-
async start() {
|
|
40
|
-
this.started = true;
|
|
41
|
-
}
|
|
42
|
-
async stop() {
|
|
43
|
-
for (const connection of this.connections) {
|
|
44
|
-
await this.closeConnections(connection.remotePeer);
|
|
45
|
-
}
|
|
46
|
-
this.started = false;
|
|
47
|
-
}
|
|
48
|
-
getConnections(peerId) {
|
|
49
|
-
if (peerId != null) {
|
|
50
|
-
return this.connections
|
|
51
|
-
.filter(c => c.remotePeer.toString() === peerId.toString());
|
|
52
|
-
}
|
|
53
|
-
return this.connections;
|
|
54
|
-
}
|
|
55
|
-
getConnectionsMap() {
|
|
56
|
-
const map = new PeerMap();
|
|
57
|
-
for (const conn of this.connections) {
|
|
58
|
-
const conns = map.get(conn.remotePeer) ?? [];
|
|
59
|
-
conns.push(conn);
|
|
60
|
-
map.set(conn.remotePeer, conns);
|
|
61
|
-
}
|
|
62
|
-
return map;
|
|
63
|
-
}
|
|
64
|
-
getMaxConnections() {
|
|
65
|
-
return 10_000;
|
|
66
|
-
}
|
|
67
|
-
setMaxConnections() {
|
|
68
|
-
}
|
|
69
|
-
async openConnection(peerId, options) {
|
|
70
|
-
if (isMultiaddr(peerId)) {
|
|
71
|
-
throw new UnsupportedOperationError('Dialing multiaddrs not supported');
|
|
72
|
-
}
|
|
73
|
-
options?.signal?.throwIfAborted();
|
|
74
|
-
let existingConnections = [];
|
|
75
|
-
if (Array.isArray(peerId) && peerId.length > 0) {
|
|
76
|
-
existingConnections = this.getConnections(peerIdFromString(peerId[0].getPeerId() ?? ''));
|
|
77
|
-
}
|
|
78
|
-
else if (isPeerId(peerId)) {
|
|
79
|
-
existingConnections = this.getConnections(peerId);
|
|
80
|
-
}
|
|
81
|
-
if (existingConnections.length > 0) {
|
|
82
|
-
return existingConnections[0];
|
|
83
|
-
}
|
|
84
|
-
const componentsB = mockNetwork.getNode(peerId);
|
|
85
|
-
const [aToB, bToA] = connectionPair(this.components, componentsB);
|
|
86
|
-
// track connections
|
|
87
|
-
this.connections.push(aToB);
|
|
88
|
-
componentsB.connectionManager.connections.push(bToA);
|
|
89
|
-
this.components.events.safeDispatchEvent('connection:open', {
|
|
90
|
-
detail: aToB
|
|
91
|
-
});
|
|
92
|
-
for (const protocol of this.components.registrar.getProtocols()) {
|
|
93
|
-
for (const topology of this.components.registrar.getTopologies(protocol)) {
|
|
94
|
-
topology.onConnect?.(componentsB.peerId, aToB);
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
this.components.events.safeDispatchEvent('peer:connect', { detail: componentsB.peerId });
|
|
98
|
-
componentsB.events.safeDispatchEvent('connection:open', {
|
|
99
|
-
detail: bToA
|
|
100
|
-
});
|
|
101
|
-
for (const protocol of componentsB.registrar.getProtocols()) {
|
|
102
|
-
for (const topology of componentsB.registrar.getTopologies(protocol)) {
|
|
103
|
-
topology.onConnect?.(this.components.peerId, bToA);
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
componentsB.events.safeDispatchEvent('peer:connect', { detail: this.components.peerId });
|
|
107
|
-
return aToB;
|
|
108
|
-
}
|
|
109
|
-
async closeConnections(peerId) {
|
|
110
|
-
const connections = this.getConnections(peerId);
|
|
111
|
-
if (connections.length === 0) {
|
|
112
|
-
return;
|
|
113
|
-
}
|
|
114
|
-
const componentsB = mockNetwork.getNode(peerId);
|
|
115
|
-
for (const protocol of this.components.registrar.getProtocols()) {
|
|
116
|
-
this.components.registrar.getTopologies(protocol).forEach(topology => {
|
|
117
|
-
topology.onDisconnect?.(componentsB.peerId);
|
|
118
|
-
});
|
|
119
|
-
}
|
|
120
|
-
for (const conn of connections) {
|
|
121
|
-
await conn.close();
|
|
122
|
-
}
|
|
123
|
-
this.connections = this.connections.filter(c => !c.remotePeer.equals(peerId));
|
|
124
|
-
if (this.connections.filter(c => !c.remotePeer.equals(peerId)).length === 0) {
|
|
125
|
-
componentsB.events.safeDispatchEvent('peer:disconnect', { detail: peerId });
|
|
126
|
-
}
|
|
127
|
-
await componentsB.connectionManager?.closeConnections(this.components.peerId);
|
|
128
|
-
if (componentsB.connectionManager?.getConnectionsMap().get(this.components.peerId) == null) {
|
|
129
|
-
componentsB.events.safeDispatchEvent('peer:disconnect', { detail: this.components.peerId });
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
async acceptIncomingConnection() {
|
|
133
|
-
return true;
|
|
134
|
-
}
|
|
135
|
-
afterUpgradeInbound() {
|
|
136
|
-
}
|
|
137
|
-
getDialQueue() {
|
|
138
|
-
return [];
|
|
139
|
-
}
|
|
140
|
-
async isDialable() {
|
|
141
|
-
return true;
|
|
142
|
-
}
|
|
143
|
-
}
|
|
144
|
-
export function mockConnectionManager(components) {
|
|
145
|
-
return new MockConnectionManager(components);
|
|
146
|
-
}
|
|
147
|
-
//# sourceMappingURL=connection-manager.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"connection-manager.js","sourceRoot":"","sources":["../../../src/mocks/connection-manager.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import { Uint8ArrayList } from 'uint8arraylist';
|
|
2
|
-
import type { ComponentLogger, MultiaddrConnection, Connection, Stream, Direction, PeerId, StreamMuxerFactory } from '@libp2p/interface';
|
|
3
|
-
import type { Registrar } from '@libp2p/interface-internal';
|
|
4
|
-
import type { Duplex, Source } from 'it-stream-types';
|
|
5
|
-
export interface MockConnectionOptions {
|
|
6
|
-
direction?: Direction;
|
|
7
|
-
registrar?: Registrar;
|
|
8
|
-
muxerFactory?: StreamMuxerFactory;
|
|
9
|
-
logger?: ComponentLogger;
|
|
10
|
-
}
|
|
11
|
-
export declare function mockConnection(maConn: MultiaddrConnection, opts?: MockConnectionOptions): Connection;
|
|
12
|
-
export interface StreamInit {
|
|
13
|
-
direction?: Direction;
|
|
14
|
-
protocol?: string;
|
|
15
|
-
id?: string;
|
|
16
|
-
}
|
|
17
|
-
export declare function mockStream(stream: Duplex<AsyncGenerator<Uint8ArrayList>, Source<Uint8ArrayList | Uint8Array>, Promise<void>>, init?: StreamInit): Stream;
|
|
18
|
-
export interface StreamPairInit {
|
|
19
|
-
duplex: Duplex<AsyncGenerator<Uint8ArrayList>, Source<Uint8ArrayList | Uint8Array>, Promise<void>>;
|
|
20
|
-
init?: StreamInit;
|
|
21
|
-
}
|
|
22
|
-
export declare function streamPair(a: StreamPairInit, b: StreamPairInit, init?: StreamInit): [Stream, Stream];
|
|
23
|
-
export interface Peer {
|
|
24
|
-
peerId: PeerId;
|
|
25
|
-
registrar: Registrar;
|
|
26
|
-
}
|
|
27
|
-
export declare function multiaddrConnectionPair(a: {
|
|
28
|
-
peerId: PeerId;
|
|
29
|
-
registrar: Registrar;
|
|
30
|
-
}, b: {
|
|
31
|
-
peerId: PeerId;
|
|
32
|
-
registrar: Registrar;
|
|
33
|
-
}): [MultiaddrConnection, MultiaddrConnection];
|
|
34
|
-
export declare function connectionPair(a: {
|
|
35
|
-
peerId: PeerId;
|
|
36
|
-
registrar: Registrar;
|
|
37
|
-
}, b: {
|
|
38
|
-
peerId: PeerId;
|
|
39
|
-
registrar: Registrar;
|
|
40
|
-
}): [Connection, Connection];
|
|
41
|
-
//# sourceMappingURL=connection.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"connection.d.ts","sourceRoot":"","sources":["../../../src/mocks/connection.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAI/C,OAAO,KAAK,EAAgB,eAAe,EAAU,mBAAmB,EAAE,UAAU,EAAE,MAAM,EAAE,SAAS,EAAwC,MAAM,EAAe,kBAAkB,EAAsC,MAAM,mBAAmB,CAAA;AACrP,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAA;AAE3D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAA;AAErD,MAAM,WAAW,qBAAqB;IACpC,SAAS,CAAC,EAAE,SAAS,CAAA;IACrB,SAAS,CAAC,EAAE,SAAS,CAAA;IACrB,YAAY,CAAC,EAAE,kBAAkB,CAAA;IACjC,MAAM,CAAC,EAAE,eAAe,CAAA;CACzB;AAsGD,wBAAgB,cAAc,CAAE,MAAM,EAAE,mBAAmB,EAAE,IAAI,GAAE,qBAA0B,GAAG,UAAU,CA4DzG;AAED,MAAM,WAAW,UAAU;IACzB,SAAS,CAAC,EAAE,SAAS,CAAA;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,EAAE,CAAC,EAAE,MAAM,CAAA;CACZ;AAED,wBAAgB,UAAU,CAAE,MAAM,EAAE,MAAM,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,MAAM,CAAC,cAAc,GAAG,UAAU,CAAC,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,GAAE,UAAe,GAAG,MAAM,CAsE7J;AAED,MAAM,WAAW,cAAc;IAC7B,MAAM,EAAE,MAAM,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,MAAM,CAAC,cAAc,GAAG,UAAU,CAAC,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAA;IAClG,IAAI,CAAC,EAAE,UAAU,CAAA;CAClB;AAED,wBAAgB,UAAU,CAAE,CAAC,EAAE,cAAc,EAAE,CAAC,EAAE,cAAc,EAAE,IAAI,GAAE,UAAe,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAazG;AAED,MAAM,WAAW,IAAI;IACnB,MAAM,EAAE,MAAM,CAAA;IACd,SAAS,EAAE,SAAS,CAAA;CACrB;AAED,wBAAgB,uBAAuB,CAAE,CAAC,EAAE;IAAE,MAAM,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,SAAS,CAAA;CAAE,EAAE,CAAC,EAAE;IAAE,MAAM,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,SAAS,CAAA;CAAE,GAAG,CAAE,mBAAmB,EAAE,mBAAmB,CAAE,CAO/K;AAED,wBAAgB,cAAc,CAAE,CAAC,EAAE;IAAE,MAAM,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,SAAS,CAAA;CAAE,EAAE,CAAC,EAAE;IAAE,MAAM,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,SAAS,CAAA;CAAE,GAAG,CAAE,UAAU,EAAE,UAAU,CAAE,CAWpJ"}
|
|
@@ -1,236 +0,0 @@
|
|
|
1
|
-
import { ConnectionClosedError } from '@libp2p/interface';
|
|
2
|
-
import { defaultLogger, logger } from '@libp2p/logger';
|
|
3
|
-
import * as mss from '@libp2p/multistream-select';
|
|
4
|
-
import { peerIdFromString } from '@libp2p/peer-id';
|
|
5
|
-
import { closeSource } from '@libp2p/utils/close-source';
|
|
6
|
-
import { duplexPair } from 'it-pair/duplex';
|
|
7
|
-
import { pipe } from 'it-pipe';
|
|
8
|
-
import { Uint8ArrayList } from 'uint8arraylist';
|
|
9
|
-
import { mockMultiaddrConnection } from './multiaddr-connection.js';
|
|
10
|
-
import { mockMuxer } from './muxer.js';
|
|
11
|
-
import { mockRegistrar } from './registrar.js';
|
|
12
|
-
class MockConnection {
|
|
13
|
-
id;
|
|
14
|
-
remoteAddr;
|
|
15
|
-
remotePeer;
|
|
16
|
-
direction;
|
|
17
|
-
timeline;
|
|
18
|
-
multiplexer;
|
|
19
|
-
encryption;
|
|
20
|
-
status;
|
|
21
|
-
streams;
|
|
22
|
-
tags;
|
|
23
|
-
limits;
|
|
24
|
-
log;
|
|
25
|
-
muxer;
|
|
26
|
-
maConn;
|
|
27
|
-
logger;
|
|
28
|
-
constructor(init) {
|
|
29
|
-
const { remoteAddr, remotePeer, direction, maConn, muxer, logger } = init;
|
|
30
|
-
this.id = `mock-connection-${Math.random()}`;
|
|
31
|
-
this.remoteAddr = remoteAddr;
|
|
32
|
-
this.remotePeer = remotePeer;
|
|
33
|
-
this.direction = direction;
|
|
34
|
-
this.status = 'open';
|
|
35
|
-
this.direction = direction;
|
|
36
|
-
this.timeline = maConn.timeline;
|
|
37
|
-
this.multiplexer = 'test-multiplexer';
|
|
38
|
-
this.encryption = 'yes-yes-very-secure';
|
|
39
|
-
this.streams = [];
|
|
40
|
-
this.tags = [];
|
|
41
|
-
this.muxer = muxer;
|
|
42
|
-
this.maConn = maConn;
|
|
43
|
-
this.logger = logger;
|
|
44
|
-
this.log = logger.forComponent(this.id);
|
|
45
|
-
}
|
|
46
|
-
async newStream(protocols, options) {
|
|
47
|
-
if (!Array.isArray(protocols)) {
|
|
48
|
-
protocols = [protocols];
|
|
49
|
-
}
|
|
50
|
-
if (protocols.length === 0) {
|
|
51
|
-
throw new Error('protocols must have a length');
|
|
52
|
-
}
|
|
53
|
-
if (this.status !== 'open') {
|
|
54
|
-
throw new ConnectionClosedError('connection must be open to create streams');
|
|
55
|
-
}
|
|
56
|
-
options?.signal?.throwIfAborted();
|
|
57
|
-
const id = `${Math.random()}`;
|
|
58
|
-
const stream = await this.muxer.newStream(id);
|
|
59
|
-
const result = await mss.select(stream, protocols, {
|
|
60
|
-
...options,
|
|
61
|
-
log: this.logger.forComponent('libp2p:mock-connection:stream:mss:select')
|
|
62
|
-
});
|
|
63
|
-
stream.protocol = result.protocol;
|
|
64
|
-
stream.direction = 'outbound';
|
|
65
|
-
stream.sink = result.stream.sink;
|
|
66
|
-
stream.source = result.stream.source;
|
|
67
|
-
this.streams.push(stream);
|
|
68
|
-
return stream;
|
|
69
|
-
}
|
|
70
|
-
async close(options) {
|
|
71
|
-
this.status = 'closing';
|
|
72
|
-
await Promise.all(this.streams.map(async (s) => s.close(options)));
|
|
73
|
-
await this.maConn.close();
|
|
74
|
-
this.status = 'closed';
|
|
75
|
-
this.timeline.close = Date.now();
|
|
76
|
-
}
|
|
77
|
-
abort(err) {
|
|
78
|
-
this.status = 'closing';
|
|
79
|
-
this.streams.forEach(s => {
|
|
80
|
-
s.abort(err);
|
|
81
|
-
});
|
|
82
|
-
this.maConn.abort(err);
|
|
83
|
-
this.status = 'closed';
|
|
84
|
-
this.timeline.close = Date.now();
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
export function mockConnection(maConn, opts = {}) {
|
|
88
|
-
const remoteAddr = maConn.remoteAddr;
|
|
89
|
-
const remotePeerIdStr = remoteAddr.getPeerId() ?? '12D3KooWCrhmFM1BCPGBkNzbPfDk4cjYmtAYSpZwUBC69Qg2kZyq';
|
|
90
|
-
const logger = opts.logger ?? defaultLogger();
|
|
91
|
-
if (remotePeerIdStr == null) {
|
|
92
|
-
throw new Error('Remote multiaddr must contain a peer id');
|
|
93
|
-
}
|
|
94
|
-
const remotePeer = peerIdFromString(remotePeerIdStr);
|
|
95
|
-
const direction = opts.direction ?? 'inbound';
|
|
96
|
-
const registrar = opts.registrar ?? mockRegistrar();
|
|
97
|
-
const muxerFactory = opts.muxerFactory ?? mockMuxer();
|
|
98
|
-
const log = logger.forComponent('libp2p:mock-muxer');
|
|
99
|
-
const muxer = muxerFactory.createStreamMuxer({
|
|
100
|
-
log,
|
|
101
|
-
direction,
|
|
102
|
-
onIncomingStream: (muxedStream) => {
|
|
103
|
-
try {
|
|
104
|
-
mss.handle(muxedStream, registrar.getProtocols(), {
|
|
105
|
-
log
|
|
106
|
-
})
|
|
107
|
-
.then(async ({ stream, protocol }) => {
|
|
108
|
-
log('%s: incoming stream opened on %s', direction, protocol);
|
|
109
|
-
muxedStream.protocol = protocol;
|
|
110
|
-
muxedStream.sink = stream.sink;
|
|
111
|
-
muxedStream.source = stream.source;
|
|
112
|
-
connection.streams.push(muxedStream);
|
|
113
|
-
const { handler } = registrar.getHandler(protocol);
|
|
114
|
-
await handler({ connection, stream: muxedStream });
|
|
115
|
-
}).catch(err => {
|
|
116
|
-
log.error(err);
|
|
117
|
-
muxedStream.abort(err);
|
|
118
|
-
});
|
|
119
|
-
}
|
|
120
|
-
catch (err) {
|
|
121
|
-
log.error(err);
|
|
122
|
-
}
|
|
123
|
-
},
|
|
124
|
-
onStreamEnd: (muxedStream) => {
|
|
125
|
-
connection.streams = connection.streams.filter(stream => stream.id !== muxedStream.id);
|
|
126
|
-
}
|
|
127
|
-
});
|
|
128
|
-
void pipe(maConn, muxer, maConn);
|
|
129
|
-
const connection = new MockConnection({
|
|
130
|
-
remoteAddr,
|
|
131
|
-
remotePeer,
|
|
132
|
-
direction,
|
|
133
|
-
maConn,
|
|
134
|
-
muxer,
|
|
135
|
-
logger
|
|
136
|
-
});
|
|
137
|
-
return connection;
|
|
138
|
-
}
|
|
139
|
-
export function mockStream(stream, init = {}) {
|
|
140
|
-
const id = `stream-${Date.now()}`;
|
|
141
|
-
const log = logger(`libp2p:mock-stream:${id}`);
|
|
142
|
-
// ensure stream output is `Uint8ArrayList` as it would be from an actual
|
|
143
|
-
// Stream where everything is length-varint encoded
|
|
144
|
-
const originalSource = stream.source;
|
|
145
|
-
stream.source = (async function* () {
|
|
146
|
-
for await (const buf of originalSource) {
|
|
147
|
-
if (buf instanceof Uint8Array) {
|
|
148
|
-
yield new Uint8ArrayList(buf);
|
|
149
|
-
}
|
|
150
|
-
else {
|
|
151
|
-
yield buf;
|
|
152
|
-
}
|
|
153
|
-
}
|
|
154
|
-
})();
|
|
155
|
-
const abortSinkController = new AbortController();
|
|
156
|
-
const originalSink = stream.sink.bind(stream);
|
|
157
|
-
stream.sink = async (source) => {
|
|
158
|
-
abortSinkController.signal.addEventListener('abort', () => {
|
|
159
|
-
closeSource(source, log);
|
|
160
|
-
});
|
|
161
|
-
await originalSink(source);
|
|
162
|
-
};
|
|
163
|
-
const mockStream = {
|
|
164
|
-
...stream,
|
|
165
|
-
close: async (options) => {
|
|
166
|
-
await mockStream.closeRead(options);
|
|
167
|
-
await mockStream.closeWrite(options);
|
|
168
|
-
},
|
|
169
|
-
closeRead: async () => {
|
|
170
|
-
closeSource(originalSource, log);
|
|
171
|
-
mockStream.timeline.closeRead = Date.now();
|
|
172
|
-
if (mockStream.timeline.closeWrite != null) {
|
|
173
|
-
mockStream.timeline.close = Date.now();
|
|
174
|
-
}
|
|
175
|
-
},
|
|
176
|
-
closeWrite: async () => {
|
|
177
|
-
abortSinkController.abort();
|
|
178
|
-
mockStream.timeline.closeWrite = Date.now();
|
|
179
|
-
if (mockStream.timeline.closeRead != null) {
|
|
180
|
-
mockStream.timeline.close = Date.now();
|
|
181
|
-
}
|
|
182
|
-
},
|
|
183
|
-
abort: () => {
|
|
184
|
-
closeSource(originalSource, log);
|
|
185
|
-
mockStream.timeline.closeWrite = Date.now();
|
|
186
|
-
mockStream.timeline.closeRead = Date.now();
|
|
187
|
-
mockStream.timeline.close = Date.now();
|
|
188
|
-
},
|
|
189
|
-
direction: 'outbound',
|
|
190
|
-
protocol: '/foo/1.0.0',
|
|
191
|
-
timeline: {
|
|
192
|
-
open: Date.now()
|
|
193
|
-
},
|
|
194
|
-
metadata: {},
|
|
195
|
-
id: `stream-${Date.now()}`,
|
|
196
|
-
status: 'open',
|
|
197
|
-
readStatus: 'ready',
|
|
198
|
-
writeStatus: 'ready',
|
|
199
|
-
log: logger('mock-stream'),
|
|
200
|
-
...init
|
|
201
|
-
};
|
|
202
|
-
return mockStream;
|
|
203
|
-
}
|
|
204
|
-
export function streamPair(a, b, init = {}) {
|
|
205
|
-
return [
|
|
206
|
-
mockStream(a.duplex, {
|
|
207
|
-
direction: 'outbound',
|
|
208
|
-
...init,
|
|
209
|
-
...(a.init ?? {})
|
|
210
|
-
}),
|
|
211
|
-
mockStream(b.duplex, {
|
|
212
|
-
direction: 'inbound',
|
|
213
|
-
...init,
|
|
214
|
-
...(b.init ?? {})
|
|
215
|
-
})
|
|
216
|
-
];
|
|
217
|
-
}
|
|
218
|
-
export function multiaddrConnectionPair(a, b) {
|
|
219
|
-
const [peerBtoPeerA, peerAtoPeerB] = duplexPair();
|
|
220
|
-
return [
|
|
221
|
-
mockMultiaddrConnection(peerAtoPeerB, b.peerId),
|
|
222
|
-
mockMultiaddrConnection(peerBtoPeerA, a.peerId)
|
|
223
|
-
];
|
|
224
|
-
}
|
|
225
|
-
export function connectionPair(a, b) {
|
|
226
|
-
const [peerBtoPeerA, peerAtoPeerB] = multiaddrConnectionPair(a, b);
|
|
227
|
-
return [
|
|
228
|
-
mockConnection(peerBtoPeerA, {
|
|
229
|
-
registrar: a.registrar
|
|
230
|
-
}),
|
|
231
|
-
mockConnection(peerAtoPeerB, {
|
|
232
|
-
registrar: b.registrar
|
|
233
|
-
})
|
|
234
|
-
];
|
|
235
|
-
}
|
|
236
|
-
//# sourceMappingURL=connection.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"connection.js","sourceRoot":"","sources":["../../../src/mocks/connection.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import type { Duplex, Source } from 'it-stream-types';
|
|
2
|
-
import type { Uint8ArrayList } from 'uint8arraylist';
|
|
3
|
-
export declare function mockDuplex(): Duplex<AsyncGenerator<Uint8Array | Uint8ArrayList>, Source<Uint8Array | Uint8ArrayList>, Promise<void>>;
|
|
4
|
-
//# sourceMappingURL=duplex.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"duplex.d.ts","sourceRoot":"","sources":["../../../src/mocks/duplex.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAA;AACrD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAEpD,wBAAgB,UAAU,IAAK,MAAM,CAAC,cAAc,CAAC,UAAU,GAAG,cAAc,CAAC,EAAE,MAAM,CAAC,UAAU,GAAG,cAAc,CAAC,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC,CAOrI"}
|
package/dist/src/mocks/duplex.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"duplex.js","sourceRoot":"","sources":["../../../src/mocks/duplex.ts"],"names":[],"mappings":"AAGA,MAAM,UAAU,UAAU;IACxB,OAAO;QACL,MAAM,EAAE,CAAC,KAAK,SAAU,CAAC;YACvB,KAAM,CAAC,CAAC,EAAE,CAAA;QACZ,CAAC,EAAE,CAAC;QACJ,IAAI,EAAE,KAAK,IAAI,EAAE,GAAE,CAAC;KACrB,CAAA;AACH,CAAC"}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
export { mockConnectionManager, mockNetwork } from './connection-manager.js';
|
|
2
|
-
export { mockConnection, mockStream, streamPair, connectionPair } from './connection.js';
|
|
3
|
-
export { mockMultiaddrConnection, mockMultiaddrConnPair } from './multiaddr-connection.js';
|
|
4
|
-
export { mockMuxer } from './muxer.js';
|
|
5
|
-
export { mockRegistrar } from './registrar.js';
|
|
6
|
-
export { mockUpgrader } from './upgrader.js';
|
|
7
|
-
export { mockDuplex } from './duplex.js';
|
|
8
|
-
export type { MockUpgraderInit } from './upgrader.js';
|
|
9
|
-
export type { MockNetworkComponents, MockConnectionManagerComponents, MockNetwork } from './connection-manager.js';
|
|
10
|
-
export type { MockConnectionOptions, StreamInit, StreamPairInit } from './connection.js';
|
|
11
|
-
export type { MockMultiaddrConnPairOptions } from './multiaddr-connection.js';
|
|
12
|
-
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/mocks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AAC5E,OAAO,EAAE,cAAc,EAAE,UAAU,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAA;AACxF,OAAO,EAAE,uBAAuB,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAA;AAC1F,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAA;AACtC,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAA;AAC9C,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAA;AAC5C,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AACxC,YAAY,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAA;AACrD,YAAY,EAAE,qBAAqB,EAAE,+BAA+B,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AAClH,YAAY,EAAE,qBAAqB,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAA;AACxF,YAAY,EAAE,4BAA4B,EAAE,MAAM,2BAA2B,CAAA"}
|
package/dist/src/mocks/index.js
DELETED
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
export { mockConnectionManager, mockNetwork } from './connection-manager.js';
|
|
2
|
-
export { mockConnection, mockStream, streamPair, connectionPair } from './connection.js';
|
|
3
|
-
export { mockMultiaddrConnection, mockMultiaddrConnPair } from './multiaddr-connection.js';
|
|
4
|
-
export { mockMuxer } from './muxer.js';
|
|
5
|
-
export { mockRegistrar } from './registrar.js';
|
|
6
|
-
export { mockUpgrader } from './upgrader.js';
|
|
7
|
-
export { mockDuplex } from './duplex.js';
|
|
8
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/mocks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AAC5E,OAAO,EAAE,cAAc,EAAE,UAAU,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAA;AACxF,OAAO,EAAE,uBAAuB,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAA;AAC1F,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAA;AACtC,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAA;AAC9C,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAA;AAC5C,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA"}
|