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 '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
|
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
|