I have write a socket.io
server, and I'm using mocha
to test it. But the the I cannot connect to server at the second time.
Here is my code, it's written by coffee script.
server = require('http').Server()
io = require('socket.io').listen(server)
io.on 'connection', (socket) ->
console.log socket.id
server.listen(3000)
chai = require 'chai'
io = require 'socket.io-client'
should = chai.should()
describe 'Socket', ()->
url = 'http://0.0.0.0:3000'
it 'should be connected', (done) ->
client = io.connect(url)
client.on 'connect', (data) ->
console.log(data)
client.socket.connected.should.equal(true)
client.disconnect()
done()
describe 'User', ()->
url = 'http://0.0.0.0:3000'
it 'should be connected', (done) ->
client = io.connect(url)
client.on 'connect', (data) ->
console.log(data)
client.socket.connected.should.equal(true)
client.disconnect()
done()
info - socket.io started
debug - client authorized
info - handshake authorized b_2h4dCr-YfD-7-Iw9Hl
debug - setting request GET /socket.io/1/websocket/b_2h4dCr-YfD-7-Iw9Hl
debug - set heartbeat interval for client b_2h4dCr-YfD-7-Iw9Hl
debug - client authorized for
debug - websocket writing 1::
b_2h4dCr-YfD-7-Iw9Hl
debug - got disconnection packet
info - transport end by forced client disconnection
debug - websocket writing 0::
info - transport end (booted)
debug - set close timeout for client b_2h4dCr-YfD-7-Iw9Hl
debug - cleared close timeout for client b_2h4dCr-YfD-7-Iw9Hl
debug - cleared heartbeat interval for client b_2h4dCr-YfD-7-Iw9Hl
debug - discarding transport
Socket
◦ should be connected: undefined
✓ should be connected (75ms)
User
1) should be connected
1 passing (2 seconds)
1 failing
1) User should be connected:
Error: timeout of 2000ms exceeded
at null.<anonymous> (/home/wangbin/webapp/chat_server/node_modules/mocha/lib/runnable.js:165:14)
at Timer.listOnTimeout [as ontimeout] (timers.js:110:15)
When you want to create new session - set 'force new connection' option for .connect method
io.connect(socketAddress,{'force new connection': true});
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With