This repository has been archived on 2024-11-11. You can view files and clone it, but cannot push or open issues or pull requests.
socketio-jwt/test/authorizer_namespaces.test.js

91 lines
2.9 KiB
JavaScript
Raw Normal View History

const fixture = require('./fixture/namespace');
const request = require('request');
const io = require('socket.io-client');
2015-08-31 16:04:04 +02:00
describe('authorizer with namespaces', () => {
2015-08-31 16:04:04 +02:00
//start and stop the server
before(fixture.start);
after(fixture.stop);
describe('when the user is not logged in', () => {
2015-08-31 16:04:04 +02:00
it('should be able to connect to the default namespace', (done) => {
io.connect('http://localhost:9000')
.once('hi', () => done())
.on('error', done);
2015-08-31 16:04:04 +02:00
});
it('should not be able to connect to the admin namespace', (done) => {
io.connect('http://localhost:9000/admin')
.once('disconnect', () => done())
.once('hi admin', () => done(new Error('unauthenticated client was able to connect to the admin namespace')));
2015-08-31 16:04:04 +02:00
});
it('should not be able to connect to the admin_hs namespace', (done) => {
io.connect('http://localhost:9000/admin_hs')
.once('hi admin', () => done(new Error('unauthenticated client was able to connect to the admin_hs namespace')))
.on('error', (err) => {
if (err === 'Invalid namespace') { // SocketIO throws this error, if auth failed
return;
} else if (err && err.type == 'UnauthorizedError') {
done();
} else {
done(err);
}
});
});
2015-08-31 16:04:04 +02:00
});
describe('when the user is logged in', () => {
2015-08-31 16:04:04 +02:00
beforeEach((done) => {
2015-08-31 16:04:04 +02:00
request.post({
url: 'http://localhost:9000/login',
form: { username: 'jose', password: 'Pa123' },
json: true
}, (err, resp, body) => {
2015-08-31 16:04:04 +02:00
this.token = body.token;
done();
});
2015-08-31 16:04:04 +02:00
});
it('should do the authentication and connect', (done) => {
io.connect('http://localhost:9000/admin', { forceNew: true })
.on('hi admin', () => done())
.emit('authenticate', { token: this.token });
});
it('should do the authentication and connect without "forceNew"', (done) => {
io.connect('http://localhost:9000/admin', { forceNew: false })
.on('hi admin', () => done())
.emit('authenticate', { token: this.token });
2015-08-31 16:04:04 +02:00
});
});
describe('when the user is logged in via handshake', () => {
beforeEach((done) => {
request.post({
url: 'http://localhost:9000/login',
form: { username: 'jose', password: 'Pa123' },
json: true
}, (err, resp, body) => {
this.token = body.token;
done();
});
});
it('should do the handshake and connect', (done) => {
io.connect('http://localhost:9000/admin_hs', { forceNew: true, query: 'token=' + this.token })
.once('hi admin', () => done());
});
it('should do the handshake and connect without "forceNew"', (done) => {
io.connect('http://localhost:9000/admin_hs', { forceNew: false, query: 'token=' + this.token })
.once('hi admin', () => done());
});
});
2015-08-31 16:04:04 +02:00
});