UNPKG

3.38 kBtext/coffeescriptView Raw
1_ = require 'lodash'
2UUID = require 'uuid'
3request = require 'request'
4Server = require '../../src/server'
5Redis = require 'ioredis'
6RedisNS = require '@octoblu/redis-ns'
7{ JobManagerResponder } = require 'meshblu-core-job-manager'
8
9describe 'POST /search/tokens', ->
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 # avoid returning redis
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 describe '->search', ->
69 context 'when the request is successful', ->
70 beforeEach ->
71 @jobManager.do (@request, callback) =>
72 response =
73 metadata:
74 code: 200
75 responseId: @request.metadata.responseId
76 name: 'dinosaur-getter'
77 data: [
78 {uuid: 't-rex'}
79 {uuid: 'megalodon'}
80 {uuid: 'killasaurus'}
81 ]
82
83 callback null, response
84
85 beforeEach (done) ->
86 options =
87 auth:
88 username: 'irritable-captian'
89 password: 'poop-deck'
90 json: type: 'dinosaur'
91
92 headers:
93 'x-meshblu-as': 'treasure-map'
94 'x-meshblu-erik-feature': 'custom-headers'
95
96 request.post "http://localhost:#{@port}/search/tokens", options, (error, @response, @body) =>
97 done error
98
99 it 'should return a 200', ->
100 expect(@response.statusCode).to.equal 200
101
102 it 'should dispatch the correct metadata', ->
103 expect(@request).to.containSubset
104 metadata:
105 fromUuid: 'treasure-map'
106 erikFeature: 'custom-headers'
107 auth:
108 uuid: 'irritable-captian'
109 token: 'poop-deck'
110
111 it 'should send the search body as the data of the job', ->
112 data = JSON.parse @request.rawData
113 expect(data).to.containSubset type: 'dinosaur'
114
115 it 'should have a tokens array in the response', ->
116 expect(@body).to.be.an 'array'
117 expect(@body.length).to.equal 3