109 lines
3.1 KiB
JavaScript
109 lines
3.1 KiB
JavaScript
const fixture = require('./fixture/namespace')
|
|
const request = require('request')
|
|
const io = require('socket.io-client')
|
|
|
|
describe('authorizer with namespaces', () => {
|
|
//start and stop the server
|
|
before(fixture.start)
|
|
after(fixture.stop)
|
|
|
|
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())
|
|
.on('error', done)
|
|
})
|
|
|
|
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'
|
|
)
|
|
)
|
|
)
|
|
})
|
|
|
|
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)
|
|
}
|
|
})
|
|
})
|
|
})
|
|
|
|
describe('when the user is logged in', () => {
|
|
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 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 })
|
|
})
|
|
})
|
|
|
|
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())
|
|
})
|
|
})
|
|
})
|