test: add interface tests

License: MIT
Signed-off-by: Alan Shaw <alan.shaw@protocol.ai>
This commit is contained in:
Alan Shaw 2019-04-03 10:38:35 +01:00
parent 1b9c591da6
commit f674122b6f
No known key found for this signature in database
GPG Key ID: AFC4442246B75B6F
8 changed files with 126 additions and 56 deletions

View File

@ -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 = {

View File

@ -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",

View File

@ -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
View 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()
})

View File

@ -1,2 +1,4 @@
'use strict'
require('./compliance.node') require('./compliance.node')
require('./node') require('./node')

View File

@ -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]), expect(results).to.eql([message])
sink: pull.collect((err, results) => {
expect(err).to.not.exist()
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)
}) })
}) })
}) })

View File

@ -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()
}
}) })
}) })

View File

@ -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', () => {