mirror of
https://github.com/fluencelabs/js-libp2p-websockets
synced 2025-04-25 16:12:33 +00:00
test: add interface tests
License: MIT Signed-off-by: Alan Shaw <alan.shaw@protocol.ai>
This commit is contained in:
parent
1b9c591da6
commit
f674122b6f
11
.aegir.js
11
.aegir.js
@ -1,21 +1,24 @@
|
|||||||
'use strict'
|
'use strict'
|
||||||
|
|
||||||
const multiaddr = require('multiaddr')
|
const multiaddr = require('multiaddr')
|
||||||
const pull = require('pull-stream')
|
const pipe = require('it-pipe')
|
||||||
|
|
||||||
const WS = require('./src')
|
const WS = require('./src')
|
||||||
|
|
||||||
let listener
|
let listener
|
||||||
|
|
||||||
function boot (done) {
|
function boot (done) {
|
||||||
|
console.log('boot!')
|
||||||
const ws = new WS()
|
const ws = new WS()
|
||||||
const ma = multiaddr('/ip4/127.0.0.1/tcp/9095/ws')
|
const ma = multiaddr('/ip4/127.0.0.1/tcp/9095/ws')
|
||||||
listener = ws.createListener((conn) => pull(conn, conn))
|
listener = ws.createListener(conn => pipe(conn, conn))
|
||||||
listener.listen(ma, done)
|
listener.listen(ma).then(() => done()).catch(done)
|
||||||
|
listener.on('error', console.error)
|
||||||
}
|
}
|
||||||
|
|
||||||
function shutdown (done) {
|
function shutdown (done) {
|
||||||
listener.close(done)
|
console.log('shutdown')
|
||||||
|
listener.close().then(done).catch(done)
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
|
@ -52,7 +52,7 @@
|
|||||||
"aegir": "^18.0.3",
|
"aegir": "^18.0.3",
|
||||||
"chai": "^4.1.2",
|
"chai": "^4.1.2",
|
||||||
"dirty-chai": "^2.0.1",
|
"dirty-chai": "^2.0.1",
|
||||||
"interface-transport": "~0.3.6",
|
"interface-transport": "github:libp2p/interface-transport#feat/async-await",
|
||||||
"it-goodbye": "^1.0.0",
|
"it-goodbye": "^1.0.0",
|
||||||
"it-pipe": "^1.0.0",
|
"it-pipe": "^1.0.0",
|
||||||
"multiaddr": "^6.0.3",
|
"multiaddr": "^6.0.3",
|
||||||
|
@ -12,10 +12,10 @@ module.exports = (options, handler) => {
|
|||||||
|
|
||||||
options = options || {}
|
options = options || {}
|
||||||
|
|
||||||
const server = createServer(options, socket => {
|
const server = createServer(options, handler ? socket => {
|
||||||
socket.getObservedAddrs = () => []
|
socket.getObservedAddrs = () => []
|
||||||
handler(socket)
|
handler(socket)
|
||||||
})
|
} : null)
|
||||||
|
|
||||||
let listeningMultiaddr
|
let listeningMultiaddr
|
||||||
|
|
||||||
|
81
test/adapter/browser.js
Normal file
81
test/adapter/browser.js
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
/* eslint-env mocha */
|
||||||
|
'use strict'
|
||||||
|
|
||||||
|
const chai = require('chai')
|
||||||
|
const dirtyChai = require('dirty-chai')
|
||||||
|
const expect = chai.expect
|
||||||
|
chai.use(dirtyChai)
|
||||||
|
|
||||||
|
const multiaddr = require('multiaddr')
|
||||||
|
const pull = require('pull-stream')
|
||||||
|
const goodbye = require('pull-goodbye')
|
||||||
|
|
||||||
|
const WS = require('../../src/adapter')
|
||||||
|
|
||||||
|
describe('adapter libp2p-websockets', () => {
|
||||||
|
const ma = multiaddr('/ip4/127.0.0.1/tcp/9095/ws')
|
||||||
|
let ws
|
||||||
|
let conn
|
||||||
|
|
||||||
|
beforeEach((done) => {
|
||||||
|
ws = new WS()
|
||||||
|
expect(ws).to.exist()
|
||||||
|
conn = ws.dial(ma, (err, res) => {
|
||||||
|
expect(err).to.not.exist()
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
it('echo', (done) => {
|
||||||
|
const message = 'Hello World!'
|
||||||
|
|
||||||
|
const s = goodbye({
|
||||||
|
source: pull.values([message]),
|
||||||
|
sink: pull.collect((err, results) => {
|
||||||
|
expect(err).to.not.exist()
|
||||||
|
expect(results).to.eql([message])
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
pull(s, conn, s)
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('stress', () => {
|
||||||
|
it('one big write', (done) => {
|
||||||
|
const rawMessage = Buffer.allocUnsafe(1000000).fill('a')
|
||||||
|
|
||||||
|
const s = goodbye({
|
||||||
|
source: pull.values([rawMessage]),
|
||||||
|
sink: pull.collect((err, results) => {
|
||||||
|
expect(err).to.not.exist()
|
||||||
|
expect(results).to.eql([rawMessage])
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
pull(s, conn, s)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('many writes', function (done) {
|
||||||
|
this.timeout(100000)
|
||||||
|
const s = goodbye({
|
||||||
|
source: pull(
|
||||||
|
pull.infinite(),
|
||||||
|
pull.take(20000),
|
||||||
|
pull.map((val) => Buffer.from(val.toString()))
|
||||||
|
),
|
||||||
|
sink: pull.collect((err, result) => {
|
||||||
|
expect(err).to.not.exist()
|
||||||
|
expect(result).to.have.length(20000)
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
pull(s, conn, s)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
it('.createServer throws in browser', () => {
|
||||||
|
expect(new WS().createListener).to.throw()
|
||||||
|
})
|
@ -1,2 +1,4 @@
|
|||||||
|
'use strict'
|
||||||
|
|
||||||
require('./compliance.node')
|
require('./compliance.node')
|
||||||
require('./node')
|
require('./node')
|
||||||
|
@ -7,71 +7,57 @@ const expect = chai.expect
|
|||||||
chai.use(dirtyChai)
|
chai.use(dirtyChai)
|
||||||
|
|
||||||
const multiaddr = require('multiaddr')
|
const multiaddr = require('multiaddr')
|
||||||
const pull = require('pull-stream')
|
const pipe = require('it-pipe')
|
||||||
const goodbye = require('pull-goodbye')
|
const goodbye = require('it-goodbye')
|
||||||
|
const { collect, take } = require('streaming-iterables')
|
||||||
|
|
||||||
const WS = require('../src')
|
const WS = require('../src')
|
||||||
|
|
||||||
|
// require('./adapter/browser')
|
||||||
|
|
||||||
describe('libp2p-websockets', () => {
|
describe('libp2p-websockets', () => {
|
||||||
const ma = multiaddr('/ip4/127.0.0.1/tcp/9095/ws')
|
const ma = multiaddr('/ip4/127.0.0.1/tcp/9095/ws')
|
||||||
let ws
|
let ws
|
||||||
let conn
|
let conn
|
||||||
|
|
||||||
beforeEach((done) => {
|
beforeEach(async () => {
|
||||||
ws = new WS()
|
ws = new WS()
|
||||||
expect(ws).to.exist()
|
conn = await ws.dial(ma)
|
||||||
conn = ws.dial(ma, (err, res) => {
|
|
||||||
expect(err).to.not.exist()
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
})
|
})
|
||||||
|
|
||||||
it('echo', (done) => {
|
it('echo', async () => {
|
||||||
const message = 'Hello World!'
|
const message = 'Hello World!'
|
||||||
|
const s = goodbye({ source: [message], sink: collect })
|
||||||
|
|
||||||
const s = goodbye({
|
const results = await pipe(s, conn, s)
|
||||||
source: pull.values([message]),
|
|
||||||
sink: pull.collect((err, results) => {
|
|
||||||
expect(err).to.not.exist()
|
|
||||||
expect(results).to.eql([message])
|
expect(results).to.eql([message])
|
||||||
done()
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
pull(s, conn, s)
|
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('stress', () => {
|
describe('stress', () => {
|
||||||
it('one big write', (done) => {
|
it('one big write', async () => {
|
||||||
const rawMessage = Buffer.allocUnsafe(1000000).fill('a')
|
const rawMessage = Buffer.allocUnsafe(1000000).fill('a')
|
||||||
|
|
||||||
const s = goodbye({
|
const s = goodbye({ source: [rawMessage], sink: collect })
|
||||||
source: pull.values([rawMessage]),
|
|
||||||
sink: pull.collect((err, results) => {
|
const results = await pipe(s, conn, s)
|
||||||
expect(err).to.not.exist()
|
|
||||||
expect(results).to.eql([rawMessage])
|
expect(results).to.eql([rawMessage])
|
||||||
done()
|
|
||||||
})
|
|
||||||
})
|
|
||||||
pull(s, conn, s)
|
|
||||||
})
|
})
|
||||||
|
|
||||||
it('many writes', function (done) {
|
it('many writes', async function () {
|
||||||
this.timeout(10000)
|
this.timeout(100000)
|
||||||
const s = goodbye({
|
const s = goodbye({
|
||||||
source: pull(
|
source: pipe(
|
||||||
pull.infinite(),
|
{
|
||||||
pull.take(1000),
|
[Symbol.iterator] () { return this },
|
||||||
pull.map((val) => Buffer.from(val.toString()))
|
next: () => ({ done: false, value: Buffer.from(Math.random().toString()) })
|
||||||
|
},
|
||||||
|
take(20000)
|
||||||
),
|
),
|
||||||
sink: pull.collect((err, result) => {
|
sink: collect
|
||||||
expect(err).to.not.exist()
|
|
||||||
expect(result).to.have.length(1000)
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
})
|
})
|
||||||
|
|
||||||
pull(s, conn, s)
|
const result = await pipe(s, conn, s)
|
||||||
|
expect(result).to.have.length(20000)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
@ -5,20 +5,18 @@ const tests = require('interface-transport')
|
|||||||
const multiaddr = require('multiaddr')
|
const multiaddr = require('multiaddr')
|
||||||
const WS = require('../src')
|
const WS = require('../src')
|
||||||
|
|
||||||
describe('compliance', () => {
|
describe('adapter compliance', () => {
|
||||||
tests({
|
tests({
|
||||||
setup (callback) {
|
async setup () {
|
||||||
let ws = new WS()
|
const ws = new WS()
|
||||||
const addrs = [
|
const addrs = [
|
||||||
multiaddr('/ip4/127.0.0.1/tcp/9091/ws'),
|
multiaddr('/ip4/127.0.0.1/tcp/9091/ws'),
|
||||||
multiaddr('/ip4/127.0.0.1/tcp/9092/wss'),
|
multiaddr('/ip4/127.0.0.1/tcp/9092/wss'),
|
||||||
multiaddr('/dns4/ipfs.io/tcp/9092/ws'),
|
multiaddr('/dns4/ipfs.io/tcp/9092/ws'),
|
||||||
multiaddr('/dns4/ipfs.io/tcp/9092/wss')
|
multiaddr('/dns4/ipfs.io/tcp/9092/wss')
|
||||||
]
|
]
|
||||||
callback(null, ws, addrs)
|
return { transport: ws, addrs }
|
||||||
},
|
},
|
||||||
teardown (callback) {
|
async teardown () {}
|
||||||
callback()
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
@ -13,7 +13,7 @@ const pipe = require('it-pipe')
|
|||||||
|
|
||||||
const WS = require('../src')
|
const WS = require('../src')
|
||||||
|
|
||||||
// require('./compliance.node')
|
require('./compliance.node')
|
||||||
|
|
||||||
describe('instantiate the transport', () => {
|
describe('instantiate the transport', () => {
|
||||||
it('create', () => {
|
it('create', () => {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user