@libp2p/interface-compliance-tests 3.0.6 → 3.0.7-06f4901a
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 +12 -3
- 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 +151 -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 +18 -0
- package/dist/src/connection-encryption/utils/index.js.map +1 -0
- package/dist/src/index.d.ts +1 -1
- package/dist/src/index.d.ts.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 +162 -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 +51 -0
- package/dist/src/mocks/multiaddr-connection.js.map +1 -0
- package/dist/src/mocks/muxer.d.ts +8 -0
- package/dist/src/mocks/muxer.d.ts.map +1 -0
- package/dist/src/mocks/muxer.js +341 -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 +269 -0
- package/dist/src/stream-muxer/close-test.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 +36 -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 +71 -95
- package/src/connection/index.ts +184 -0
- package/src/connection-encryption/index.ts +97 -0
- package/src/connection-encryption/utils/index.ts +23 -0
- package/src/index.ts +1 -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 +218 -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 +67 -0
- package/src/mocks/muxer.ts +447 -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 +346 -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 +54 -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
- package/dist/typedoc-urls.json +0 -3
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/transport/index.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,gBAAgB,CAAA;AACjC,OAAO,MAAM,MAAM,kBAAkB,CAAA;AACrC,OAAO,MAAM,MAAM,kBAAkB,CAAA;AAgBrC,eAAe,CAAC,MAAwC,EAAQ,EAAE;IAChE,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;QACnC,IAAI,CAAC,MAAM,CAAC,CAAA;QACZ,MAAM,CAAC,MAAM,CAAC,CAAA;QACd,MAAM,CAAC,MAAM,CAAC,CAAA;IAChB,CAAC,CAAC,CAAA;AACJ,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"listen-test.d.ts","sourceRoot":"","sources":["../../../src/transport/listen-test.ts"],"names":[],"mappings":"AAWA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAA;AACvD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;iCAMpB,UAAU,qBAAqB,CAAC,KAAG,IAAI;AAA/D,wBA4KC"}
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
/* eslint max-nested-callbacks: ["error", 8] */
|
|
2
|
+
import { CustomEvent, EventEmitter } from '@libp2p/interface/events';
|
|
3
|
+
import { expect } from 'aegir/chai';
|
|
4
|
+
import drain from 'it-drain';
|
|
5
|
+
import { pipe } from 'it-pipe';
|
|
6
|
+
import defer from 'p-defer';
|
|
7
|
+
import pWaitFor from 'p-wait-for';
|
|
8
|
+
import sinon from 'sinon';
|
|
9
|
+
import { fromString as uint8ArrayFromString } from 'uint8arrays/from-string';
|
|
10
|
+
import { isValidTick } from '../is-valid-tick.js';
|
|
11
|
+
import { mockUpgrader, mockRegistrar } from '../mocks/index.js';
|
|
12
|
+
export default (common) => {
|
|
13
|
+
describe('listen', () => {
|
|
14
|
+
let upgrader;
|
|
15
|
+
let addrs;
|
|
16
|
+
let transport;
|
|
17
|
+
let registrar;
|
|
18
|
+
before(async () => {
|
|
19
|
+
registrar = mockRegistrar();
|
|
20
|
+
upgrader = mockUpgrader({
|
|
21
|
+
registrar,
|
|
22
|
+
events: new EventEmitter()
|
|
23
|
+
});
|
|
24
|
+
({ transport, addrs } = await common.setup());
|
|
25
|
+
});
|
|
26
|
+
after(async () => {
|
|
27
|
+
await common.teardown();
|
|
28
|
+
});
|
|
29
|
+
afterEach(() => {
|
|
30
|
+
sinon.restore();
|
|
31
|
+
});
|
|
32
|
+
it('simple', async () => {
|
|
33
|
+
const listener = transport.createListener({
|
|
34
|
+
upgrader
|
|
35
|
+
});
|
|
36
|
+
await listener.listen(addrs[0]);
|
|
37
|
+
await listener.close();
|
|
38
|
+
});
|
|
39
|
+
it('close listener with connections, through timeout', async () => {
|
|
40
|
+
const upgradeSpy = sinon.spy(upgrader, 'upgradeInbound');
|
|
41
|
+
const listenerConns = [];
|
|
42
|
+
const protocol = '/test/protocol';
|
|
43
|
+
void registrar.handle(protocol, (data) => {
|
|
44
|
+
void drain(data.stream.source);
|
|
45
|
+
});
|
|
46
|
+
const listener = transport.createListener({
|
|
47
|
+
upgrader,
|
|
48
|
+
handler: (conn) => {
|
|
49
|
+
listenerConns.push(conn);
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
// Listen
|
|
53
|
+
await listener.listen(addrs[0]);
|
|
54
|
+
// Create two connections to the listener
|
|
55
|
+
const [conn1] = await Promise.all([
|
|
56
|
+
transport.dial(addrs[0], {
|
|
57
|
+
upgrader
|
|
58
|
+
}),
|
|
59
|
+
transport.dial(addrs[0], {
|
|
60
|
+
upgrader
|
|
61
|
+
})
|
|
62
|
+
]);
|
|
63
|
+
// Give the listener a chance to finish its upgrade
|
|
64
|
+
await pWaitFor(() => listenerConns.length === 2);
|
|
65
|
+
const stream1 = await conn1.newStream([protocol]);
|
|
66
|
+
// Wait for the data send and close to finish
|
|
67
|
+
await Promise.all([
|
|
68
|
+
pipe([uint8ArrayFromString('Some data that is never handled')], stream1),
|
|
69
|
+
// Closer the listener (will take a couple of seconds to time out)
|
|
70
|
+
listener.close()
|
|
71
|
+
]);
|
|
72
|
+
stream1.close();
|
|
73
|
+
await conn1.close();
|
|
74
|
+
expect(isValidTick(conn1.stat.timeline.close)).to.equal(true);
|
|
75
|
+
listenerConns.forEach(conn => {
|
|
76
|
+
expect(isValidTick(conn.stat.timeline.close)).to.equal(true);
|
|
77
|
+
});
|
|
78
|
+
// 2 dials = 2 connections upgraded
|
|
79
|
+
expect(upgradeSpy.callCount).to.equal(2);
|
|
80
|
+
});
|
|
81
|
+
it('should not handle connection if upgradeInbound throws', async () => {
|
|
82
|
+
sinon.stub(upgrader, 'upgradeInbound').throws();
|
|
83
|
+
const listener = transport.createListener({
|
|
84
|
+
upgrader
|
|
85
|
+
});
|
|
86
|
+
// Listen
|
|
87
|
+
await listener.listen(addrs[0]);
|
|
88
|
+
// Create a connection to the listener
|
|
89
|
+
const conn = await transport.dial(addrs[0], {
|
|
90
|
+
upgrader
|
|
91
|
+
});
|
|
92
|
+
await pWaitFor(() => typeof conn.stat.timeline.close === 'number');
|
|
93
|
+
await listener.close();
|
|
94
|
+
});
|
|
95
|
+
describe('events', () => {
|
|
96
|
+
it('connection', async () => {
|
|
97
|
+
const upgradeSpy = sinon.spy(upgrader, 'upgradeInbound');
|
|
98
|
+
const listener = transport.createListener({
|
|
99
|
+
upgrader
|
|
100
|
+
});
|
|
101
|
+
const deferred = defer();
|
|
102
|
+
let conn;
|
|
103
|
+
listener.addEventListener('connection', (evt) => {
|
|
104
|
+
conn = evt.detail;
|
|
105
|
+
deferred.resolve();
|
|
106
|
+
});
|
|
107
|
+
void (async () => {
|
|
108
|
+
await listener.listen(addrs[0]);
|
|
109
|
+
await transport.dial(addrs[0], {
|
|
110
|
+
upgrader
|
|
111
|
+
});
|
|
112
|
+
})();
|
|
113
|
+
await deferred.promise;
|
|
114
|
+
await expect(upgradeSpy.getCall(0).returnValue).to.eventually.equal(conn);
|
|
115
|
+
expect(upgradeSpy.callCount).to.equal(1);
|
|
116
|
+
await listener.close();
|
|
117
|
+
});
|
|
118
|
+
it('listening', (done) => {
|
|
119
|
+
const listener = transport.createListener({
|
|
120
|
+
upgrader
|
|
121
|
+
});
|
|
122
|
+
listener.addEventListener('listening', () => {
|
|
123
|
+
listener.close().then(done, done);
|
|
124
|
+
});
|
|
125
|
+
void listener.listen(addrs[0]);
|
|
126
|
+
});
|
|
127
|
+
it('error', (done) => {
|
|
128
|
+
const listener = transport.createListener({
|
|
129
|
+
upgrader
|
|
130
|
+
});
|
|
131
|
+
listener.addEventListener('error', (evt) => {
|
|
132
|
+
expect(evt.detail).to.be.an.instanceOf(Error);
|
|
133
|
+
listener.close().then(done, done);
|
|
134
|
+
});
|
|
135
|
+
listener.dispatchEvent(new CustomEvent('error', {
|
|
136
|
+
detail: new Error('my err')
|
|
137
|
+
}));
|
|
138
|
+
});
|
|
139
|
+
it('close', (done) => {
|
|
140
|
+
const listener = transport.createListener({
|
|
141
|
+
upgrader
|
|
142
|
+
});
|
|
143
|
+
listener.addEventListener('close', () => { done(); });
|
|
144
|
+
void (async () => {
|
|
145
|
+
await listener.listen(addrs[0]);
|
|
146
|
+
await listener.close();
|
|
147
|
+
})();
|
|
148
|
+
});
|
|
149
|
+
});
|
|
150
|
+
});
|
|
151
|
+
};
|
|
152
|
+
//# sourceMappingURL=listen-test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"listen-test.js","sourceRoot":"","sources":["../../../src/transport/listen-test.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,24 +1,20 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@libp2p/interface-compliance-tests",
|
|
3
|
-
"version": "3.0.
|
|
3
|
+
"version": "3.0.7-06f4901a",
|
|
4
4
|
"description": "Compliance tests for JS libp2p interfaces",
|
|
5
5
|
"license": "Apache-2.0 OR MIT",
|
|
6
|
-
"homepage": "https://github.com/libp2p/js-libp2p
|
|
6
|
+
"homepage": "https://github.com/libp2p/js-libp2p/tree/master/packages/interface-compliance-tests#readme",
|
|
7
7
|
"repository": {
|
|
8
8
|
"type": "git",
|
|
9
|
-
"url": "git+https://github.com/libp2p/js-libp2p
|
|
9
|
+
"url": "git+https://github.com/libp2p/js-libp2p.git"
|
|
10
10
|
},
|
|
11
11
|
"bugs": {
|
|
12
|
-
"url": "https://github.com/libp2p/js-libp2p
|
|
12
|
+
"url": "https://github.com/libp2p/js-libp2p/issues"
|
|
13
13
|
},
|
|
14
14
|
"keywords": [
|
|
15
15
|
"interface",
|
|
16
16
|
"libp2p"
|
|
17
17
|
],
|
|
18
|
-
"engines": {
|
|
19
|
-
"node": ">=16.0.0",
|
|
20
|
-
"npm": ">=7.0.0"
|
|
21
|
-
},
|
|
22
18
|
"type": "module",
|
|
23
19
|
"types": "./dist/src/index.d.ts",
|
|
24
20
|
"typesVersions": {
|
|
@@ -48,13 +44,41 @@
|
|
|
48
44
|
"types": "./dist/src/index.d.ts",
|
|
49
45
|
"import": "./dist/src/index.js"
|
|
50
46
|
},
|
|
47
|
+
"./connection": {
|
|
48
|
+
"types": "./dist/src/connection/index.d.ts",
|
|
49
|
+
"import": "./dist/src/connection/index.js"
|
|
50
|
+
},
|
|
51
|
+
"./connection-encryption": {
|
|
52
|
+
"types": "./dist/src/connection-encryption/index.d.ts",
|
|
53
|
+
"import": "./dist/src/connection-encryption/index.js"
|
|
54
|
+
},
|
|
51
55
|
"./is-valid-tick": {
|
|
52
56
|
"types": "./dist/src/is-valid-tick.d.ts",
|
|
53
57
|
"import": "./dist/src/is-valid-tick.js"
|
|
54
58
|
},
|
|
59
|
+
"./mocks": {
|
|
60
|
+
"types": "./dist/src/mocks/index.d.ts",
|
|
61
|
+
"import": "./dist/src/mocks/index.js"
|
|
62
|
+
},
|
|
63
|
+
"./peer-discovery": {
|
|
64
|
+
"types": "./dist/src/peer-discovery/index.d.ts",
|
|
65
|
+
"import": "./dist/src/peer-discovery/index.js"
|
|
66
|
+
},
|
|
55
67
|
"./peers": {
|
|
56
68
|
"types": "./dist/src/peers.d.ts",
|
|
57
69
|
"import": "./dist/src/peers.js"
|
|
70
|
+
},
|
|
71
|
+
"./pubsub": {
|
|
72
|
+
"types": "./dist/src/pubsub/index.d.ts",
|
|
73
|
+
"import": "./dist/src/pubsub/index.js"
|
|
74
|
+
},
|
|
75
|
+
"./stream-muxer": {
|
|
76
|
+
"types": "./dist/src/stream-muxer/index.d.ts",
|
|
77
|
+
"import": "./dist/src/stream-muxer/index.js"
|
|
78
|
+
},
|
|
79
|
+
"./transport": {
|
|
80
|
+
"types": "./dist/src/transport/index.d.ts",
|
|
81
|
+
"import": "./dist/src/transport/index.js"
|
|
58
82
|
}
|
|
59
83
|
},
|
|
60
84
|
"eslintConfig": {
|
|
@@ -63,100 +87,52 @@
|
|
|
63
87
|
"sourceType": "module"
|
|
64
88
|
}
|
|
65
89
|
},
|
|
66
|
-
"release": {
|
|
67
|
-
"branches": [
|
|
68
|
-
"master"
|
|
69
|
-
],
|
|
70
|
-
"plugins": [
|
|
71
|
-
[
|
|
72
|
-
"@semantic-release/commit-analyzer",
|
|
73
|
-
{
|
|
74
|
-
"preset": "conventionalcommits",
|
|
75
|
-
"releaseRules": [
|
|
76
|
-
{
|
|
77
|
-
"breaking": true,
|
|
78
|
-
"release": "major"
|
|
79
|
-
},
|
|
80
|
-
{
|
|
81
|
-
"revert": true,
|
|
82
|
-
"release": "patch"
|
|
83
|
-
},
|
|
84
|
-
{
|
|
85
|
-
"type": "feat",
|
|
86
|
-
"release": "minor"
|
|
87
|
-
},
|
|
88
|
-
{
|
|
89
|
-
"type": "fix",
|
|
90
|
-
"release": "patch"
|
|
91
|
-
},
|
|
92
|
-
{
|
|
93
|
-
"type": "docs",
|
|
94
|
-
"release": "patch"
|
|
95
|
-
},
|
|
96
|
-
{
|
|
97
|
-
"type": "test",
|
|
98
|
-
"release": "patch"
|
|
99
|
-
},
|
|
100
|
-
{
|
|
101
|
-
"type": "deps",
|
|
102
|
-
"release": "patch"
|
|
103
|
-
},
|
|
104
|
-
{
|
|
105
|
-
"scope": "no-release",
|
|
106
|
-
"release": false
|
|
107
|
-
}
|
|
108
|
-
]
|
|
109
|
-
}
|
|
110
|
-
],
|
|
111
|
-
[
|
|
112
|
-
"@semantic-release/release-notes-generator",
|
|
113
|
-
{
|
|
114
|
-
"preset": "conventionalcommits",
|
|
115
|
-
"presetConfig": {
|
|
116
|
-
"types": [
|
|
117
|
-
{
|
|
118
|
-
"type": "feat",
|
|
119
|
-
"section": "Features"
|
|
120
|
-
},
|
|
121
|
-
{
|
|
122
|
-
"type": "fix",
|
|
123
|
-
"section": "Bug Fixes"
|
|
124
|
-
},
|
|
125
|
-
{
|
|
126
|
-
"type": "chore",
|
|
127
|
-
"section": "Trivial Changes"
|
|
128
|
-
},
|
|
129
|
-
{
|
|
130
|
-
"type": "docs",
|
|
131
|
-
"section": "Documentation"
|
|
132
|
-
},
|
|
133
|
-
{
|
|
134
|
-
"type": "deps",
|
|
135
|
-
"section": "Dependencies"
|
|
136
|
-
},
|
|
137
|
-
{
|
|
138
|
-
"type": "test",
|
|
139
|
-
"section": "Tests"
|
|
140
|
-
}
|
|
141
|
-
]
|
|
142
|
-
}
|
|
143
|
-
}
|
|
144
|
-
],
|
|
145
|
-
"@semantic-release/changelog",
|
|
146
|
-
"@semantic-release/npm",
|
|
147
|
-
"@semantic-release/github",
|
|
148
|
-
"@semantic-release/git"
|
|
149
|
-
]
|
|
150
|
-
},
|
|
151
90
|
"scripts": {
|
|
152
91
|
"clean": "aegir clean",
|
|
153
92
|
"lint": "aegir lint",
|
|
154
93
|
"dep-check": "aegir dep-check",
|
|
155
94
|
"build": "aegir build",
|
|
156
|
-
"
|
|
95
|
+
"test": "aegir test",
|
|
96
|
+
"test:chrome": "aegir test -t browser --cov",
|
|
97
|
+
"test:chrome-webworker": "aegir test -t webworker",
|
|
98
|
+
"test:firefox": "aegir test -t browser -- --browser firefox",
|
|
99
|
+
"test:firefox-webworker": "aegir test -t webworker -- --browser firefox",
|
|
100
|
+
"test:node": "aegir test -t node --cov",
|
|
101
|
+
"test:electron-main": "aegir test -t electron-main"
|
|
157
102
|
},
|
|
158
103
|
"dependencies": {
|
|
159
|
-
"
|
|
104
|
+
"@libp2p/interface": "0.0.1-06f4901a",
|
|
105
|
+
"@libp2p/interface-internal": "0.0.1-06f4901a",
|
|
106
|
+
"@libp2p/logger": "2.1.1-06f4901a",
|
|
107
|
+
"@libp2p/multistream-select": "3.1.9-06f4901a",
|
|
108
|
+
"@libp2p/peer-collections": "3.0.2-06f4901a",
|
|
109
|
+
"@libp2p/peer-id": "2.0.3-06f4901a",
|
|
110
|
+
"@libp2p/peer-id-factory": "2.0.3-06f4901a",
|
|
111
|
+
"@multiformats/multiaddr": "^12.1.3",
|
|
112
|
+
"abortable-iterator": "^5.0.1",
|
|
113
|
+
"any-signal": "^4.1.1",
|
|
114
|
+
"delay": "^6.0.0",
|
|
115
|
+
"it-all": "^3.0.2",
|
|
116
|
+
"it-drain": "^3.0.2",
|
|
117
|
+
"it-handshake": "^4.1.3",
|
|
118
|
+
"it-map": "^3.0.3",
|
|
119
|
+
"it-ndjson": "^1.0.3",
|
|
120
|
+
"it-pair": "^2.0.6",
|
|
121
|
+
"it-pipe": "^3.0.1",
|
|
122
|
+
"it-pushable": "^3.1.3",
|
|
123
|
+
"it-stream-types": "^2.0.1",
|
|
124
|
+
"merge-options": "^3.0.4",
|
|
125
|
+
"p-defer": "^4.0.0",
|
|
126
|
+
"p-event": "^6.0.0",
|
|
127
|
+
"p-limit": "^4.0.0",
|
|
128
|
+
"p-wait-for": "^5.0.2",
|
|
129
|
+
"sinon": "^15.1.2",
|
|
130
|
+
"ts-sinon": "^2.0.2",
|
|
131
|
+
"uint8arraylist": "^2.4.3",
|
|
132
|
+
"uint8arrays": "^4.0.4"
|
|
133
|
+
},
|
|
134
|
+
"devDependencies": {
|
|
135
|
+
"aegir": "^39.0.10"
|
|
160
136
|
},
|
|
161
137
|
"typedoc": {
|
|
162
138
|
"entryPoint": "./src/index.ts"
|
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
import { expect } from 'aegir/chai'
|
|
2
|
+
import sinon from 'sinon'
|
|
3
|
+
import { stubInterface } from 'ts-sinon'
|
|
4
|
+
import type { TestSetup } from '../index.js'
|
|
5
|
+
import type { Connection, Stream } from '@libp2p/interface/connection'
|
|
6
|
+
|
|
7
|
+
export default (test: TestSetup<Connection>): void => {
|
|
8
|
+
describe('connection', () => {
|
|
9
|
+
describe('open connection', () => {
|
|
10
|
+
let connection: Connection
|
|
11
|
+
|
|
12
|
+
beforeEach(async () => {
|
|
13
|
+
connection = await test.setup()
|
|
14
|
+
})
|
|
15
|
+
|
|
16
|
+
afterEach(async () => {
|
|
17
|
+
await connection.close()
|
|
18
|
+
await test.teardown()
|
|
19
|
+
})
|
|
20
|
+
|
|
21
|
+
it('should have properties set', () => {
|
|
22
|
+
expect(connection.id).to.exist()
|
|
23
|
+
expect(connection.remotePeer).to.exist()
|
|
24
|
+
expect(connection.remoteAddr).to.exist()
|
|
25
|
+
expect(connection.stat.status).to.equal('OPEN')
|
|
26
|
+
expect(connection.stat.timeline.open).to.exist()
|
|
27
|
+
expect(connection.stat.timeline.close).to.not.exist()
|
|
28
|
+
expect(connection.stat.direction).to.exist()
|
|
29
|
+
expect(connection.streams).to.eql([])
|
|
30
|
+
expect(connection.tags).to.eql([])
|
|
31
|
+
})
|
|
32
|
+
|
|
33
|
+
it('should get the metadata of an open connection', () => {
|
|
34
|
+
const stat = connection.stat
|
|
35
|
+
|
|
36
|
+
expect(stat.status).to.equal('OPEN')
|
|
37
|
+
expect(stat.direction).to.exist()
|
|
38
|
+
expect(stat.timeline.open).to.exist()
|
|
39
|
+
expect(stat.timeline.close).to.not.exist()
|
|
40
|
+
})
|
|
41
|
+
|
|
42
|
+
it('should return an empty array of streams', () => {
|
|
43
|
+
const streams = connection.streams
|
|
44
|
+
|
|
45
|
+
expect(streams).to.eql([])
|
|
46
|
+
})
|
|
47
|
+
|
|
48
|
+
it('should be able to create a new stream', async () => {
|
|
49
|
+
expect(connection.streams).to.be.empty()
|
|
50
|
+
|
|
51
|
+
const protocolToUse = '/echo/0.0.1'
|
|
52
|
+
const stream = await connection.newStream([protocolToUse])
|
|
53
|
+
|
|
54
|
+
expect(stream).to.have.nested.property('stat.protocol', protocolToUse)
|
|
55
|
+
|
|
56
|
+
const connStreams = connection.streams
|
|
57
|
+
|
|
58
|
+
expect(stream).to.exist()
|
|
59
|
+
expect(connStreams).to.exist()
|
|
60
|
+
expect(connStreams).to.have.lengthOf(1)
|
|
61
|
+
expect(connStreams[0]).to.equal(stream)
|
|
62
|
+
})
|
|
63
|
+
})
|
|
64
|
+
|
|
65
|
+
describe('close connection', () => {
|
|
66
|
+
let connection: Connection
|
|
67
|
+
let timelineProxy
|
|
68
|
+
const proxyHandler = {
|
|
69
|
+
set () {
|
|
70
|
+
// @ts-expect-error - TS fails to infer here
|
|
71
|
+
return Reflect.set(...arguments)
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
beforeEach(async () => {
|
|
76
|
+
timelineProxy = new Proxy({
|
|
77
|
+
open: Date.now() - 10,
|
|
78
|
+
upgraded: Date.now()
|
|
79
|
+
}, proxyHandler)
|
|
80
|
+
|
|
81
|
+
connection = await test.setup()
|
|
82
|
+
connection.stat.timeline = timelineProxy
|
|
83
|
+
})
|
|
84
|
+
|
|
85
|
+
afterEach(async () => {
|
|
86
|
+
await test.teardown()
|
|
87
|
+
})
|
|
88
|
+
|
|
89
|
+
it('should be able to close the connection after being created', async () => {
|
|
90
|
+
expect(connection.stat.timeline.close).to.not.exist()
|
|
91
|
+
await connection.close()
|
|
92
|
+
|
|
93
|
+
expect(connection.stat.timeline.close).to.exist()
|
|
94
|
+
expect(connection.stat.status).to.equal('CLOSED')
|
|
95
|
+
})
|
|
96
|
+
|
|
97
|
+
it('should be able to close the connection after opening a stream', async () => {
|
|
98
|
+
// Open stream
|
|
99
|
+
const protocol = '/echo/0.0.1'
|
|
100
|
+
await connection.newStream([protocol])
|
|
101
|
+
|
|
102
|
+
// Close connection
|
|
103
|
+
expect(connection.stat.timeline.close).to.not.exist()
|
|
104
|
+
await connection.close()
|
|
105
|
+
|
|
106
|
+
expect(connection.stat.timeline.close).to.exist()
|
|
107
|
+
expect(connection.stat.status).to.equal('CLOSED')
|
|
108
|
+
})
|
|
109
|
+
|
|
110
|
+
it('should properly track streams', async () => {
|
|
111
|
+
// Open stream
|
|
112
|
+
const protocol = '/echo/0.0.1'
|
|
113
|
+
const stream = await connection.newStream([protocol])
|
|
114
|
+
expect(stream).to.have.nested.property('stat.protocol', protocol)
|
|
115
|
+
|
|
116
|
+
// Close stream
|
|
117
|
+
stream.close()
|
|
118
|
+
|
|
119
|
+
expect(connection.streams.filter(s => s.id === stream.id)).to.be.empty()
|
|
120
|
+
})
|
|
121
|
+
|
|
122
|
+
it('should track outbound streams', async () => {
|
|
123
|
+
// Open stream
|
|
124
|
+
const protocol = '/echo/0.0.1'
|
|
125
|
+
const stream = await connection.newStream(protocol)
|
|
126
|
+
expect(stream).to.have.nested.property('stat.direction', 'outbound')
|
|
127
|
+
})
|
|
128
|
+
|
|
129
|
+
it.skip('should track inbound streams', async () => {
|
|
130
|
+
// Add an remotely opened stream
|
|
131
|
+
const stream = stubInterface<Stream>()
|
|
132
|
+
connection.addStream(stream)
|
|
133
|
+
expect(stream).to.have.property('direction', 'inbound')
|
|
134
|
+
})
|
|
135
|
+
|
|
136
|
+
it('should support a proxy on the timeline', async () => {
|
|
137
|
+
sinon.spy(proxyHandler, 'set')
|
|
138
|
+
expect(connection.stat.timeline.close).to.not.exist()
|
|
139
|
+
|
|
140
|
+
await connection.close()
|
|
141
|
+
// @ts-expect-error - fails to infer callCount
|
|
142
|
+
expect(proxyHandler.set.callCount).to.equal(1)
|
|
143
|
+
// @ts-expect-error - fails to infer getCall
|
|
144
|
+
const [obj, key, value] = proxyHandler.set.getCall(0).args
|
|
145
|
+
expect(obj).to.eql(connection.stat.timeline)
|
|
146
|
+
expect(key).to.equal('close')
|
|
147
|
+
expect(value).to.be.a('number').that.equals(connection.stat.timeline.close)
|
|
148
|
+
})
|
|
149
|
+
|
|
150
|
+
it('should fail to create a new stream if the connection is closing', async () => {
|
|
151
|
+
expect(connection.stat.timeline.close).to.not.exist()
|
|
152
|
+
const p = connection.close()
|
|
153
|
+
|
|
154
|
+
try {
|
|
155
|
+
const protocol = '/echo/0.0.1'
|
|
156
|
+
await connection.newStream([protocol])
|
|
157
|
+
} catch (err: any) {
|
|
158
|
+
expect(err).to.exist()
|
|
159
|
+
return
|
|
160
|
+
} finally {
|
|
161
|
+
await p
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
throw new Error('should fail to create a new stream if the connection is closing')
|
|
165
|
+
})
|
|
166
|
+
|
|
167
|
+
it('should fail to create a new stream if the connection is closed', async () => {
|
|
168
|
+
expect(connection.stat.timeline.close).to.not.exist()
|
|
169
|
+
await connection.close()
|
|
170
|
+
|
|
171
|
+
try {
|
|
172
|
+
const protocol = '/echo/0.0.1'
|
|
173
|
+
await connection.newStream([protocol])
|
|
174
|
+
} catch (err: any) {
|
|
175
|
+
expect(err).to.exist()
|
|
176
|
+
expect(err.code).to.equal('ERR_CONNECTION_CLOSED')
|
|
177
|
+
return
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
throw new Error('should fail to create a new stream if the connection is closing')
|
|
181
|
+
})
|
|
182
|
+
})
|
|
183
|
+
})
|
|
184
|
+
}
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
import { UnexpectedPeerError } from '@libp2p/interface/errors'
|
|
2
|
+
import * as PeerIdFactory from '@libp2p/peer-id-factory'
|
|
3
|
+
import { expect } from 'aegir/chai'
|
|
4
|
+
import all from 'it-all'
|
|
5
|
+
import { pipe } from 'it-pipe'
|
|
6
|
+
import { fromString as uint8ArrayFromString } from 'uint8arrays/from-string'
|
|
7
|
+
import peers from '../peers.js'
|
|
8
|
+
import { createMaConnPair } from './utils/index.js'
|
|
9
|
+
import type { TestSetup } from '../index.js'
|
|
10
|
+
import type { ConnectionEncrypter } from '@libp2p/interface/connection-encrypter'
|
|
11
|
+
import type { PeerId } from '@libp2p/interface/peer-id'
|
|
12
|
+
|
|
13
|
+
export default (common: TestSetup<ConnectionEncrypter>): void => {
|
|
14
|
+
describe('interface-connection-encrypter compliance tests', () => {
|
|
15
|
+
let crypto: ConnectionEncrypter
|
|
16
|
+
let localPeer: PeerId
|
|
17
|
+
let remotePeer: PeerId
|
|
18
|
+
let mitmPeer: PeerId
|
|
19
|
+
|
|
20
|
+
before(async () => {
|
|
21
|
+
[
|
|
22
|
+
crypto,
|
|
23
|
+
localPeer,
|
|
24
|
+
remotePeer,
|
|
25
|
+
mitmPeer
|
|
26
|
+
] = await Promise.all([
|
|
27
|
+
common.setup(),
|
|
28
|
+
PeerIdFactory.createFromJSON(peers[0]),
|
|
29
|
+
PeerIdFactory.createFromJSON(peers[1]),
|
|
30
|
+
PeerIdFactory.createFromJSON(peers[2])
|
|
31
|
+
])
|
|
32
|
+
})
|
|
33
|
+
|
|
34
|
+
after(async () => {
|
|
35
|
+
await common.teardown()
|
|
36
|
+
})
|
|
37
|
+
|
|
38
|
+
it('has a protocol string', () => {
|
|
39
|
+
expect(crypto.protocol).to.exist()
|
|
40
|
+
expect(crypto.protocol).to.be.a('string')
|
|
41
|
+
})
|
|
42
|
+
|
|
43
|
+
it('it wraps the provided duplex connection', async () => {
|
|
44
|
+
const [localConn, remoteConn] = createMaConnPair()
|
|
45
|
+
|
|
46
|
+
const [
|
|
47
|
+
inboundResult,
|
|
48
|
+
outboundResult
|
|
49
|
+
] = await Promise.all([
|
|
50
|
+
crypto.secureInbound(remotePeer, localConn),
|
|
51
|
+
crypto.secureOutbound(localPeer, remoteConn, remotePeer)
|
|
52
|
+
])
|
|
53
|
+
|
|
54
|
+
// Echo server
|
|
55
|
+
void pipe(inboundResult.conn, inboundResult.conn)
|
|
56
|
+
|
|
57
|
+
// Send some data and collect the result
|
|
58
|
+
const input = uint8ArrayFromString('data to encrypt')
|
|
59
|
+
const result = await pipe(
|
|
60
|
+
[input],
|
|
61
|
+
outboundResult.conn,
|
|
62
|
+
async (source) => all(source)
|
|
63
|
+
)
|
|
64
|
+
|
|
65
|
+
expect(result).to.eql([input])
|
|
66
|
+
})
|
|
67
|
+
|
|
68
|
+
it('should return the remote peer id', async () => {
|
|
69
|
+
const [localConn, remoteConn] = createMaConnPair()
|
|
70
|
+
|
|
71
|
+
const [
|
|
72
|
+
inboundResult,
|
|
73
|
+
outboundResult
|
|
74
|
+
] = await Promise.all([
|
|
75
|
+
crypto.secureInbound(remotePeer, localConn),
|
|
76
|
+
crypto.secureOutbound(localPeer, remoteConn, remotePeer)
|
|
77
|
+
])
|
|
78
|
+
|
|
79
|
+
// Inbound should return the initiator (local) peer
|
|
80
|
+
expect(inboundResult.remotePeer.toBytes()).to.equalBytes(localPeer.toBytes())
|
|
81
|
+
// Outbound should return the receiver (remote) peer
|
|
82
|
+
expect(outboundResult.remotePeer.toBytes()).to.equalBytes(remotePeer.toBytes())
|
|
83
|
+
})
|
|
84
|
+
|
|
85
|
+
it('inbound connections should verify peer integrity if known', async () => {
|
|
86
|
+
const [localConn, remoteConn] = createMaConnPair()
|
|
87
|
+
|
|
88
|
+
await Promise.all([
|
|
89
|
+
crypto.secureInbound(remotePeer, localConn, mitmPeer),
|
|
90
|
+
crypto.secureOutbound(localPeer, remoteConn, remotePeer)
|
|
91
|
+
]).then(() => expect.fail(), (err) => {
|
|
92
|
+
expect(err).to.exist()
|
|
93
|
+
expect(err).to.have.property('code', UnexpectedPeerError.code)
|
|
94
|
+
})
|
|
95
|
+
})
|
|
96
|
+
})
|
|
97
|
+
}
|