mirror of
https://github.com/fluencelabs/js-libp2p
synced 2025-04-01 15:21:04 +00:00
202 lines
5.2 KiB
JavaScript
202 lines
5.2 KiB
JavaScript
/* eslint max-nested-callbacks: ["error", 8] */
|
|
/* eslint-env mocha */
|
|
'use strict'
|
|
|
|
const chai = require('chai')
|
|
chai.use(require('dirty-chai'))
|
|
const expect = chai.expect
|
|
const PeerInfo = require('peer-info')
|
|
const PeerId = require('peer-id')
|
|
const pull = require('pull-stream')
|
|
const goodbye = require('pull-goodbye')
|
|
const serializer = require('pull-serializer')
|
|
const Buffer = require('safe-buffer').Buffer
|
|
|
|
const Node = require('./browser-bundle')
|
|
const rawPeer = require('./peer.json')
|
|
|
|
describe('libp2p-ipfs-browser (websockets only)', () => {
|
|
let peerB
|
|
let nodeA
|
|
|
|
before((done) => {
|
|
const ma = '/ip4/127.0.0.1/tcp/9200/ws/ipfs/' + rawPeer.id
|
|
|
|
PeerId.createFromPrivKey(rawPeer.privKey, (err, id) => {
|
|
if (err) {
|
|
return done(err)
|
|
}
|
|
|
|
peerB = new PeerInfo(id)
|
|
peerB.multiaddrs.add(ma)
|
|
done()
|
|
})
|
|
})
|
|
|
|
after((done) => nodeA.stop(done))
|
|
|
|
it('create libp2pNode', (done) => {
|
|
PeerInfo.create((err, peerInfo) => {
|
|
expect(err).to.not.exist()
|
|
peerInfo.multiaddrs.add('/ip4/0.0.0.0/tcp/0')
|
|
|
|
nodeA = new Node(peerInfo)
|
|
done()
|
|
})
|
|
})
|
|
|
|
it('create libp2pNode with multiplex only', (done) => {
|
|
PeerInfo.create((err, peerInfo) => {
|
|
expect(err).to.not.exist()
|
|
|
|
const b = new Node(peerInfo, null, { muxer: ['multiplex'] })
|
|
expect(b.modules.connection.muxer).to.eql([require('libp2p-multiplex')])
|
|
done()
|
|
})
|
|
})
|
|
|
|
it('start libp2pNode', (done) => {
|
|
nodeA.start(done)
|
|
})
|
|
|
|
// General connectivity tests
|
|
|
|
it('libp2p.dial using Multiaddr nodeA to nodeB', (done) => {
|
|
nodeA.dial(peerB.multiaddrs.toArray()[0], (err) => {
|
|
expect(err).to.not.exist()
|
|
|
|
setTimeout(check, 500) // Some time for Identify to finish
|
|
|
|
function check () {
|
|
const peers = nodeA.peerBook.getAll()
|
|
expect(Object.keys(peers)).to.have.length(1)
|
|
done()
|
|
}
|
|
})
|
|
})
|
|
|
|
it('libp2p.dial using Multiaddr on Protocol nodeA to nodeB', (done) => {
|
|
nodeA.dial(peerB.multiaddrs.toArray()[0], '/echo/1.0.0', (err, conn) => {
|
|
expect(err).to.not.exist()
|
|
|
|
const peers = nodeA.peerBook.getAll()
|
|
expect(Object.keys(peers)).to.have.length(1)
|
|
|
|
pull(
|
|
pull.values([Buffer.from('hey')]),
|
|
conn,
|
|
pull.collect((err, data) => {
|
|
expect(err).to.not.exist()
|
|
expect(data).to.eql([Buffer.from('hey')])
|
|
done()
|
|
})
|
|
)
|
|
})
|
|
})
|
|
|
|
it('libp2p.hangUp using Multiaddr nodeA to nodeB', (done) => {
|
|
nodeA.hangUp(peerB.multiaddrs.toArray()[0], (err) => {
|
|
expect(err).to.not.exist()
|
|
|
|
setTimeout(check, 500)
|
|
|
|
function check () {
|
|
const peers = nodeA.peerBook.getAll()
|
|
expect(Object.keys(peers)).to.have.length(1)
|
|
expect(Object.keys(nodeA.swarm.muxedConns)).to.have.length(0)
|
|
done()
|
|
}
|
|
})
|
|
})
|
|
|
|
it('libp2p.dial using PeerInfo nodeA to nodeB', (done) => {
|
|
nodeA.dial(peerB, (err) => {
|
|
expect(err).to.not.exist()
|
|
|
|
setTimeout(check, 500) // Some time for Identify to finish
|
|
|
|
function check () {
|
|
const peers = nodeA.peerBook.getAll()
|
|
expect(Object.keys(peers)).to.have.length(1)
|
|
done()
|
|
}
|
|
})
|
|
})
|
|
|
|
it('libp2p.dial using PeerInfo on Protocol nodeA to nodeB', (done) => {
|
|
nodeA.dial(peerB, '/echo/1.0.0', (err, conn) => {
|
|
expect(err).to.not.exist()
|
|
const peers = nodeA.peerBook.getAll()
|
|
expect(err).to.not.exist()
|
|
expect(Object.keys(peers)).to.have.length(1)
|
|
|
|
pull(
|
|
pull.values([Buffer.from('hey')]),
|
|
conn,
|
|
pull.collect((err, data) => {
|
|
expect(err).to.not.exist()
|
|
expect(data).to.eql([Buffer.from('hey')])
|
|
done()
|
|
})
|
|
)
|
|
})
|
|
})
|
|
|
|
it('libp2p.hangUp using PeerInfo nodeA to nodeB', (done) => {
|
|
nodeA.hangUp(peerB, (err) => {
|
|
expect(err).to.not.exist()
|
|
setTimeout(check, 500)
|
|
|
|
function check () {
|
|
const peers = nodeA.peerBook.getAll()
|
|
expect(err).to.not.exist()
|
|
expect(Object.keys(peers)).to.have.length(1)
|
|
expect(Object.keys(nodeA.swarm.muxedConns)).to.have.length(0)
|
|
done()
|
|
}
|
|
})
|
|
})
|
|
|
|
describe('stress', () => {
|
|
it('one big write', (done) => {
|
|
nodeA.dial(peerB, '/echo/1.0.0', (err, conn) => {
|
|
expect(err).to.not.exist()
|
|
const rawMessage = Buffer.alloc(100000)
|
|
rawMessage.fill('a')
|
|
|
|
const s = serializer(goodbye({
|
|
source: pull.values([rawMessage]),
|
|
sink: pull.collect((err, results) => {
|
|
expect(err).to.not.exist()
|
|
expect(results).to.have.length(1)
|
|
expect(Buffer.from(results[0])).to.have.length(rawMessage.length)
|
|
done()
|
|
})
|
|
}))
|
|
pull(s, conn, s)
|
|
})
|
|
})
|
|
|
|
it('many writes', (done) => {
|
|
nodeA.dial(peerB, '/echo/1.0.0', (err, conn) => {
|
|
expect(err).to.not.exist()
|
|
|
|
const s = serializer(goodbye({
|
|
source: pull(
|
|
pull.infinite(),
|
|
pull.take(1000),
|
|
pull.map((val) => Buffer.from(val.toString()))
|
|
),
|
|
sink: pull.collect((err, result) => {
|
|
expect(err).to.not.exist()
|
|
expect(result).to.have.length(1000)
|
|
done()
|
|
})
|
|
}))
|
|
|
|
pull(s, conn, s)
|
|
})
|
|
})
|
|
})
|
|
})
|