add noqs method

This commit is contained in:
José F. Romaniello
2014-01-13 18:41:10 -03:00
parent 14a34ae380
commit b0f4354ecb
5 changed files with 148 additions and 10 deletions

View File

@ -0,0 +1,67 @@
var fixture = require('./fixture');
var request = require('request');
var io = require('socket.io-client');
describe('authorizer without querystring', function () {
//start and stop the server
before(function (done) {
fixture.start({
noQS: true
} , done);
});
after(fixture.stop);
describe('when the user is not logged in', function () {
it('should close the connection after a timeout if no auth message is received', function (done){
var socket = io.connect('http://localhost:9000');
socket.on('disconnect', function () {
done();
});
});
it('should not respond echo', function (done){
var socket = io.connect('http://localhost:9000', {
'force new connection':true,
});
socket.on('echo-response', function () {
done(new Error('this should not happen'));
}).emit('echo', { hi: 123 });
setTimeout(done, 1200);
});
});
describe('when the user is logged in', function() {
beforeEach(function (done) {
request.post({
url: 'http://localhost:9000/login',
form: { username: 'jose', password: 'Pa123' },
json: true
}, function (err, resp, body) {
this.token = body.token;
done();
}.bind(this));
});
it('should do the handshake and connect', function (done){
var socket = io.connect('http://localhost:9000', {
'force new connection':true,
});
var token = this.token;
socket.on('connect', function(){
console.log('connected');
socket.on('echo-response', done)
.on('authenticated', function () {
socket.emit('echo');
}).emit('authenticate', { token: token });
});
});
});
});

View File

@ -17,7 +17,10 @@ exports.start = function (options, callback) {
options = {};
}
options = xtend({ secret: 'aaafoo super sercret'}, options);
options = xtend({
secret: 'aaafoo super sercret',
timeout: 1000
}, options);
var app = express();
@ -45,13 +48,23 @@ exports.start = function (options, callback) {
var sio = socketIo.listen(server);
sio.configure(function(){
this.set('authorization', socketio_jwt.authorize(options));
if (!options.noQS) {
this.set('authorization', socketio_jwt.authorize(options));
}
this.set('log level', 0);
});
sio.sockets.on('echo', function (m) {
sio.sockets.emit('echo-response', m);
});
if (!options.noQS) {
sio.sockets.on('echo', function (m) {
sio.sockets.emit('echo-response', m);
});
} else {
sio.sockets.on('connection', socketio_jwt.authorize(options, function (socket) {
socket.on('echo', function (m) {
socket.emit('echo-response', m);
});
}));
}
server.listen(9000, callback);
};

View File

@ -1,2 +1,3 @@
--require should
--reporter spec
--reporter spec
--timeout 15000