@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.
Files changed (176) hide show
  1. package/README.md +12 -3
  2. package/dist/src/connection/index.d.ts +5 -0
  3. package/dist/src/connection/index.d.ts.map +1 -0
  4. package/dist/src/connection/index.js +151 -0
  5. package/dist/src/connection/index.js.map +1 -0
  6. package/dist/src/connection-encryption/index.d.ts +5 -0
  7. package/dist/src/connection-encryption/index.d.ts.map +1 -0
  8. package/dist/src/connection-encryption/index.js +71 -0
  9. package/dist/src/connection-encryption/index.js.map +1 -0
  10. package/dist/src/connection-encryption/utils/index.d.ts +3 -0
  11. package/dist/src/connection-encryption/utils/index.d.ts.map +1 -0
  12. package/dist/src/connection-encryption/utils/index.js +18 -0
  13. package/dist/src/connection-encryption/utils/index.js.map +1 -0
  14. package/dist/src/index.d.ts +1 -1
  15. package/dist/src/index.d.ts.map +1 -1
  16. package/dist/src/mocks/connection-encrypter.d.ts +3 -0
  17. package/dist/src/mocks/connection-encrypter.d.ts.map +1 -0
  18. package/dist/src/mocks/connection-encrypter.js +98 -0
  19. package/dist/src/mocks/connection-encrypter.js.map +1 -0
  20. package/dist/src/mocks/connection-gater.d.ts +3 -0
  21. package/dist/src/mocks/connection-gater.d.ts.map +1 -0
  22. package/dist/src/mocks/connection-gater.js +17 -0
  23. package/dist/src/mocks/connection-gater.js.map +1 -0
  24. package/dist/src/mocks/connection-manager.d.ts +29 -0
  25. package/dist/src/mocks/connection-manager.d.ts.map +1 -0
  26. package/dist/src/mocks/connection-manager.js +145 -0
  27. package/dist/src/mocks/connection-manager.js.map +1 -0
  28. package/dist/src/mocks/connection.d.ts +32 -0
  29. package/dist/src/mocks/connection.d.ts.map +1 -0
  30. package/dist/src/mocks/connection.js +162 -0
  31. package/dist/src/mocks/connection.js.map +1 -0
  32. package/dist/src/mocks/duplex.d.ts +3 -0
  33. package/dist/src/mocks/duplex.d.ts.map +1 -0
  34. package/dist/src/mocks/duplex.js +9 -0
  35. package/dist/src/mocks/duplex.js.map +1 -0
  36. package/dist/src/mocks/index.d.ts +13 -0
  37. package/dist/src/mocks/index.d.ts.map +1 -0
  38. package/dist/src/mocks/index.js +11 -0
  39. package/dist/src/mocks/index.js.map +1 -0
  40. package/dist/src/mocks/metrics.d.ts +3 -0
  41. package/dist/src/mocks/metrics.d.ts.map +1 -0
  42. package/dist/src/mocks/metrics.js +115 -0
  43. package/dist/src/mocks/metrics.js.map +1 -0
  44. package/dist/src/mocks/multiaddr-connection.d.ts +17 -0
  45. package/dist/src/mocks/multiaddr-connection.d.ts.map +1 -0
  46. package/dist/src/mocks/multiaddr-connection.js +51 -0
  47. package/dist/src/mocks/multiaddr-connection.js.map +1 -0
  48. package/dist/src/mocks/muxer.d.ts +8 -0
  49. package/dist/src/mocks/muxer.d.ts.map +1 -0
  50. package/dist/src/mocks/muxer.js +341 -0
  51. package/dist/src/mocks/muxer.js.map +1 -0
  52. package/dist/src/mocks/peer-discovery.d.ts +22 -0
  53. package/dist/src/mocks/peer-discovery.d.ts.map +1 -0
  54. package/dist/src/mocks/peer-discovery.js +47 -0
  55. package/dist/src/mocks/peer-discovery.js.map +1 -0
  56. package/dist/src/mocks/registrar.d.ts +18 -0
  57. package/dist/src/mocks/registrar.d.ts.map +1 -0
  58. package/dist/src/mocks/registrar.js +66 -0
  59. package/dist/src/mocks/registrar.js.map +1 -0
  60. package/dist/src/mocks/upgrader.d.ts +10 -0
  61. package/dist/src/mocks/upgrader.d.ts.map +1 -0
  62. package/dist/src/mocks/upgrader.js +31 -0
  63. package/dist/src/mocks/upgrader.js.map +1 -0
  64. package/dist/src/peer-discovery/index.d.ts +5 -0
  65. package/dist/src/peer-discovery/index.d.ts.map +1 -0
  66. package/dist/src/peer-discovery/index.js +66 -0
  67. package/dist/src/peer-discovery/index.js.map +1 -0
  68. package/dist/src/pubsub/api.d.ts +6 -0
  69. package/dist/src/pubsub/api.d.ts.map +1 -0
  70. package/dist/src/pubsub/api.js +87 -0
  71. package/dist/src/pubsub/api.js.map +1 -0
  72. package/dist/src/pubsub/connection-handlers.d.ts +6 -0
  73. package/dist/src/pubsub/connection-handlers.d.ts.map +1 -0
  74. package/dist/src/pubsub/connection-handlers.js +329 -0
  75. package/dist/src/pubsub/connection-handlers.js.map +1 -0
  76. package/dist/src/pubsub/emit-self.d.ts +6 -0
  77. package/dist/src/pubsub/emit-self.d.ts.map +1 -0
  78. package/dist/src/pubsub/emit-self.js +80 -0
  79. package/dist/src/pubsub/emit-self.js.map +1 -0
  80. package/dist/src/pubsub/index.d.ts +18 -0
  81. package/dist/src/pubsub/index.d.ts.map +1 -0
  82. package/dist/src/pubsub/index.js +17 -0
  83. package/dist/src/pubsub/index.js.map +1 -0
  84. package/dist/src/pubsub/messages.d.ts +6 -0
  85. package/dist/src/pubsub/messages.d.ts.map +1 -0
  86. package/dist/src/pubsub/messages.js +48 -0
  87. package/dist/src/pubsub/messages.js.map +1 -0
  88. package/dist/src/pubsub/multiple-nodes.d.ts +6 -0
  89. package/dist/src/pubsub/multiple-nodes.d.ts.map +1 -0
  90. package/dist/src/pubsub/multiple-nodes.js +350 -0
  91. package/dist/src/pubsub/multiple-nodes.js.map +1 -0
  92. package/dist/src/pubsub/two-nodes.d.ts +6 -0
  93. package/dist/src/pubsub/two-nodes.d.ts.map +1 -0
  94. package/dist/src/pubsub/two-nodes.js +217 -0
  95. package/dist/src/pubsub/two-nodes.js.map +1 -0
  96. package/dist/src/pubsub/utils.d.ts +6 -0
  97. package/dist/src/pubsub/utils.d.ts.map +1 -0
  98. package/dist/src/pubsub/utils.js +22 -0
  99. package/dist/src/pubsub/utils.js.map +1 -0
  100. package/dist/src/stream-muxer/base-test.d.ts +5 -0
  101. package/dist/src/stream-muxer/base-test.d.ts.map +1 -0
  102. package/dist/src/stream-muxer/base-test.js +153 -0
  103. package/dist/src/stream-muxer/base-test.js.map +1 -0
  104. package/dist/src/stream-muxer/close-test.d.ts +5 -0
  105. package/dist/src/stream-muxer/close-test.d.ts.map +1 -0
  106. package/dist/src/stream-muxer/close-test.js +269 -0
  107. package/dist/src/stream-muxer/close-test.js.map +1 -0
  108. package/dist/src/stream-muxer/index.d.ts +5 -0
  109. package/dist/src/stream-muxer/index.d.ts.map +1 -0
  110. package/dist/src/stream-muxer/index.js +13 -0
  111. package/dist/src/stream-muxer/index.js.map +1 -0
  112. package/dist/src/stream-muxer/mega-stress-test.d.ts +5 -0
  113. package/dist/src/stream-muxer/mega-stress-test.d.ts.map +1 -0
  114. package/dist/src/stream-muxer/mega-stress-test.js +11 -0
  115. package/dist/src/stream-muxer/mega-stress-test.js.map +1 -0
  116. package/dist/src/stream-muxer/spawner.d.ts +4 -0
  117. package/dist/src/stream-muxer/spawner.d.ts.map +1 -0
  118. package/dist/src/stream-muxer/spawner.js +36 -0
  119. package/dist/src/stream-muxer/spawner.js.map +1 -0
  120. package/dist/src/stream-muxer/stress-test.d.ts +5 -0
  121. package/dist/src/stream-muxer/stress-test.d.ts.map +1 -0
  122. package/dist/src/stream-muxer/stress-test.js +23 -0
  123. package/dist/src/stream-muxer/stress-test.js.map +1 -0
  124. package/dist/src/transport/dial-test.d.ts +5 -0
  125. package/dist/src/transport/dial-test.d.ts.map +1 -0
  126. package/dist/src/transport/dial-test.js +98 -0
  127. package/dist/src/transport/dial-test.js.map +1 -0
  128. package/dist/src/transport/filter-test.d.ts +5 -0
  129. package/dist/src/transport/filter-test.d.ts.map +1 -0
  130. package/dist/src/transport/filter-test.js +18 -0
  131. package/dist/src/transport/filter-test.js.map +1 -0
  132. package/dist/src/transport/index.d.ts +15 -0
  133. package/dist/src/transport/index.d.ts.map +1 -0
  134. package/dist/src/transport/index.js +11 -0
  135. package/dist/src/transport/index.js.map +1 -0
  136. package/dist/src/transport/listen-test.d.ts +5 -0
  137. package/dist/src/transport/listen-test.d.ts.map +1 -0
  138. package/dist/src/transport/listen-test.js +152 -0
  139. package/dist/src/transport/listen-test.js.map +1 -0
  140. package/package.json +71 -95
  141. package/src/connection/index.ts +184 -0
  142. package/src/connection-encryption/index.ts +97 -0
  143. package/src/connection-encryption/utils/index.ts +23 -0
  144. package/src/index.ts +1 -1
  145. package/src/mocks/connection-encrypter.ts +113 -0
  146. package/src/mocks/connection-gater.ts +18 -0
  147. package/src/mocks/connection-manager.ts +211 -0
  148. package/src/mocks/connection.ts +218 -0
  149. package/src/mocks/duplex.ts +10 -0
  150. package/src/mocks/index.ts +12 -0
  151. package/src/mocks/metrics.ts +162 -0
  152. package/src/mocks/multiaddr-connection.ts +67 -0
  153. package/src/mocks/muxer.ts +447 -0
  154. package/src/mocks/peer-discovery.ts +60 -0
  155. package/src/mocks/registrar.ts +88 -0
  156. package/src/mocks/upgrader.ts +49 -0
  157. package/src/peer-discovery/index.ts +90 -0
  158. package/src/pubsub/api.ts +114 -0
  159. package/src/pubsub/connection-handlers.ts +413 -0
  160. package/src/pubsub/emit-self.ts +99 -0
  161. package/src/pubsub/index.ts +34 -0
  162. package/src/pubsub/messages.ts +59 -0
  163. package/src/pubsub/multiple-nodes.ts +440 -0
  164. package/src/pubsub/two-nodes.ts +273 -0
  165. package/src/pubsub/utils.ts +29 -0
  166. package/src/stream-muxer/base-test.ts +196 -0
  167. package/src/stream-muxer/close-test.ts +346 -0
  168. package/src/stream-muxer/index.ts +15 -0
  169. package/src/stream-muxer/mega-stress-test.ts +14 -0
  170. package/src/stream-muxer/spawner.ts +54 -0
  171. package/src/stream-muxer/stress-test.ts +27 -0
  172. package/src/transport/dial-test.ts +124 -0
  173. package/src/transport/filter-test.ts +25 -0
  174. package/src/transport/index.ts +25 -0
  175. package/src/transport/listen-test.ts +191 -0
  176. 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,5 @@
1
+ import type { TransportTestFixtures } from './index.js';
2
+ import type { TestSetup } from '../index.js';
3
+ declare const _default: (common: TestSetup<TransportTestFixtures>) => void;
4
+ export default _default;
5
+ //# sourceMappingURL=listen-test.d.ts.map
@@ -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.6",
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-interfaces/tree/master/packages/interface-compliance-tests#readme",
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-interfaces.git"
9
+ "url": "git+https://github.com/libp2p/js-libp2p.git"
10
10
  },
11
11
  "bugs": {
12
- "url": "https://github.com/libp2p/js-libp2p-interfaces/issues"
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
- "release": "aegir release"
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
- "aegir": "^38.1.0"
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
+ }