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

109 lines
3.1 KiB
JavaScript
Raw Normal View History

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