1 | _ = require 'lodash'
|
2 | UUID = require 'uuid'
|
3 | request = require 'request'
|
4 | Server = require '../../src/server'
|
5 | Redis = require 'ioredis'
|
6 | RedisNS = require '@octoblu/redis-ns'
|
7 | { JobManagerResponder } = require 'meshblu-core-job-manager'
|
8 |
|
9 | describe 'GET /v3/devices/:uuid', ->
|
10 | beforeEach (done) ->
|
11 | @responseQueueId = UUID.v4()
|
12 | @requestQueueName = "request:queue:#{@responseQueueId}"
|
13 | @responseQueueName = "response:queue:#{@responseQueueId}"
|
14 | @namespace = 'test:meshblu-http'
|
15 | @jobLogQueue = 'test:meshblu:job-log'
|
16 | @redisUri = 'redis://localhost'
|
17 | @port = 0xd00d
|
18 | @sut = new Server {
|
19 | @port
|
20 | disableLogging: true
|
21 | jobTimeoutSeconds: 1
|
22 | @namespace
|
23 | @jobLogQueue
|
24 | jobLogRedisUri: @redisUri
|
25 | jobLogSampleRate: 1
|
26 | redisUri: @redisUri
|
27 | cacheRedisUri: @redisUri
|
28 | @requestQueueName
|
29 | @responseQueueName
|
30 | }
|
31 |
|
32 | @sut.run done
|
33 |
|
34 | afterEach ->
|
35 | @sut.stop()
|
36 |
|
37 | beforeEach (done) ->
|
38 | @redis = new RedisNS @namespace, new Redis @redisUri, dropBufferSupport: true
|
39 | @redis.on 'ready', done
|
40 |
|
41 | afterEach (done) ->
|
42 | @redis.del @requestQueueName, @responseQueueName, done
|
43 | return
|
44 |
|
45 | beforeEach (done) ->
|
46 | @workerFunc = (@request, callback=_.noop) =>
|
47 | @jobManagerDo @request, callback
|
48 |
|
49 | @jobManager = new JobManagerResponder {
|
50 | @redisUri
|
51 | @namespace
|
52 | @workerFunc
|
53 | maxConnections: 1
|
54 | queueTimeoutSeconds: 1
|
55 | jobTimeoutSeconds: 1
|
56 | jobLogSampleRate: 1
|
57 | requestQueueName: @requestQueueName
|
58 | responseQueueName: @responseQueueName
|
59 | }
|
60 | @jobManager.start done
|
61 |
|
62 | beforeEach ->
|
63 | @jobManager.do = (@jobManagerDo) =>
|
64 |
|
65 | afterEach ->
|
66 | @jobManager.stop()
|
67 |
|
68 | context 'when the request is successful', ->
|
69 | beforeEach ->
|
70 | @jobManager.do (@jobRequest, callback) =>
|
71 | response =
|
72 | metadata:
|
73 | code: 200
|
74 | responseId: @jobRequest.metadata.responseId
|
75 | name: 'koshin'
|
76 | data:
|
77 | uuid: 'secret-island'
|
78 |
|
79 | callback null, response
|
80 |
|
81 | beforeEach (done) ->
|
82 | options =
|
83 | auth:
|
84 | username: 'irritable-captian'
|
85 | password: 'poop-deck'
|
86 |
|
87 | headers:
|
88 | 'x-meshblu-as': 'treasure-map'
|
89 |
|
90 | request.get "http://localhost:#{@port}/v3/devices/secret-island", options, (error, @response, @body) =>
|
91 | done error
|
92 |
|
93 | it 'should return a 200', ->
|
94 | expect(@response.statusCode).to.equal 200
|
95 |
|
96 | it 'should have the device in the body', ->
|
97 | expect(JSON.parse(@body)).to.contain uuid: 'secret-island'
|
98 |
|
99 | it 'should have set the fromUuid correctly', ->
|
100 | expect(@jobRequest.metadata.fromUuid).to.equal 'treasure-map'
|
101 |
|
102 | it 'should have set the toUuid correctly', ->
|
103 | expect(@jobRequest.metadata.toUuid).to.equal 'secret-island'
|
104 |
|
105 | it 'should have set the auth correctly', ->
|
106 | expect(@jobRequest.metadata.auth).to.deep.equal
|
107 | as: 'treasure-map'
|
108 | uuid: 'irritable-captian'
|
109 | token: 'poop-deck'
|
110 |
|
111 | it 'should have the metadata in the headers', ->
|
112 | expect(@response.headers).to.containSubset
|
113 | 'x-meshblu-code': '200'
|
114 | 'x-meshblu-name': 'koshin'
|
115 | 'x-meshblu-response-id': @jobRequest.metadata.responseId
|