1 | _ = require 'lodash'
|
2 | request = require 'request'
|
3 | Server = require '../../src/server'
|
4 | async = require 'async'
|
5 | redis = require 'redis'
|
6 | RedisNS = require '@octoblu/redis-ns'
|
7 | JobManager = require 'meshblu-core-job-manager'
|
8 |
|
9 | describe 'GET /v2/devices/:uuid/subscriptions', ->
|
10 | beforeEach (done) ->
|
11 | @port = 0xd00d
|
12 | @sut = new Server
|
13 | port: @port
|
14 | disableLogging: true
|
15 | jobTimeoutSeconds: 1
|
16 | namespace: 'meshblu:server:http:test'
|
17 | jobLogQueue: 'meshblu:job-log'
|
18 | jobLogRedisUri: 'redis://localhost:6379'
|
19 | meshbluHost: 'localhost'
|
20 | meshbluPort: 3000
|
21 |
|
22 | @sut.run done
|
23 |
|
24 | afterEach (done) ->
|
25 | @sut.stop => done()
|
26 |
|
27 | beforeEach ->
|
28 | @redis = _.bindAll new RedisNS 'meshblu:server:http:test', redis.createClient()
|
29 | @jobManager = new JobManager client: @redis, timeoutSeconds: 1
|
30 |
|
31 | context 'when the request is successful', ->
|
32 | beforeEach ->
|
33 | async.forever (next) =>
|
34 | @jobManager.getRequest ['request'], (error, request) =>
|
35 | next request
|
36 | return unless request?
|
37 |
|
38 | response =
|
39 | metadata:
|
40 | code: 200
|
41 | responseId: request.metadata.responseId
|
42 | data: []
|
43 |
|
44 | @jobManager.createResponse 'response', response, (error) =>
|
45 | throw error if error?
|
46 |
|
47 | beforeEach (done) ->
|
48 | options =
|
49 | auth:
|
50 | username: 'irritable-captian'
|
51 | password: 'poop-deck'
|
52 |
|
53 | request.get "http://localhost:#{@port}/v2/devices/irritable-captian/subscriptions", options, (error, @response, @body) =>
|
54 | done error
|
55 |
|
56 | it 'should return a 200', ->
|
57 | expect(@response.statusCode).to.equal 200
|
58 |
|
59 | it 'should have the list in the body', ->
|
60 | expect(JSON.parse(@body)).to.deep.equal []
|