meshblu-server-http
Version:
Maybe. Unofficial. You know how it is.
183 lines (155 loc) • 5.64 kB
text/coffeescript
_ = require 'lodash'
request = require 'request'
Server = require '../../src/server'
async = require 'async'
moment = require 'moment'
redis = require 'redis'
RedisNS = require '@octoblu/redis-ns'
JobManager = require 'meshblu-core-job-manager'
describe 'POST /messages', ->
beforeEach (done) ->
= 0xd00d
= new Server
port:
disableLogging: true
jobTimeoutSeconds: 1
namespace: 'meshblu:server:http:test'
jobLogQueue: 'meshblu:job-log'
jobLogRedisUri: 'redis://localhost:6379'
meshbluHost: 'localhost'
meshbluPort: 3000
.run done
afterEach (done) ->
.stop => done()
beforeEach ->
= _.bindAll new RedisNS 'meshblu:server:http:test', redis.createClient()
= new JobManager client: , timeoutSeconds: 1
beforeEach (done) ->
= redis.createClient()
.del 'meshblu:job-log', done
context 'when the request is successful', ->
beforeEach ->
async.forever (next) =>
.getRequest ['request'], (error, ) =>
next
return unless ?
response =
metadata:
code: 201
responseId: .metadata.responseId
.createResponse 'response', response, (error) =>
throw error if error?
beforeEach (done) ->
options =
auth:
username: 'irritable-captian'
password: 'poop-deck'
json:
devices: ['*']
request.post "http://localhost:#{@port}/messages", options, (error, ) =>
done error
it 'should return a 201', ->
expect(.statusCode).to.equal 201
it 'should submit the correct job type', ->
expect(.metadata.jobType).to.equal 'SendMessage'
it 'should set the correct auth data', ->
expect(.metadata.auth).to.deep.equal uuid: 'irritable-captian', token: 'poop-deck'
it 'should send the correct message', ->
message = JSON.parse .rawData
expect(message).to.deep.equal devices: ['*']
it 'should log the message', (done) ->
.llen 'meshblu:job-log', (error, count) =>
return done error if error?
expect(count).to.equal 1
done()
it 'should log the attempt and success of the message', (done) ->
.lindex 'meshblu:job-log', 0, (error, jobStr) =>
return done error if error?
todaySuffix = moment.utc().format('YYYY-MM-DD')
index = "metric:meshblu-server-http-#{todaySuffix}"
expect(JSON.parse jobStr).to.containSubset {
"index": index
"type": "meshblu-server-http:request"
"body": {
"request": {
"metadata": {
"auth": {
"uuid": "irritable-captian"
}
"fromUuid": "irritable-captian"
"jobType": "SendMessage"
"toUuid": "irritable-captian"
}
}
"response": {
"metadata": {
"code": 201
"success": true
}
}
}
}
done()
context 'when the request is unsuccessful', ->
beforeEach ->
async.forever (next) =>
.getRequest ['request'], (error, ) =>
next
return unless ?
response =
metadata:
code: 506
responseId: .metadata.responseId
.createResponse 'response', response, (error) =>
throw error if error?
beforeEach (done) ->
options =
auth:
username: 'irritable-captian'
password: 'poop-deck'
json:
devices: ['*']
request.post "http://localhost:#{@port}/messages", options, (error, ) =>
done error
it 'should return a 506', ->
expect(.statusCode).to.equal 506
it 'should submit the correct job type', ->
expect(.metadata.jobType).to.equal 'SendMessage'
it 'should set the correct auth data', ->
expect(.metadata.auth).to.deep.equal uuid: 'irritable-captian', token: 'poop-deck'
it 'should send the correct message', ->
message = JSON.parse .rawData
expect(message).to.deep.equal devices: ['*']
it 'should log the message', (done) ->
.llen 'meshblu:job-log', (error, count) =>
return done error if error?
expect(count).to.equal 1
done()
it 'should log the attempt and success of the message', (done) ->
.lindex 'meshblu:job-log', 0, (error, jobStr) =>
return done error if error?
todaySuffix = moment.utc().format('YYYY-MM-DD')
index = "metric:meshblu-server-http-#{todaySuffix}"
expect(JSON.parse jobStr).to.containSubset {
"index": index
"type": "meshblu-server-http:request"
"body": {
"request": {
"metadata": {
"auth": {
"uuid": "irritable-captian"
}
"fromUuid": "irritable-captian"
"jobType": "SendMessage"
"toUuid": "irritable-captian"
}
}
"response": {
"metadata": {
"code": 506
"success": false
}
}
}
}
done()