2014-10-31 11:59:23 -04:00
|
|
|
expect = require('chai').expect
|
|
|
|
nock = require('nock')
|
|
|
|
server = require('./server')
|
|
|
|
config = require('../config')
|
2014-11-14 11:05:30 -04:00
|
|
|
token = require('../token/token')
|
2014-11-14 15:48:37 -04:00
|
|
|
mock = require('../../tests/utils/mock')
|
2014-11-14 11:05:30 -04:00
|
|
|
johnDoeFixture = require('../../tests/fixtures/johndoe.json')
|
2014-10-31 11:59:23 -04:00
|
|
|
|
2014-11-18 08:53:07 -04:00
|
|
|
TEST_URI = config.remoteUrl
|
2014-10-31 11:59:23 -04:00
|
|
|
|
|
|
|
URI =
|
|
|
|
ok: '/ok'
|
|
|
|
nojson: '/nojson'
|
2014-10-31 13:25:02 -04:00
|
|
|
error: '/error'
|
2014-10-31 11:59:23 -04:00
|
|
|
|
|
|
|
RESPONSE =
|
|
|
|
nojson: 'NO JSON RESPONSE'
|
|
|
|
|
|
|
|
STATUS =
|
|
|
|
ok: 'ok'
|
2014-10-31 13:25:02 -04:00
|
|
|
error: 'error'
|
2014-10-31 11:59:23 -04:00
|
|
|
|
|
|
|
METHODS = [
|
|
|
|
'GET'
|
|
|
|
'HEAD'
|
|
|
|
'POST'
|
|
|
|
'PUT'
|
|
|
|
'DELETE'
|
|
|
|
'PATCH'
|
|
|
|
]
|
|
|
|
|
2014-11-07 12:43:10 -04:00
|
|
|
describe 'Server:', ->
|
2014-10-31 11:59:23 -04:00
|
|
|
|
|
|
|
beforeEach ->
|
2014-10-31 13:25:02 -04:00
|
|
|
nock(TEST_URI).get(URI.nojson).reply(200, RESPONSE.nojson)
|
|
|
|
nock(TEST_URI).get(URI.error).reply(400, status: STATUS.error)
|
2014-10-31 11:59:23 -04:00
|
|
|
|
|
|
|
for method in METHODS
|
|
|
|
lowercaseMethod = method.toLowerCase()
|
2014-10-31 13:25:02 -04:00
|
|
|
nock(TEST_URI)[lowercaseMethod](URI.ok).reply(200, status: STATUS.ok)
|
2014-10-31 11:59:23 -04:00
|
|
|
|
2014-11-14 15:48:37 -04:00
|
|
|
mock.fs.init()
|
|
|
|
|
|
|
|
afterEach ->
|
|
|
|
mock.fs.restore()
|
|
|
|
|
2014-10-31 11:59:23 -04:00
|
|
|
describe '#request()', ->
|
|
|
|
|
|
|
|
it 'should make a real HTTP request', (done) ->
|
2014-11-18 09:59:19 -04:00
|
|
|
server.request {
|
|
|
|
method: 'GET'
|
|
|
|
url: URI.ok
|
|
|
|
}, (error, response) ->
|
2014-10-31 11:59:23 -04:00
|
|
|
return done(error) if error?
|
|
|
|
expect(response.body.status).to.equal(STATUS.ok)
|
|
|
|
expect(response.statusCode).to.equal(200)
|
|
|
|
done()
|
|
|
|
|
|
|
|
it 'should make a GET request if method is omitted', (done) ->
|
2014-11-18 09:59:19 -04:00
|
|
|
server.request {
|
|
|
|
url: URI.ok
|
|
|
|
}, (error, response) ->
|
2014-10-31 11:59:23 -04:00
|
|
|
return done(error) if error?
|
|
|
|
expect(response.request.method).to.equal('GET')
|
|
|
|
done()
|
|
|
|
|
|
|
|
checkRequestType = (type) ->
|
|
|
|
return (done) ->
|
2014-11-18 09:59:19 -04:00
|
|
|
server.request {
|
|
|
|
method: type
|
|
|
|
url: URI.ok
|
|
|
|
}, (error, response) ->
|
2014-10-31 11:59:23 -04:00
|
|
|
return done(error) if error?
|
|
|
|
expect(response.request.method).to.equal(type)
|
|
|
|
done()
|
|
|
|
|
|
|
|
for method in METHODS
|
|
|
|
it("should make a #{method} request if method is #{method}", checkRequestType(method))
|
|
|
|
|
|
|
|
it 'should get a raw response of response is not JSON', (done) ->
|
2014-11-18 09:59:19 -04:00
|
|
|
server.request {
|
|
|
|
method: 'GET'
|
|
|
|
url: URI.nojson
|
|
|
|
}, (error, response) ->
|
2014-10-31 11:59:23 -04:00
|
|
|
return done(error) if error?
|
|
|
|
expect(response.body).to.equal(RESPONSE.nojson)
|
|
|
|
done()
|
|
|
|
|
2014-11-14 11:53:46 -04:00
|
|
|
it 'should parse the body', (done) ->
|
2014-11-18 09:59:19 -04:00
|
|
|
server.request {
|
|
|
|
method: 'GET'
|
|
|
|
url: URI.ok
|
|
|
|
}, (error, response, body) ->
|
2014-11-14 11:53:46 -04:00
|
|
|
expect(error).to.not.exist
|
|
|
|
expect(body).to.be.an.object
|
|
|
|
expect(body).not.to.be.a.string
|
|
|
|
done()
|
|
|
|
|
2014-10-31 11:59:23 -04:00
|
|
|
it 'should be able to send data in the body', (done) ->
|
|
|
|
body = { hello: 'world' }
|
|
|
|
|
2014-11-18 09:59:19 -04:00
|
|
|
server.request {
|
|
|
|
method: 'POST'
|
|
|
|
url: URI.ok
|
|
|
|
json: body
|
|
|
|
}, (error, response) ->
|
2014-10-31 11:59:23 -04:00
|
|
|
return done(error) if error?
|
|
|
|
expect(response.request.body.toString()).to.equal(JSON.stringify(body))
|
|
|
|
done()
|
|
|
|
|
|
|
|
it 'should throw an error if method is unknown', (done) ->
|
2014-11-18 09:59:19 -04:00
|
|
|
server.request {
|
|
|
|
method: 'FOO'
|
|
|
|
url: URI.ok
|
|
|
|
}, (error, response) ->
|
2014-10-31 11:59:23 -04:00
|
|
|
expect(error).to.exist
|
|
|
|
expect(error).to.be.an.instanceof(Error)
|
|
|
|
done()
|
|
|
|
|
2014-10-31 13:25:02 -04:00
|
|
|
it 'should throw an error if the status code is >= 400', (done) ->
|
2014-11-18 09:59:19 -04:00
|
|
|
server.request {
|
|
|
|
method: 'GET'
|
|
|
|
url: URI.error
|
|
|
|
}, (error, response) ->
|
2014-10-31 13:25:02 -04:00
|
|
|
expect(error).to.exist
|
|
|
|
expect(error).to.be.an.instanceof(Error)
|
|
|
|
done()
|
|
|
|
|
2014-10-31 11:59:23 -04:00
|
|
|
checkRequestTypeWithoutBody = (type) ->
|
|
|
|
return (done) ->
|
|
|
|
lowercaseType = type.toLowerCase()
|
|
|
|
server[lowercaseType] URI.ok, (error, response) ->
|
|
|
|
return done(error) if error?
|
|
|
|
expect(response.request.method).to.equal(type)
|
|
|
|
done()
|
|
|
|
|
|
|
|
describe '#get()', ->
|
|
|
|
it('should be a facade to request()', checkRequestTypeWithoutBody('GET'))
|
|
|
|
|
|
|
|
describe '#head()', ->
|
|
|
|
it('should be a facade to request()', checkRequestTypeWithoutBody('HEAD'))
|
|
|
|
|
|
|
|
describe '#delete()', ->
|
|
|
|
it('should be a facade to request()', checkRequestTypeWithoutBody('DELETE'))
|
|
|
|
|
|
|
|
checkRequestTypeWithBody = (type, body) ->
|
|
|
|
return (done) ->
|
|
|
|
lowercaseType = type.toLowerCase()
|
|
|
|
server[lowercaseType] URI.ok, body, (error, response) ->
|
|
|
|
return done(error) if error?
|
|
|
|
expect(response.request.method).to.equal(type)
|
|
|
|
done()
|
|
|
|
|
|
|
|
describe '#post()', ->
|
|
|
|
it('should be a facade to request()', checkRequestTypeWithBody('POST', { hello: 'world' }))
|
|
|
|
|
|
|
|
describe '#put()', ->
|
|
|
|
it('should be a facade to request()', checkRequestTypeWithBody('PUT', { hello: 'world' }))
|
|
|
|
|
|
|
|
describe '#patch()', ->
|
|
|
|
it('should be a facade to request()', checkRequestTypeWithBody('PATCH', { hello: 'world' }))
|
2014-11-14 11:05:30 -04:00
|
|
|
|
|
|
|
describe 'given there is a token', ->
|
|
|
|
|
|
|
|
beforeEach (done) ->
|
|
|
|
token.saveToken(johnDoeFixture.token, done)
|
|
|
|
|
|
|
|
describe '#request()', ->
|
|
|
|
|
|
|
|
it 'should send the Authorization header', (done) ->
|
|
|
|
|
2014-11-18 09:59:19 -04:00
|
|
|
server.request {
|
|
|
|
method: 'GET'
|
|
|
|
url: URI.ok
|
|
|
|
}, (error, response) ->
|
2014-11-14 11:05:30 -04:00
|
|
|
authorizationHeader = response.request.headers.Authorization
|
|
|
|
|
|
|
|
expect(error).to.not.exist
|
|
|
|
expect(authorizationHeader).to.exist
|
|
|
|
expect(authorizationHeader).to.equal("Bearer #{johnDoeFixture.token}")
|
|
|
|
done()
|
|
|
|
|
|
|
|
describe 'given there is not a token', ->
|
|
|
|
|
|
|
|
beforeEach (done) ->
|
|
|
|
token.clearToken(done)
|
|
|
|
|
|
|
|
describe '#request()', ->
|
|
|
|
|
|
|
|
it 'should not send the Authorization header', (done) ->
|
2014-11-18 09:59:19 -04:00
|
|
|
server.request {
|
|
|
|
method: 'GET'
|
|
|
|
url: URI.ok
|
|
|
|
}, (error, response) ->
|
2014-11-14 11:05:30 -04:00
|
|
|
expect(error).to.not.exist
|
2014-11-14 14:58:56 -04:00
|
|
|
authorizationHeader = response.request.headers.Authorization
|
2014-11-14 11:05:30 -04:00
|
|
|
expect(authorizationHeader).to.not.exist
|
|
|
|
done()
|
|
|
|
|