-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcoverage.html
357 lines (310 loc) · 106 KB
/
coverage.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
UPLOAD FAILED: { [Error: EISDIR, read] errno: 28, code: 'EISDIR' }
UPLOAD FAILED: { [Error: EISDIR, read] errno: 28, code: 'EISDIR' }
<!DOCTYPE html><html><head><title>Coverage</title><meta charset="utf-8"><script>
headings = [];
onload = function(){
headings = document.querySelectorAll('h2');
};
onscroll = function(e){
var heading = find(window.scrollY);
if (!heading) return;
var links = document.querySelectorAll('#menu a')
, link;
for (var i = 0, len = links.length; i < len; ++i) {
link = links[i];
link.className = link.getAttribute('href') == '#' + heading.id
? 'active'
: '';
}
};
function find(y) {
var i = headings.length
, heading;
while (i--) {
heading = headings[i];
if (y >= heading.offsetTop) {
return heading;
}
}
}
</script>
<style>
body {
font: 14px/1.6 "Helvetica Neue", Helvetica, Arial, sans-serif;
margin: 0;
color: #2C2C2C;
border-top: 2px solid #ddd;
}
#coverage {
padding: 60px;
}
h1 a {
color: inherit;
font-weight: inherit;
}
h1 a:hover {
text-decoration: none;
}
.onload h1 {
opacity: 1;
}
h2 {
width: 80%;
margin-top: 80px;
margin-bottom: 0;
font-weight: 100;
letter-spacing: 1px;
border-bottom: 1px solid #eee;
}
a {
color: #8A6343;
font-weight: bold;
text-decoration: none;
}
a:hover {
text-decoration: underline;
}
ul {
margin-top: 20px;
padding: 0 15px;
width: 100%;
}
ul li {
float: left;
width: 40%;
margin-top: 5px;
margin-right: 60px;
list-style: none;
border-bottom: 1px solid #eee;
padding: 5px 0;
font-size: 12px;
}
ul::after {
content: '.';
height: 0;
display: block;
visibility: hidden;
clear: both;
}
code {
font: 12px monaco, monospace;
}
pre {
margin: 30px;
padding: 30px;
border: 1px solid #eee;
border-bottom-color: #ddd;
-webkit-border-radius: 2px;
-moz-border-radius: 2px;
border-radius: 2px;
-webkit-box-shadow: inset 0 0 10px #eee;
-moz-box-shadow: inset 0 0 10px #eee;
box-shadow: inset 0 0 10px #eee;
overflow-x: auto;
}
img {
margin: 30px;
padding: 1px;
-webkit-border-radius: 3px;
-moz-border-radius: 3px;
border-radius: 3px;
-webkit-box-shadow: 0 3px 10px #dedede, 0 1px 5px #888;
-moz-box-shadow: 0 3px 10px #dedede, 0 1px 5px #888;
box-shadow: 0 3px 10px #dedede, 0 1px 5px #888;
max-width: 100%;
}
footer {
background: #eee;
width: 100%;
padding: 50px 0;
text-align: right;
border-top: 1px solid #ddd;
}
footer span {
display: block;
margin-right: 30px;
color: #888;
font-size: 12px;
}
#menu {
position: fixed;
font-size: 12px;
overflow-y: auto;
top: 0;
right: 0;
margin: 0;
height: 100%;
padding: 15px 0;
text-align: right;
border-left: 1px solid #eee;
-moz-box-shadow: 0 0 2px #888
, inset 5px 0 20px rgba(0,0,0,.5)
, inset 5px 0 3px rgba(0,0,0,.3);
-webkit-box-shadow: 0 0 2px #888
, inset 5px 0 20px rgba(0,0,0,.5)
, inset 5px 0 3px rgba(0,0,0,.3);
box-shadow: 0 0 2px #888
, inset 5px 0 20px rgba(0,0,0,.5)
, inset 5px 0 3px rgba(0,0,0,.3);
-webkit-font-smoothing: antialiased;
background: url("");
}
#menu::after {
display: block;
content: '';
padding-top: 80px;
}
#logo {
position: fixed;
bottom: 10px;
right: 10px;
background: rgba(255,255,255,.1);
font-size: 11px;
display: block;
width: 20px;
height: 20px;
line-height: 20px;
text-align: center;
-webkit-border-radius: 20px;
-moz-border-radius: 20px;
border-radius: 20px;
-webkit-box-shadow: 0 0 3px rgba(0,0,0,.2);
-moz-box-shadow: 0 0 3px rgba(0,0,0,.2);
box-shadow: 0 0 3px rgba(0,0,0,.2);
color: inherit;
}
#menu li a {
display: block;
color: white;
padding: 0 35px 0 25px;
-webkit-transition: background 300ms;
-moz-transition: background 300ms;
}
#menu li {
position: relative;
list-style: none;
}
#menu a:hover,
#menu a.active {
text-decoration: none;
background: rgba(255,255,255,.1);
}
#menu li:hover .cov {
opacity: 1;
}
#menu li .dirname {
opacity: .60;
padding-right: 2px;
}
#menu li .basename {
opacity: 1;
}
#menu .cov {
background: rgba(0,0,0,.4);
position: absolute;
top: 0;
right: 8px;
font-size: 9px;
opacity: .6;
text-align: left;
width: 17px;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
border-radius: 10px;
padding: 2px 3px;
text-align: center;
}
#stats:nth-child(2n) {
display: inline-block;
margin-top: 15px;
border: 1px solid #eee;
padding: 10px;
-webkit-box-shadow: inset 0 0 2px #eee;
-moz-box-shadow: inset 0 0 2px #eee;
box-shadow: inset 0 0 2px #eee;
-webkit-border-radius: 5px;
-moz-border-radius: 5px;
border-radius: 5px;
}
#stats div {
float: left;
padding: 0 5px;
}
#stats::after {
display: block;
content: '';
clear: both;
}
#stats .sloc::after {
content: ' SLOC';
color: #b6b6b6;
}
#stats .percentage::after {
content: ' coverage';
color: #b6b6b6;
}
#stats .hits,
#stats .misses {
display: none;
}
.high {
color: #00d4b4;
}
.medium {
color: #e87d0d;
}
.low {
color: #d4081a;
}
.terrible {
color: #d4081a;
font-weight: bold;
}
table {
width: 80%;
margin-top: 10px;
border-collapse: collapse;
border: 1px solid #cbcbcb;
color: #363636;
-webkit-border-radius: 3px;
-moz-border-radius: 3px;
border-radius: 3px;
}
table thead {
display: none;
}
table td.line,
table td.hits {
width: 20px;
background: #eaeaea;
text-align: center;
font-size: 11px;
padding: 0 10px;
color: #949494;
}
table td.hits {
width: 10px;
padding: 2px 5px;
color: rgba(0,0,0,.2);
background: #f0f0f0;
}
tr.miss td.line,
tr.miss td.hits {
background: #e6c3c7;
}
tr.miss td {
background: #f8d5d8;
}
td.source {
padding-left: 15px;
line-height: 15px;
white-space: pre;
font: 12px monaco, monospace;
}
code .comment { color: #ddd }
code .init { color: #2F6FAD }
code .string { color: #5890AD }
code .keyword { color: #8A6343 }
code .number { color: #2F6FAD }
</style>
</head><body><div id="coverage"><h1 id="overview">Coverage</h1><div id="menu"><li><a href="#overview">overview</a></li><li><span class="cov high">80</span><a href="#/vagrant/app/worker/lib/Client.js"><span class="dirname">/vagrant/app/worker/lib/</span><span class="basename">Client.js</span></a></li><li><span class="cov high">97</span><a href="#/vagrant/app/worker/lib/Container.js"><span class="dirname">/vagrant/app/worker/lib/</span><span class="basename">Container.js</span></a></li><li><span class="cov high">97</span><a href="#/vagrant/app/worker/lib/JobItem.js"><span class="dirname">/vagrant/app/worker/lib/</span><span class="basename">JobItem.js</span></a></li><li><span class="cov high">100</span><a href="#/vagrant/app/worker/lib/Logger.js"><span class="dirname">/vagrant/app/worker/lib/</span><span class="basename">Logger.js</span></a></li><li><span class="cov high">89</span><a href="#/vagrant/app/worker/lib/PromisedDocker.js"><span class="dirname">/vagrant/app/worker/lib/</span><span class="basename">PromisedDocker.js</span></a></li><li><span class="cov high">94</span><a href="#/vagrant/app/worker/lib/S3ArtifactPersistanceHandler.js"><span class="dirname">/vagrant/app/worker/lib/</span><span class="basename">S3ArtifactPersistanceHandler.js</span></a></li><li><span class="cov medium">72</span><a href="#/vagrant/app/worker/lib/Worker.js"><span class="dirname">/vagrant/app/worker/lib/</span><span class="basename">Worker.js</span></a></li><a id="logo" href="http://visionmedia.github.io/mocha/">m</a></div><div id="stats" class="high"><div class="percentage">85%</div><div class="sloc">303</div><div class="hits">259</div><div class="misses">44</div></div><div id="files"><div class="file"><h2 id="/vagrant/app/worker/lib/Client.js">/vagrant/app/worker/lib/Client.js</h2><div id="stats" class="high"><div class="percentage">80%</div><div class="sloc">56</div><div class="hits">45</div><div class="misses">11</div></div><table id="source"><thead><tr><th>Line</th><th>Hits</th><th>Source</th></tr></thead><tbody><tr class="hit"><td class="line">1</td><td class="hits">1</td><td class="source">'use strict';</td></tr><tr><td class="line">2</td><td class="hits"></td><td class="source">// Queue handler</td></tr><tr><td class="line">3</td><td class="hits"></td><td class="source">// =============</td></tr><tr><td class="line">4</td><td class="hits"></td><td class="source">//</td></tr><tr><td class="line">5</td><td class="hits"></td><td class="source">// TODO: describe dependencies</td></tr><tr><td class="line">6</td><td class="hits"></td><td class="source">//</td></tr><tr class="hit"><td class="line">7</td><td class="hits">1</td><td class="source">var Queue = require('bull'),</td></tr><tr><td class="line">8</td><td class="hits"></td><td class="source"> EventEmitter = require('events').EventEmitter,</td></tr><tr><td class="line">9</td><td class="hits"></td><td class="source"> redis = require('redis'),</td></tr><tr><td class="line">10</td><td class="hits"></td><td class="source"> util = require('util'),</td></tr><tr><td class="line">11</td><td class="hits"></td><td class="source"> S3ArtifactPersistanceHandler = require('./S3ArtifactPersistanceHandler'),</td></tr><tr><td class="line">12</td><td class="hits"></td><td class="source"> Worker = require('./Worker');</td></tr><tr><td class="line">13</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">14</td><td class="hits"></td><td class="source">// The main purpose of `Client` object is to process the build queue and</td></tr><tr><td class="line">15</td><td class="hits"></td><td class="source">// report back to result queue and also to stream output to redis pub/sub channel</td></tr><tr><td class="line">16</td><td class="hits"></td><td class="source">//</td></tr><tr><td class="line">17</td><td class="hits"></td><td class="source">// It accepts `host` and `port` of redis server and logger which must be able to</td></tr><tr><td class="line">18</td><td class="hits"></td><td class="source">// respond to `info`, `warn`, `log` and `error`</td></tr><tr><td class="line">19</td><td class="hits"></td><td class="source">//</td></tr><tr><td class="line">20</td><td class="hits"></td><td class="source">// `Client` uses Revealing Module Pattern for expose simple public interface.</td></tr><tr><td class="line">21</td><td class="hits"></td><td class="source">//</td></tr><tr class="hit"><td class="line">22</td><td class="hits">1</td><td class="source">var Client = function (host, port, log) {</td></tr><tr><td class="line">23</td><td class="hits"></td><td class="source"> // Worker object</td></tr><tr class="hit"><td class="line">24</td><td class="hits">3</td><td class="source"> var worker = new Worker({</td></tr><tr><td class="line">25</td><td class="hits"></td><td class="source"> postProcess : function (resultData,done) {</td></tr><tr class="hit"><td class="line">26</td><td class="hits">2</td><td class="source"> log.info("artifact HANDLED:",resultData);</td></tr><tr class="hit"><td class="line">27</td><td class="hits">2</td><td class="source"> (new S3ArtifactPersistanceHandler(log)).handle(resultData,done);</td></tr><tr><td class="line">28</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">29</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">30</td><td class="hits"></td><td class="source"> // Logger object</td></tr><tr class="hit"><td class="line">31</td><td class="hits">3</td><td class="source"> var log = log || console;</td></tr><tr><td class="line">32</td><td class="hits"></td><td class="source"> // Referring current instance as emitter</td></tr><tr class="hit"><td class="line">33</td><td class="hits">3</td><td class="source"> var emitter = this;</td></tr><tr><td class="line">34</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">35</td><td class="hits"></td><td class="source"> // Build queue contains job order items</td></tr><tr class="hit"><td class="line">36</td><td class="hits">3</td><td class="source"> var buildQueue = Queue("build", port, host);</td></tr><tr><td class="line">37</td><td class="hits"></td><td class="source"> // Result queue contains job results</td></tr><tr class="hit"><td class="line">38</td><td class="hits">3</td><td class="source"> var resultQueue = Queue("result", port, host);</td></tr><tr><td class="line">39</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">40</td><td class="hits"></td><td class="source"> // Instance of redis used for streaming of output from container during build execution</td></tr><tr class="hit"><td class="line">41</td><td class="hits">3</td><td class="source"> var reportChannel = redis.createClient(port, host);</td></tr><tr><td class="line">42</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">43</td><td class="hits"></td><td class="source"> // Instance of redis used for saving output to the redis list</td></tr><tr><td class="line">44</td><td class="hits"></td><td class="source"> // (we can not use instance reportChannel because once we switch to subscriber mode we can't execute regular functions)</td></tr><tr class="hit"><td class="line">45</td><td class="hits">3</td><td class="source"> var report = redis.createClient(port, host);</td></tr><tr><td class="line">46</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">47</td><td class="hits"></td><td class="source"> // Generates key to be used as channel name</td></tr><tr class="hit"><td class="line">48</td><td class="hits">3</td><td class="source"> var getKey = function (id) {</td></tr><tr class="hit"><td class="line">49</td><td class="hits">4</td><td class="source"> return "report:build:" + id;</td></tr><tr><td class="line">50</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">51</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">52</td><td class="hits"></td><td class="source"> // Handles streaming of output from container during build execution</td></tr><tr><td class="line">53</td><td class="hits"></td><td class="source"> // also it saves all lines within redis list</td></tr><tr><td class="line">54</td><td class="hits"></td><td class="source"> //</td></tr><tr><td class="line">55</td><td class="hits"></td><td class="source"> // Arguments:</td></tr><tr><td class="line">56</td><td class="hits"></td><td class="source"> // - `data` __literal__</td></tr><tr><td class="line">57</td><td class="hits"></td><td class="source"> // {</td></tr><tr><td class="line">58</td><td class="hits"></td><td class="source"> // id : <build id>,</td></tr><tr><td class="line">59</td><td class="hits"></td><td class="source"> // data: <line of output></td></tr><tr><td class="line">60</td><td class="hits"></td><td class="source"> // }</td></tr><tr><td class="line">61</td><td class="hits"></td><td class="source"> // - `job` __bull.Job__ object</td></tr><tr><td class="line">62</td><td class="hits"></td><td class="source"> //</td></tr><tr class="hit"><td class="line">63</td><td class="hits">3</td><td class="source"> var reportHandler = function (data, job) {</td></tr><tr class="hit"><td class="line">64</td><td class="hits">4</td><td class="source"> var channel = "channel_" + job.data._id;</td></tr><tr class="hit"><td class="line">65</td><td class="hits">4</td><td class="source"> var b = new Buffer(data.data);</td></tr><tr class="hit"><td class="line">66</td><td class="hits">4</td><td class="source"> emitter.emit("progress", data);</td></tr><tr class="hit"><td class="line">67</td><td class="hits">4</td><td class="source"> report.rpush(getKey(job.data._id), b);</td></tr><tr class="hit"><td class="line">68</td><td class="hits">4</td><td class="source"> reportChannel.publish(channel, JSON.stringify(data));</td></tr><tr><td class="line">69</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">70</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">71</td><td class="hits"></td><td class="source"> // Handles result of build execution</td></tr><tr><td class="line">72</td><td class="hits"></td><td class="source"> //</td></tr><tr><td class="line">73</td><td class="hits"></td><td class="source"> // Arguments:</td></tr><tr><td class="line">74</td><td class="hits"></td><td class="source"> // - `result` __literal__</td></tr><tr><td class="line">75</td><td class="hits"></td><td class="source"> // {</td></tr><tr><td class="line">76</td><td class="hits"></td><td class="source"> // status : {</td></tr><tr><td class="line">77</td><td class="hits"></td><td class="source"> // StatusCode : <exit code></td></tr><tr><td class="line">78</td><td class="hits"></td><td class="source"> // }</td></tr><tr><td class="line">79</td><td class="hits"></td><td class="source"> // }</td></tr><tr><td class="line">80</td><td class="hits"></td><td class="source"> // - `complete` __function__ bull complete callback</td></tr><tr><td class="line">81</td><td class="hits"></td><td class="source"> //</td></tr><tr class="hit"><td class="line">82</td><td class="hits">3</td><td class="source"> var resultHandler = function (result, complete) {</td></tr><tr class="hit"><td class="line">83</td><td class="hits">2</td><td class="source"> resultQueue.add(result);</td></tr><tr class="hit"><td class="line">84</td><td class="hits">2</td><td class="source"> complete();</td></tr><tr><td class="line">85</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">86</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">87</td><td class="hits"></td><td class="source"> // Handles the build process once new job order is available</td></tr><tr><td class="line">88</td><td class="hits"></td><td class="source"> //</td></tr><tr><td class="line">89</td><td class="hits"></td><td class="source"> // Arguments:</td></tr><tr><td class="line">90</td><td class="hits"></td><td class="source"> // - `job` __bull.Job__ object</td></tr><tr><td class="line">91</td><td class="hits"></td><td class="source"> // - `complete` __function__ bull complete callback</td></tr><tr class="hit"><td class="line">92</td><td class="hits">3</td><td class="source"> var buildHandler = function (job, complete) {</td></tr><tr class="hit"><td class="line">93</td><td class="hits">2</td><td class="source"> log.info("job processing");</td></tr><tr class="hit"><td class="line">94</td><td class="hits">2</td><td class="source"> job.data.started = new Date().getTime();</td></tr><tr class="hit"><td class="line">95</td><td class="hits">2</td><td class="source"> worker.put(job.data, function (data) {</td></tr><tr class="hit"><td class="line">96</td><td class="hits">4</td><td class="source"> job.data.output = [];</td></tr><tr class="hit"><td class="line">97</td><td class="hits">4</td><td class="source"> reportHandler(data, job)</td></tr><tr><td class="line">98</td><td class="hits"></td><td class="source"> }).on('complete', function (result,artifact_name) {</td></tr><tr class="hit"><td class="line">99</td><td class="hits">2</td><td class="source"> job.data.status = result;</td></tr><tr class="hit"><td class="line">100</td><td class="hits">2</td><td class="source"> if(artifact_name){</td></tr><tr class="miss"><td class="line">101</td><td class="hits">0</td><td class="source"> job.data.artifact_name = artifact_name;</td></tr><tr><td class="line">102</td><td class="hits"></td><td class="source"> }</td></tr><tr class="hit"><td class="line">103</td><td class="hits">2</td><td class="source"> job.data.finished = new Date().getTime();</td></tr><tr class="hit"><td class="line">104</td><td class="hits">2</td><td class="source"> emitter.emit('complete', result);</td></tr><tr class="hit"><td class="line">105</td><td class="hits">2</td><td class="source"> log.info("job processed");</td></tr><tr class="hit"><td class="line">106</td><td class="hits">2</td><td class="source"> resultHandler(job.data, complete);</td></tr><tr><td class="line">107</td><td class="hits"></td><td class="source"> }).on('timeout', function(result){</td></tr><tr class="miss"><td class="line">108</td><td class="hits">0</td><td class="source"> job.data.status = result;</td></tr><tr class="miss"><td class="line">109</td><td class="hits">0</td><td class="source"> job.data.finished = new Date().getTime();</td></tr><tr class="miss"><td class="line">110</td><td class="hits">0</td><td class="source"> emitter.emit('timeout', result);</td></tr><tr class="miss"><td class="line">111</td><td class="hits">0</td><td class="source"> log.info("job processed timeout");</td></tr><tr class="miss"><td class="line">112</td><td class="hits">0</td><td class="source"> resultHandler(job.data, complete);</td></tr><tr><td class="line">113</td><td class="hits"></td><td class="source"> }).on('error', function(result){</td></tr><tr class="miss"><td class="line">114</td><td class="hits">0</td><td class="source"> job.data.status = {</td></tr><tr><td class="line">115</td><td class="hits"></td><td class="source"> StatusCode: 500</td></tr><tr><td class="line">116</td><td class="hits"></td><td class="source"> };</td></tr><tr class="miss"><td class="line">117</td><td class="hits">0</td><td class="source"> job.data.finished = new Date().getTime();</td></tr><tr class="miss"><td class="line">118</td><td class="hits">0</td><td class="source"> emitter.emit('error', result);</td></tr><tr class="miss"><td class="line">119</td><td class="hits">0</td><td class="source"> log.info("job processed timeout");</td></tr><tr class="miss"><td class="line">120</td><td class="hits">0</td><td class="source"> resultHandler(job.data, complete);</td></tr><tr><td class="line">121</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">122</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">123</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">124</td><td class="hits"></td><td class="source"> // Starting waiting for new job order</td></tr><tr><td class="line">125</td><td class="hits"></td><td class="source"> // this call is blocking as it uses redis blocking `BRPOPLPUSH` command</td></tr><tr class="hit"><td class="line">126</td><td class="hits">3</td><td class="source"> buildQueue.process(buildHandler);</td></tr><tr><td class="line">127</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">128</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">129</td><td class="hits"></td><td class="source"> // Object literal that describes public interface of `Client`</td></tr><tr class="hit"><td class="line">130</td><td class="hits">3</td><td class="source"> return {</td></tr><tr><td class="line">131</td><td class="hits"></td><td class="source"> close: function () {</td></tr><tr class="hit"><td class="line">132</td><td class="hits">3</td><td class="source"> buildQueue.close();</td></tr><tr class="hit"><td class="line">133</td><td class="hits">3</td><td class="source"> resultQueue.close();</td></tr><tr class="hit"><td class="line">134</td><td class="hits">3</td><td class="source"> reportChannel.end();</td></tr><tr class="hit"><td class="line">135</td><td class="hits">3</td><td class="source"> report.end();</td></tr><tr><td class="line">136</td><td class="hits"></td><td class="source"> },</td></tr><tr><td class="line">137</td><td class="hits"></td><td class="source"> complete: function (callback) {</td></tr><tr class="hit"><td class="line">138</td><td class="hits">2</td><td class="source"> emitter.on('complete', callback);</td></tr><tr><td class="line">139</td><td class="hits"></td><td class="source"> },</td></tr><tr><td class="line">140</td><td class="hits"></td><td class="source"> progress: function (callback) {</td></tr><tr class="hit"><td class="line">141</td><td class="hits">1</td><td class="source"> emitter.on('progress', callback);</td></tr><tr><td class="line">142</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">143</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">144</td><td class="hits"></td><td class="source">};</td></tr><tr><td class="line">145</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">146</td><td class="hits"></td><td class="source">// Inheriting from EventEmitter</td></tr><tr class="hit"><td class="line">147</td><td class="hits">1</td><td class="source">util.inherits(Client, EventEmitter);</td></tr><tr><td class="line">148</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">149</td><td class="hits">1</td><td class="source">module.exports = Client;</td></tr></tbody></table></div><div class="file"><h2 id="/vagrant/app/worker/lib/Container.js">/vagrant/app/worker/lib/Container.js</h2><div id="stats" class="high"><div class="percentage">97%</div><div class="sloc">39</div><div class="hits">38</div><div class="misses">1</div></div><table id="source"><thead><tr><th>Line</th><th>Hits</th><th>Source</th></tr></thead><tbody><tr class="hit"><td class="line">1</td><td class="hits">1</td><td class="source">'use strict';</td></tr><tr class="hit"><td class="line">2</td><td class="hits">1</td><td class="source">var _ = require("lodash");</td></tr><tr class="hit"><td class="line">3</td><td class="hits">1</td><td class="source">var tmp = require('temporary');</td></tr><tr class="hit"><td class="line">4</td><td class="hits">1</td><td class="source">var utils = require('util');</td></tr><tr class="hit"><td class="line">5</td><td class="hits">1</td><td class="source">var EventEmitter = require('events').EventEmitter;</td></tr><tr><td class="line">6</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">7</td><td class="hits">1</td><td class="source">var Container = function(docker,options, buildOptions){</td></tr><tr class="hit"><td class="line">8</td><td class="hits">10</td><td class="source"> var options = _.merge({</td></tr><tr><td class="line">9</td><td class="hits"></td><td class="source"> command : ['date'],</td></tr><tr><td class="line">10</td><td class="hits"></td><td class="source"> stdOut : process.stdout</td></tr><tr><td class="line">11</td><td class="hits"></td><td class="source"> },options);</td></tr><tr class="hit"><td class="line">12</td><td class="hits">10</td><td class="source"> var self = this;</td></tr><tr><td class="line">13</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">14</td><td class="hits">10</td><td class="source"> var container_inst;</td></tr><tr class="hit"><td class="line">15</td><td class="hits">10</td><td class="source"> var timeout_handle;</td></tr><tr><td class="line">16</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">17</td><td class="hits">10</td><td class="source"> var timeout = function(timeout){</td></tr><tr class="hit"><td class="line">18</td><td class="hits">3</td><td class="source"> timeout_handle = setTimeout(function () {</td></tr><tr class="hit"><td class="line">19</td><td class="hits">1</td><td class="source"> container_inst.remove({v:true,force:true}).then(function(){</td></tr><tr class="hit"><td class="line">20</td><td class="hits">1</td><td class="source"> timeout_handle && clearTimeout(timeout_handle);</td></tr><tr class="hit"><td class="line">21</td><td class="hits">1</td><td class="source"> self.emit("timeout",{</td></tr><tr><td class="line">22</td><td class="hits"></td><td class="source"> StatusCode : 100</td></tr><tr><td class="line">23</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">24</td><td class="hits"></td><td class="source"> }).catch(function(err){</td></tr><tr class="miss"><td class="line">25</td><td class="hits">0</td><td class="source"> self.emit("error",err);</td></tr><tr><td class="line">26</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">27</td><td class="hits"></td><td class="source"> }, timeout);</td></tr><tr class="hit"><td class="line">28</td><td class="hits">3</td><td class="source"> return timeout_handle;</td></tr><tr><td class="line">29</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">30</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">31</td><td class="hits">10</td><td class="source"> var start = function(){</td></tr><tr class="hit"><td class="line">32</td><td class="hits">10</td><td class="source"> return docker.create({</td></tr><tr><td class="line">33</td><td class="hits"></td><td class="source"> Image: options.container_name,</td></tr><tr><td class="line">34</td><td class="hits"></td><td class="source"> Cmd: options.command,</td></tr><tr><td class="line">35</td><td class="hits"></td><td class="source"> name : options.name,</td></tr><tr><td class="line">36</td><td class="hits"></td><td class="source"> AttachStdin: false,</td></tr><tr><td class="line">37</td><td class="hits"></td><td class="source"> AttachStdout: true,</td></tr><tr><td class="line">38</td><td class="hits"></td><td class="source"> AttachStderr: true,</td></tr><tr><td class="line">39</td><td class="hits"></td><td class="source"> Tty: true,</td></tr><tr><td class="line">40</td><td class="hits"></td><td class="source"> OpenStdin: true,</td></tr><tr><td class="line">41</td><td class="hits"></td><td class="source"> StdinOnce: false</td></tr><tr><td class="line">42</td><td class="hits"></td><td class="source"> }).then(function(container){</td></tr><tr class="hit"><td class="line">43</td><td class="hits">10</td><td class="source"> container_inst = container;</td></tr><tr class="hit"><td class="line">44</td><td class="hits">10</td><td class="source"> return container.attach({</td></tr><tr><td class="line">45</td><td class="hits"></td><td class="source"> stream: true,</td></tr><tr><td class="line">46</td><td class="hits"></td><td class="source"> stdout: true,</td></tr><tr><td class="line">47</td><td class="hits"></td><td class="source"> stderr: true</td></tr><tr><td class="line">48</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">49</td><td class="hits"></td><td class="source"> }).then(function(stream){</td></tr><tr class="hit"><td class="line">50</td><td class="hits">10</td><td class="source"> stream.setEncoding('utf8');</td></tr><tr class="hit"><td class="line">51</td><td class="hits">10</td><td class="source"> options.stdOut && stream.pipe(options.stdOut, {end: true});</td></tr><tr class="hit"><td class="line">52</td><td class="hits">10</td><td class="source"> return container_inst.start({Links:options.links, Binds : options.binds});</td></tr><tr><td class="line">53</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">54</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">55</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">56</td><td class="hits">10</td><td class="source"> var wait = function(){</td></tr><tr class="hit"><td class="line">57</td><td class="hits">6</td><td class="source"> options.timeout && timeout(options.timeout);</td></tr><tr class="hit"><td class="line">58</td><td class="hits">6</td><td class="source"> return container_inst.wait().then(function(data){</td></tr><tr class="hit"><td class="line">59</td><td class="hits">6</td><td class="source"> timeout_handle && clearTimeout(timeout_handle);</td></tr><tr class="hit"><td class="line">60</td><td class="hits">6</td><td class="source"> return container_inst.dummy(data);</td></tr><tr><td class="line">61</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">62</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">63</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">64</td><td class="hits">10</td><td class="source"> var stop = function(){</td></tr><tr class="hit"><td class="line">65</td><td class="hits">4</td><td class="source"> timeout_handle && clearTimeout(timeout_handle);</td></tr><tr class="hit"><td class="line">66</td><td class="hits">4</td><td class="source"> return container_inst.stop({t:0});</td></tr><tr><td class="line">67</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">68</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">69</td><td class="hits">10</td><td class="source"> var remove = function(){</td></tr><tr class="hit"><td class="line">70</td><td class="hits">9</td><td class="source"> timeout_handle && clearTimeout(timeout_handle);</td></tr><tr class="hit"><td class="line">71</td><td class="hits">9</td><td class="source"> return container_inst.remove({v:true,force:true});</td></tr><tr><td class="line">72</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">73</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">74</td><td class="hits">10</td><td class="source"> return {</td></tr><tr><td class="line">75</td><td class="hits"></td><td class="source"> start : start,</td></tr><tr><td class="line">76</td><td class="hits"></td><td class="source"> stop : stop,</td></tr><tr><td class="line">77</td><td class="hits"></td><td class="source"> wait : wait,</td></tr><tr><td class="line">78</td><td class="hits"></td><td class="source"> remove : remove,</td></tr><tr><td class="line">79</td><td class="hits"></td><td class="source"> onTimeout : function(callback){</td></tr><tr class="hit"><td class="line">80</td><td class="hits">3</td><td class="source"> self.on('timeout',callback);</td></tr><tr><td class="line">81</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">82</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">83</td><td class="hits"></td><td class="source">};</td></tr><tr><td class="line">84</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">85</td><td class="hits">1</td><td class="source">utils.inherits(Container,EventEmitter);</td></tr><tr><td class="line">86</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">87</td><td class="hits">1</td><td class="source">module.exports = Container;</td></tr></tbody></table></div><div class="file"><h2 id="/vagrant/app/worker/lib/JobItem.js">/vagrant/app/worker/lib/JobItem.js</h2><div id="stats" class="high"><div class="percentage">97%</div><div class="sloc">38</div><div class="hits">37</div><div class="misses">1</div></div><table id="source"><thead><tr><th>Line</th><th>Hits</th><th>Source</th></tr></thead><tbody><tr class="hit"><td class="line">1</td><td class="hits">1</td><td class="source">"use strict";</td></tr><tr><td class="line">2</td><td class="hits"></td><td class="source">// Result stream</td></tr><tr><td class="line">3</td><td class="hits"></td><td class="source">// =============</td></tr><tr><td class="line">4</td><td class="hits"></td><td class="source">//</td></tr><tr><td class="line">5</td><td class="hits"></td><td class="source">// TODO: describe dependencies</td></tr><tr><td class="line">6</td><td class="hits"></td><td class="source">//</td></tr><tr class="hit"><td class="line">7</td><td class="hits">1</td><td class="source">var stream = require("stream");</td></tr><tr class="hit"><td class="line">8</td><td class="hits">1</td><td class="source">var Writable = stream.Writable;</td></tr><tr class="hit"><td class="line">9</td><td class="hits">1</td><td class="source">var _ = require('lodash');</td></tr><tr class="hit"><td class="line">10</td><td class="hits">1</td><td class="source">var util = require('util');</td></tr><tr><td class="line">11</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">12</td><td class="hits"></td><td class="source">// Implements Writable stream so we be able to pipe into docker container</td></tr><tr><td class="line">13</td><td class="hits"></td><td class="source">// output stream</td></tr><tr><td class="line">14</td><td class="hits"></td><td class="source">//</td></tr><tr><td class="line">15</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">16</td><td class="hits"></td><td class="source">// Constructor function - handles stream initialization</td></tr><tr><td class="line">17</td><td class="hits"></td><td class="source">//</td></tr><tr><td class="line">18</td><td class="hits"></td><td class="source">// Arguments:</td></tr><tr><td class="line">19</td><td class="hits"></td><td class="source">// - `item` __literal__</td></tr><tr><td class="line">20</td><td class="hits"></td><td class="source">// - callback __function__ executed once stream ready to write line of output</td></tr><tr><td class="line">21</td><td class="hits"></td><td class="source">// - options __Stream options__</td></tr><tr class="hit"><td class="line">22</td><td class="hits">1</td><td class="source">var Container = function (item, callback, options) {</td></tr><tr class="hit"><td class="line">23</td><td class="hits">2</td><td class="source"> this.callback = callback;</td></tr><tr><td class="line">24</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">25</td><td class="hits"></td><td class="source"> // Build Id</td></tr><tr class="hit"><td class="line">26</td><td class="hits">2</td><td class="source"> this.id = item.id;</td></tr><tr><td class="line">27</td><td class="hits"></td><td class="source"> // Line number</td></tr><tr class="hit"><td class="line">28</td><td class="hits">2</td><td class="source"> this.lineNum = 0;</td></tr><tr class="hit"><td class="line">29</td><td class="hits">2</td><td class="source"> this.item = item;</td></tr><tr><td class="line">30</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">31</td><td class="hits"></td><td class="source"> // Buffer to hold incomplete chunks (it will be complete once line feed or carriage return detected)</td></tr><tr class="hit"><td class="line">32</td><td class="hits">2</td><td class="source"> this.lineBuffer = "";</td></tr><tr class="hit"><td class="line">33</td><td class="hits">2</td><td class="source"> options = !options ? {} : options;</td></tr><tr class="hit"><td class="line">34</td><td class="hits">2</td><td class="source"> options.objectMode = true;</td></tr><tr><td class="line">35</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">36</td><td class="hits"></td><td class="source"> // Calling parent constructor</td></tr><tr class="hit"><td class="line">37</td><td class="hits">2</td><td class="source"> Writable.call(this, options);</td></tr><tr><td class="line">38</td><td class="hits"></td><td class="source">};</td></tr><tr><td class="line">39</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">40</td><td class="hits"></td><td class="source">// Inheriting from StreamWritable</td></tr><tr class="hit"><td class="line">41</td><td class="hits">1</td><td class="source">util.inherits(Container, Writable);</td></tr><tr><td class="line">42</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">43</td><td class="hits"></td><td class="source">// Handles chunk of data. It will buffer it if line end not detected</td></tr><tr class="hit"><td class="line">44</td><td class="hits">1</td><td class="source">Container.prototype.parse = function (data) {</td></tr><tr class="hit"><td class="line">45</td><td class="hits">4</td><td class="source"> var chars = [</td></tr><tr><td class="line">46</td><td class="hits"></td><td class="source"> {from: /\r\r/g, to: "[#RETURN#]"},</td></tr><tr><td class="line">47</td><td class="hits"></td><td class="source"> {from: /\r\n/g, to: "[#SPLIT#]"},</td></tr><tr><td class="line">48</td><td class="hits"></td><td class="source"> {from: /\n/g, to: "[#SPLIT#]"},</td></tr><tr><td class="line">49</td><td class="hits"></td><td class="source"> {from: /\r/g, to: "[#RETURN#]"},</td></tr><tr><td class="line">50</td><td class="hits"></td><td class="source"> {from: /\r\s/g, to: " "},</td></tr><tr><td class="line">51</td><td class="hits"></td><td class="source"> {from: /\[0G/g, to: "[#RETURN#]"}</td></tr><tr><td class="line">52</td><td class="hits"></td><td class="source"> ];</td></tr><tr><td class="line">53</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">54</td><td class="hits">4</td><td class="source"> var result = data.toString().replace("\u001b[K","").replace("\u001b[2K","");</td></tr><tr class="hit"><td class="line">55</td><td class="hits">4</td><td class="source"> _.each(chars, function (val, idx) {</td></tr><tr class="hit"><td class="line">56</td><td class="hits">24</td><td class="source"> result = result.replace(val.from, val.to);</td></tr><tr><td class="line">57</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">58</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">59</td><td class="hits">4</td><td class="source"> this.lineBuffer += result;</td></tr><tr><td class="line">60</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">61</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">62</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">63</td><td class="hits">4</td><td class="source"> if (/\[#SPLIT#\]/.test(result)) {</td></tr><tr class="hit"><td class="line">64</td><td class="hits">4</td><td class="source"> var lines = [];</td></tr><tr class="hit"><td class="line">65</td><td class="hits">4</td><td class="source"> var result = this.lineBuffer.split("[#SPLIT#]").filter(function (e) {</td></tr><tr class="hit"><td class="line">66</td><td class="hits">8</td><td class="source"> return e</td></tr><tr><td class="line">67</td><td class="hits"></td><td class="source"> });</td></tr><tr class="hit"><td class="line">68</td><td class="hits">4</td><td class="source"> _.each(result, function (l) {</td></tr><tr class="hit"><td class="line">69</td><td class="hits">4</td><td class="source"> lines = lines.concat(l.replace(/(.*)\[#RETURN#\]/g,''));</td></tr><tr><td class="line">70</td><td class="hits"></td><td class="source"> }, this);</td></tr><tr class="hit"><td class="line">71</td><td class="hits">4</td><td class="source"> this.lineBuffer = "";</td></tr><tr class="hit"><td class="line">72</td><td class="hits">4</td><td class="source"> return lines.filter(function (e) {</td></tr><tr class="hit"><td class="line">73</td><td class="hits">4</td><td class="source"> return e != "\\r" && e != ""</td></tr><tr><td class="line">74</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">75</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">76</td><td class="hits"></td><td class="source"> </td></tr><tr class="miss"><td class="line">77</td><td class="hits">0</td><td class="source"> return null;</td></tr><tr><td class="line">78</td><td class="hits"></td><td class="source">};</td></tr><tr><td class="line">79</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">80</td><td class="hits"></td><td class="source">// Handles chunk of data from pipe</td></tr><tr><td class="line">81</td><td class="hits"></td><td class="source">// Note:it may call `this.callback` more than once</td></tr><tr class="hit"><td class="line">82</td><td class="hits">1</td><td class="source">Container.prototype._write = function (chunk, enc, cb) {</td></tr><tr class="hit"><td class="line">83</td><td class="hits">4</td><td class="source"> var lines = this.parse(chunk);</td></tr><tr class="hit"><td class="line">84</td><td class="hits">4</td><td class="source"> if (this.callback && lines) {</td></tr><tr class="hit"><td class="line">85</td><td class="hits">4</td><td class="source"> _.each(lines, function (l) {</td></tr><tr class="hit"><td class="line">86</td><td class="hits">4</td><td class="source"> this.callback({</td></tr><tr><td class="line">87</td><td class="hits"></td><td class="source"> id: this.id,</td></tr><tr><td class="line">88</td><td class="hits"></td><td class="source"> line: this.lineNum++,</td></tr><tr><td class="line">89</td><td class="hits"></td><td class="source"> data: l</td></tr><tr><td class="line">90</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">91</td><td class="hits"></td><td class="source"> }, this);</td></tr><tr><td class="line">92</td><td class="hits"></td><td class="source"> }</td></tr><tr class="hit"><td class="line">93</td><td class="hits">4</td><td class="source"> cb();</td></tr><tr><td class="line">94</td><td class="hits"></td><td class="source">};</td></tr><tr><td class="line">95</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">96</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">97</td><td class="hits">1</td><td class="source">module.exports = Container;</td></tr></tbody></table></div><div class="file"><h2 id="/vagrant/app/worker/lib/Logger.js">/vagrant/app/worker/lib/Logger.js</h2><div id="stats" class="high"><div class="percentage">100%</div><div class="sloc">11</div><div class="hits">11</div><div class="misses">0</div></div><table id="source"><thead><tr><th>Line</th><th>Hits</th><th>Source</th></tr></thead><tbody><tr class="hit"><td class="line">1</td><td class="hits">1</td><td class="source">'use strict';</td></tr><tr class="hit"><td class="line">2</td><td class="hits">1</td><td class="source">var logger = require('winston');</td></tr><tr><td class="line">3</td><td class="hits"></td><td class="source">// Logger configuration</td></tr><tr><td class="line">4</td><td class="hits"></td><td class="source">// ====================</td></tr><tr><td class="line">5</td><td class="hits"></td><td class="source">//</td></tr><tr><td class="line">6</td><td class="hits"></td><td class="source">// Configures Logger instance. Uses `winston` library to log to different destinations</td></tr><tr class="hit"><td class="line">7</td><td class="hits">1</td><td class="source">var Logger = function (env) {</td></tr><tr class="hit"><td class="line">8</td><td class="hits">1</td><td class="source"> env = env || "test";</td></tr><tr class="hit"><td class="line">9</td><td class="hits">1</td><td class="source"> var levels = {</td></tr><tr><td class="line">10</td><td class="hits"></td><td class="source"> "test": "error",</td></tr><tr><td class="line">11</td><td class="hits"></td><td class="source"> "dev": "debug",</td></tr><tr><td class="line">12</td><td class="hits"></td><td class="source"> "production": "info"</td></tr><tr><td class="line">13</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">14</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">15</td><td class="hits">1</td><td class="source"> logger.setLevels({debug: 0, info: 1, silly: 2, warn: 3, error: 4});</td></tr><tr class="hit"><td class="line">16</td><td class="hits">1</td><td class="source"> logger.addColors({debug: 'green', info: 'cyan', silly: 'magenta', warn: 'yellow', error: 'red'});</td></tr><tr class="hit"><td class="line">17</td><td class="hits">1</td><td class="source"> logger.remove(logger.transports.Console);</td></tr><tr class="hit"><td class="line">18</td><td class="hits">1</td><td class="source"> logger.add(logger.transports.Console, { level: levels[env], colorize: true });</td></tr><tr class="hit"><td class="line">19</td><td class="hits">1</td><td class="source"> return logger;</td></tr><tr><td class="line">20</td><td class="hits"></td><td class="source">};</td></tr><tr><td class="line">21</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">22</td><td class="hits">1</td><td class="source">module.exports = Logger;</td></tr><tr><td class="line">23</td><td class="hits"></td><td class="source"> </td></tr></tbody></table></div><div class="file"><h2 id="/vagrant/app/worker/lib/PromisedDocker.js">/vagrant/app/worker/lib/PromisedDocker.js</h2><div id="stats" class="high"><div class="percentage">89%</div><div class="sloc">55</div><div class="hits">49</div><div class="misses">6</div></div><table id="source"><thead><tr><th>Line</th><th>Hits</th><th>Source</th></tr></thead><tbody><tr class="hit"><td class="line">1</td><td class="hits">1</td><td class="source">'use strict';</td></tr><tr class="hit"><td class="line">2</td><td class="hits">1</td><td class="source">var Promise = require("bluebird");</td></tr><tr class="hit"><td class="line">3</td><td class="hits">1</td><td class="source">var Docker = require("dockerode");</td></tr><tr><td class="line">4</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">5</td><td class="hits">1</td><td class="source">var PromisedContainer = function(container){</td></tr><tr class="hit"><td class="line">6</td><td class="hits">10</td><td class="source"> var start = function(options){</td></tr><tr class="hit"><td class="line">7</td><td class="hits">10</td><td class="source"> var promise = Promise.pending();</td></tr><tr class="hit"><td class="line">8</td><td class="hits">10</td><td class="source"> container.start(options, function(err, container){</td></tr><tr class="hit"><td class="line">9</td><td class="hits">10</td><td class="source"> if(err){</td></tr><tr class="miss"><td class="line">10</td><td class="hits">0</td><td class="source"> promise.reject(err);</td></tr><tr><td class="line">11</td><td class="hits"></td><td class="source"> }else{</td></tr><tr class="hit"><td class="line">12</td><td class="hits">10</td><td class="source"> promise.resolve(container);</td></tr><tr><td class="line">13</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">14</td><td class="hits"></td><td class="source"> });</td></tr><tr class="hit"><td class="line">15</td><td class="hits">10</td><td class="source"> return promise.promise;</td></tr><tr><td class="line">16</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">17</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">18</td><td class="hits">10</td><td class="source"> var attach = function(options){</td></tr><tr class="hit"><td class="line">19</td><td class="hits">10</td><td class="source"> var promise = Promise.pending();</td></tr><tr class="hit"><td class="line">20</td><td class="hits">10</td><td class="source"> container.attach(options, function(err, container){</td></tr><tr class="hit"><td class="line">21</td><td class="hits">10</td><td class="source"> if(err){</td></tr><tr class="miss"><td class="line">22</td><td class="hits">0</td><td class="source"> promise.reject(err);</td></tr><tr><td class="line">23</td><td class="hits"></td><td class="source"> }else{</td></tr><tr class="hit"><td class="line">24</td><td class="hits">10</td><td class="source"> promise.resolve(container);</td></tr><tr><td class="line">25</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">26</td><td class="hits"></td><td class="source"> });</td></tr><tr class="hit"><td class="line">27</td><td class="hits">10</td><td class="source"> return promise.promise;</td></tr><tr><td class="line">28</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">29</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">30</td><td class="hits">10</td><td class="source"> var wait = function(){</td></tr><tr class="hit"><td class="line">31</td><td class="hits">6</td><td class="source"> var promise = Promise.pending();</td></tr><tr class="hit"><td class="line">32</td><td class="hits">6</td><td class="source"> container.wait(function(err, data){</td></tr><tr class="hit"><td class="line">33</td><td class="hits">6</td><td class="source"> if(err){</td></tr><tr class="miss"><td class="line">34</td><td class="hits">0</td><td class="source"> promise.reject(err);</td></tr><tr><td class="line">35</td><td class="hits"></td><td class="source"> }else{</td></tr><tr class="hit"><td class="line">36</td><td class="hits">6</td><td class="source"> promise.resolve(data);</td></tr><tr><td class="line">37</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">38</td><td class="hits"></td><td class="source"> });</td></tr><tr class="hit"><td class="line">39</td><td class="hits">6</td><td class="source"> return promise.promise;</td></tr><tr><td class="line">40</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">41</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">42</td><td class="hits">10</td><td class="source"> var stop = function(options){</td></tr><tr class="hit"><td class="line">43</td><td class="hits">4</td><td class="source"> var promise = Promise.pending();</td></tr><tr class="hit"><td class="line">44</td><td class="hits">4</td><td class="source"> container.stop(options, function(err, container){</td></tr><tr class="hit"><td class="line">45</td><td class="hits">4</td><td class="source"> if(err){</td></tr><tr class="miss"><td class="line">46</td><td class="hits">0</td><td class="source"> promise.reject(err);</td></tr><tr><td class="line">47</td><td class="hits"></td><td class="source"> }else{</td></tr><tr class="hit"><td class="line">48</td><td class="hits">4</td><td class="source"> promise.resolve(container);</td></tr><tr><td class="line">49</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">50</td><td class="hits"></td><td class="source"> });</td></tr><tr class="hit"><td class="line">51</td><td class="hits">4</td><td class="source"> return promise.promise;</td></tr><tr><td class="line">52</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">53</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">54</td><td class="hits">10</td><td class="source"> var remove = function(options){</td></tr><tr class="hit"><td class="line">55</td><td class="hits">10</td><td class="source"> var promise = Promise.pending();</td></tr><tr class="hit"><td class="line">56</td><td class="hits">10</td><td class="source"> container.remove(options, function(err, container){</td></tr><tr class="hit"><td class="line">57</td><td class="hits">10</td><td class="source"> if(err){</td></tr><tr class="miss"><td class="line">58</td><td class="hits">0</td><td class="source"> promise.reject(err);</td></tr><tr><td class="line">59</td><td class="hits"></td><td class="source"> }else{</td></tr><tr class="hit"><td class="line">60</td><td class="hits">10</td><td class="source"> promise.resolve(container);</td></tr><tr><td class="line">61</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">62</td><td class="hits"></td><td class="source"> });</td></tr><tr class="hit"><td class="line">63</td><td class="hits">10</td><td class="source"> return promise.promise;</td></tr><tr><td class="line">64</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">65</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">66</td><td class="hits">10</td><td class="source"> var dummy = function(){</td></tr><tr class="hit"><td class="line">67</td><td class="hits">6</td><td class="source"> var promise = Promise.pending();</td></tr><tr class="hit"><td class="line">68</td><td class="hits">6</td><td class="source"> promise.resolve.apply(promise,arguments);</td></tr><tr class="hit"><td class="line">69</td><td class="hits">6</td><td class="source"> return promise.promise;</td></tr><tr><td class="line">70</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">71</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">72</td><td class="hits">10</td><td class="source"> return {</td></tr><tr><td class="line">73</td><td class="hits"></td><td class="source"> start : start,</td></tr><tr><td class="line">74</td><td class="hits"></td><td class="source"> attach : attach,</td></tr><tr><td class="line">75</td><td class="hits"></td><td class="source"> wait : wait,</td></tr><tr><td class="line">76</td><td class="hits"></td><td class="source"> stop : stop,</td></tr><tr><td class="line">77</td><td class="hits"></td><td class="source"> remove : remove,</td></tr><tr><td class="line">78</td><td class="hits"></td><td class="source"> dummy : dummy</td></tr><tr><td class="line">79</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">80</td><td class="hits"></td><td class="source">};</td></tr><tr><td class="line">81</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">82</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">83</td><td class="hits">1</td><td class="source">var PromisedDocker = function(options){</td></tr><tr class="hit"><td class="line">84</td><td class="hits">7</td><td class="source"> var docker = new Docker(options);</td></tr><tr><td class="line">85</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">86</td><td class="hits">7</td><td class="source"> var create = function(options){</td></tr><tr class="hit"><td class="line">87</td><td class="hits">10</td><td class="source"> var promise = Promise.pending();</td></tr><tr class="hit"><td class="line">88</td><td class="hits">10</td><td class="source"> docker.createContainer(options, function(err, container){</td></tr><tr class="hit"><td class="line">89</td><td class="hits">10</td><td class="source"> if(err){</td></tr><tr class="miss"><td class="line">90</td><td class="hits">0</td><td class="source"> promise.reject(err);</td></tr><tr><td class="line">91</td><td class="hits"></td><td class="source"> }else{</td></tr><tr class="hit"><td class="line">92</td><td class="hits">10</td><td class="source"> promise.resolve(new PromisedContainer(container));</td></tr><tr><td class="line">93</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">94</td><td class="hits"></td><td class="source"> });</td></tr><tr class="hit"><td class="line">95</td><td class="hits">10</td><td class="source"> return promise.promise;</td></tr><tr><td class="line">96</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">97</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">98</td><td class="hits">7</td><td class="source"> return {</td></tr><tr><td class="line">99</td><td class="hits"></td><td class="source"> create : create</td></tr><tr><td class="line">100</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">101</td><td class="hits"></td><td class="source">};</td></tr><tr><td class="line">102</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">103</td><td class="hits">1</td><td class="source">module.exports = PromisedDocker;</td></tr></tbody></table></div><div class="file"><h2 id="/vagrant/app/worker/lib/S3ArtifactPersistanceHandler.js">/vagrant/app/worker/lib/S3ArtifactPersistanceHandler.js</h2><div id="stats" class="high"><div class="percentage">94%</div><div class="sloc">17</div><div class="hits">16</div><div class="misses">1</div></div><table id="source"><thead><tr><th>Line</th><th>Hits</th><th>Source</th></tr></thead><tbody><tr class="hit"><td class="line">1</td><td class="hits">1</td><td class="source">'use strict';</td></tr><tr class="hit"><td class="line">2</td><td class="hits">1</td><td class="source">var s3 = require('s3');</td></tr><tr class="hit"><td class="line">3</td><td class="hits">1</td><td class="source">var Path = require('path');</td></tr><tr class="hit"><td class="line">4</td><td class="hits">1</td><td class="source">process.env.NODE_TLS_REJECT_UNAUTHORIZED = 0;</td></tr><tr><td class="line">5</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">6</td><td class="hits">1</td><td class="source">var S3ArtifactPersistanceHandler = function(logger){</td></tr><tr class="hit"><td class="line">7</td><td class="hits">2</td><td class="source"> var client = s3.createClient({</td></tr><tr><td class="line">8</td><td class="hits"></td><td class="source"> s3RetryCount: 6, // this is the default</td></tr><tr><td class="line">9</td><td class="hits"></td><td class="source"> s3RetryDelay: 1000,</td></tr><tr><td class="line">10</td><td class="hits"></td><td class="source"> s3Options: {</td></tr><tr><td class="line">11</td><td class="hits"></td><td class="source"> accessKeyId: process.env.AWS_KEY,</td></tr><tr><td class="line">12</td><td class="hits"></td><td class="source"> secretAccessKey: process.env.AWS_SECRET</td></tr><tr><td class="line">13</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">14</td><td class="hits"></td><td class="source"> });</td></tr><tr class="hit"><td class="line">15</td><td class="hits">2</td><td class="source"> var handle = function(data, done){</td></tr><tr class="hit"><td class="line">16</td><td class="hits">2</td><td class="source"> var params = {</td></tr><tr><td class="line">17</td><td class="hits"></td><td class="source"> localFile: data.artifact.path,</td></tr><tr><td class="line">18</td><td class="hits"></td><td class="source"> s3Params: {</td></tr><tr><td class="line">19</td><td class="hits"></td><td class="source"> Bucket: process.env.S3_BUCKET || "dev-artifact",</td></tr><tr><td class="line">20</td><td class="hits"></td><td class="source"> Key: data.artifact.name + '_' + Path.basename(data.artifact.path),</td></tr><tr><td class="line">21</td><td class="hits"></td><td class="source"> ACL : "public-read"</td></tr><tr><td class="line">22</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">23</td><td class="hits"></td><td class="source"> };</td></tr><tr class="hit"><td class="line">24</td><td class="hits">2</td><td class="source"> var uploader = client.uploadFile(params);</td></tr><tr class="hit"><td class="line">25</td><td class="hits">2</td><td class="source"> uploader.on('error', function(err) {</td></tr><tr class="hit"><td class="line">26</td><td class="hits">2</td><td class="source"> if(err){</td></tr><tr class="hit"><td class="line">27</td><td class="hits">2</td><td class="source"> console.log("UPLOAD FAILED:",err);</td></tr><tr class="hit"><td class="line">28</td><td class="hits">2</td><td class="source"> done(err);</td></tr><tr><td class="line">29</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">30</td><td class="hits"></td><td class="source"> });</td></tr><tr class="hit"><td class="line">31</td><td class="hits">2</td><td class="source"> uploader.on('end', function() {</td></tr><tr class="miss"><td class="line">32</td><td class="hits">0</td><td class="source"> done(null,data.artifact.name + '_' + Path.basename(data.artifact.path));</td></tr><tr><td class="line">33</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">34</td><td class="hits"></td><td class="source"> };</td></tr><tr class="hit"><td class="line">35</td><td class="hits">2</td><td class="source"> return {</td></tr><tr><td class="line">36</td><td class="hits"></td><td class="source"> handle : handle</td></tr><tr><td class="line">37</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">38</td><td class="hits"></td><td class="source">};</td></tr><tr><td class="line">39</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">40</td><td class="hits">1</td><td class="source">module.exports = S3ArtifactPersistanceHandler;</td></tr></tbody></table></div><div class="file"><h2 id="/vagrant/app/worker/lib/Worker.js">/vagrant/app/worker/lib/Worker.js</h2><div id="stats" class="medium"><div class="percentage">72%</div><div class="sloc">87</div><div class="hits">63</div><div class="misses">24</div></div><table id="source"><thead><tr><th>Line</th><th>Hits</th><th>Source</th></tr></thead><tbody><tr class="hit"><td class="line">1</td><td class="hits">1</td><td class="source">'use strict';</td></tr><tr class="hit"><td class="line">2</td><td class="hits">1</td><td class="source">var tmp = require('temporary');</td></tr><tr><td class="line">3</td><td class="hits"></td><td class="source">// Build handler</td></tr><tr><td class="line">4</td><td class="hits"></td><td class="source">// =============</td></tr><tr><td class="line">5</td><td class="hits"></td><td class="source">//</td></tr><tr><td class="line">6</td><td class="hits"></td><td class="source">// TODO: describe dependencies</td></tr><tr><td class="line">7</td><td class="hits"></td><td class="source">//</td></tr><tr><td class="line">8</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">9</td><td class="hits">1</td><td class="source">var Promise = require("bluebird");</td></tr><tr class="hit"><td class="line">10</td><td class="hits">1</td><td class="source">var _ = require("lodash");</td></tr><tr><td class="line">11</td><td class="hits"></td><td class="source">//var Docker = require("dockerode");</td></tr><tr class="hit"><td class="line">12</td><td class="hits">1</td><td class="source">var Docker = Promise.promisifyAll(require('../lib/PromisedDocker'));</td></tr><tr class="hit"><td class="line">13</td><td class="hits">1</td><td class="source">var Container = require('../lib/Container');</td></tr><tr class="hit"><td class="line">14</td><td class="hits">1</td><td class="source">var JobItem = require("/vagrant/app/worker/lib/./JobItem.js");</td></tr><tr><td class="line">15</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">16</td><td class="hits"></td><td class="source">// Handles and configures build execution within docker container.</td></tr><tr><td class="line">17</td><td class="hits"></td><td class="source">//</td></tr><tr><td class="line">18</td><td class="hits"></td><td class="source">// `Worker` uses Revealing Module Pattern for expose simple public interface.</td></tr><tr class="hit"><td class="line">19</td><td class="hits">1</td><td class="source">var Worker = function (options) {</td></tr><tr class="hit"><td class="line">20</td><td class="hits">3</td><td class="source"> var options = _.merge({</td></tr><tr><td class="line">21</td><td class="hits"></td><td class="source"> postProcess : null</td></tr><tr><td class="line">22</td><td class="hits"></td><td class="source"> },options);</td></tr><tr><td class="line">23</td><td class="hits"></td><td class="source"> // `dockerode` instance simplifies use of dockers remote API</td></tr><tr class="hit"><td class="line">24</td><td class="hits">3</td><td class="source"> var docker = new Docker({</td></tr><tr><td class="line">25</td><td class="hits"></td><td class="source"> socketPath: '/var/run/docker.sock'</td></tr><tr><td class="line">26</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">27</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">28</td><td class="hits"></td><td class="source"> // Creates shell script from job order literal</td></tr><tr><td class="line">29</td><td class="hits"></td><td class="source"> // Arguments:</td></tr><tr><td class="line">30</td><td class="hits"></td><td class="source"> // - `config` __literal__</td></tr><tr><td class="line">31</td><td class="hits"></td><td class="source"> // {</td></tr><tr><td class="line">32</td><td class="hits"></td><td class="source"> // payload : {</td></tr><tr><td class="line">33</td><td class="hits"></td><td class="source"> // commands : <Array of commands></td></tr><tr><td class="line">34</td><td class="hits"></td><td class="source"> // },</td></tr><tr><td class="line">35</td><td class="hits"></td><td class="source"> // reposity: {</td></tr><tr><td class="line">36</td><td class="hits"></td><td class="source"> // name : <short name of reposity></td></tr><tr><td class="line">37</td><td class="hits"></td><td class="source"> // uri : <repository uri></td></tr><tr><td class="line">38</td><td class="hits"></td><td class="source"> // },</td></tr><tr><td class="line">39</td><td class="hits"></td><td class="source"> // skipSetup : <boolean></td></tr><tr><td class="line">40</td><td class="hits"></td><td class="source"> // }</td></tr><tr class="hit"><td class="line">41</td><td class="hits">3</td><td class="source"> var prepareScript = function (config,checkoutpath) {</td></tr><tr class="hit"><td class="line">42</td><td class="hits">2</td><td class="source"> var script = [];</td></tr><tr class="hit"><td class="line">43</td><td class="hits">2</td><td class="source"> var commands = config.payload.commands;</td></tr><tr class="hit"><td class="line">44</td><td class="hits">2</td><td class="source"> for (var idx in commands) {</td></tr><tr class="hit"><td class="line">45</td><td class="hits">2</td><td class="source"> script[idx] = "echo '\u001b[32m$ " + commands[idx] + "\u001b[0m'; " + commands[idx] + " || exit 1;";</td></tr><tr><td class="line">46</td><td class="hits"></td><td class="source"> }</td></tr><tr class="hit"><td class="line">47</td><td class="hits">2</td><td class="source"> var setup = config.skipSetup ? "" : "cd "+checkoutpath+" && git clone "+config.reposity.uri+" -b "+config.reposity.branch+" .;";</td></tr><tr class="hit"><td class="line">48</td><td class="hits">2</td><td class="source"> return "(" + setup + script.join('\n') + ")";</td></tr><tr><td class="line">49</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">50</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">51</td><td class="hits">3</td><td class="source"> var getSecondaryContainers = function(containersArr){</td></tr><tr class="hit"><td class="line">52</td><td class="hits">2</td><td class="source"> return _.map(containersArr,function(item){</td></tr><tr class="miss"><td class="line">53</td><td class="hits">0</td><td class="source"> return new Container(docker,{</td></tr><tr><td class="line">54</td><td class="hits"></td><td class="source"> container_name : item.image,</td></tr><tr><td class="line">55</td><td class="hits"></td><td class="source"> name : item.name,</td></tr><tr><td class="line">56</td><td class="hits"></td><td class="source"> command : item.command,</td></tr><tr><td class="line">57</td><td class="hits"></td><td class="source"> stdOut : null</td></tr><tr><td class="line">58</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">59</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">60</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">61</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">62</td><td class="hits">3</td><td class="source"> var getSecondaryLinks = function(containersArr){</td></tr><tr class="hit"><td class="line">63</td><td class="hits">2</td><td class="source"> return _.map(containersArr,function(entry){</td></tr><tr class="miss"><td class="line">64</td><td class="hits">0</td><td class="source"> return entry.name + ":" + entry.alias;</td></tr><tr><td class="line">65</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">66</td><td class="hits"></td><td class="source"> };</td></tr><tr class="hit"><td class="line">67</td><td class="hits">3</td><td class="source"> var startContainers = function(containers){</td></tr><tr class="hit"><td class="line">68</td><td class="hits">2</td><td class="source"> if(containers){</td></tr><tr class="hit"><td class="line">69</td><td class="hits">2</td><td class="source"> return _.map(containers,function(container){</td></tr><tr class="miss"><td class="line">70</td><td class="hits">0</td><td class="source"> return container.start();</td></tr><tr><td class="line">71</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">72</td><td class="hits"></td><td class="source"> }else{</td></tr><tr class="miss"><td class="line">73</td><td class="hits">0</td><td class="source"> var promise = Promise.pending();</td></tr><tr class="miss"><td class="line">74</td><td class="hits">0</td><td class="source"> promise.resolve(true);</td></tr><tr class="miss"><td class="line">75</td><td class="hits">0</td><td class="source"> containers = [promise.promise];</td></tr><tr><td class="line">76</td><td class="hits"></td><td class="source"> }</td></tr><tr class="miss"><td class="line">77</td><td class="hits">0</td><td class="source"> return containers;</td></tr><tr><td class="line">78</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">79</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">80</td><td class="hits">3</td><td class="source"> var stopContainers = function(containers){</td></tr><tr class="hit"><td class="line">81</td><td class="hits">2</td><td class="source"> if(containers){</td></tr><tr class="hit"><td class="line">82</td><td class="hits">2</td><td class="source"> return _.map(containers,function(container){</td></tr><tr class="miss"><td class="line">83</td><td class="hits">0</td><td class="source"> return container.stop();</td></tr><tr><td class="line">84</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">85</td><td class="hits"></td><td class="source"> }else{</td></tr><tr class="miss"><td class="line">86</td><td class="hits">0</td><td class="source"> var promise = Promise.pending();</td></tr><tr class="miss"><td class="line">87</td><td class="hits">0</td><td class="source"> promise.resolve(true);</td></tr><tr class="miss"><td class="line">88</td><td class="hits">0</td><td class="source"> containers = [promise.promise];</td></tr><tr><td class="line">89</td><td class="hits"></td><td class="source"> }</td></tr><tr class="miss"><td class="line">90</td><td class="hits">0</td><td class="source"> return containers;</td></tr><tr><td class="line">91</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">92</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">93</td><td class="hits">3</td><td class="source"> var removeContainers = function(containers){</td></tr><tr class="hit"><td class="line">94</td><td class="hits">2</td><td class="source"> if(containers){</td></tr><tr class="hit"><td class="line">95</td><td class="hits">2</td><td class="source"> return _.map(containers,function(container){</td></tr><tr class="miss"><td class="line">96</td><td class="hits">0</td><td class="source"> return container.remove();</td></tr><tr><td class="line">97</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">98</td><td class="hits"></td><td class="source"> }else{</td></tr><tr class="miss"><td class="line">99</td><td class="hits">0</td><td class="source"> var promise = Promise.pending();</td></tr><tr class="miss"><td class="line">100</td><td class="hits">0</td><td class="source"> promise.resolve(true);</td></tr><tr class="miss"><td class="line">101</td><td class="hits">0</td><td class="source"> containers = [promise.promise];</td></tr><tr><td class="line">102</td><td class="hits"></td><td class="source"> }</td></tr><tr class="miss"><td class="line">103</td><td class="hits">0</td><td class="source"> return containers;</td></tr><tr><td class="line">104</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">105</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">106</td><td class="hits">3</td><td class="source"> var postProcess = function(data,callback){</td></tr><tr class="hit"><td class="line">107</td><td class="hits">2</td><td class="source"> var promise = Promise.pending();</td></tr><tr class="hit"><td class="line">108</td><td class="hits">2</td><td class="source"> if(callback){</td></tr><tr class="hit"><td class="line">109</td><td class="hits">2</td><td class="source"> callback(data, function(err,data){</td></tr><tr class="hit"><td class="line">110</td><td class="hits">2</td><td class="source"> if(err){</td></tr><tr class="hit"><td class="line">111</td><td class="hits">2</td><td class="source"> promise.reject(err);</td></tr><tr><td class="line">112</td><td class="hits"></td><td class="source"> }else{</td></tr><tr class="miss"><td class="line">113</td><td class="hits">0</td><td class="source"> promise.resolve(data);</td></tr><tr><td class="line">114</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">115</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">116</td><td class="hits"></td><td class="source"> }else{</td></tr><tr class="miss"><td class="line">117</td><td class="hits">0</td><td class="source"> promise.resolve(true);</td></tr><tr><td class="line">118</td><td class="hits"></td><td class="source"> }</td></tr><tr class="hit"><td class="line">119</td><td class="hits">2</td><td class="source"> promise.promise;</td></tr><tr><td class="line">120</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">121</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">122</td><td class="hits"></td><td class="source"> // Handles execution of build</td></tr><tr><td class="line">123</td><td class="hits"></td><td class="source"> // Arguments:</td></tr><tr><td class="line">124</td><td class="hits"></td><td class="source"> // - `item` __JobItem__</td></tr><tr class="hit"><td class="line">125</td><td class="hits">3</td><td class="source"> var processItem = function (item) {</td></tr><tr class="hit"><td class="line">126</td><td class="hits">2</td><td class="source"> var dir = new tmp.Dir();</td></tr><tr class="hit"><td class="line">127</td><td class="hits">2</td><td class="source"> var volumes = {};</td></tr><tr class="hit"><td class="line">128</td><td class="hits">2</td><td class="source"> var checkoutpath = "/home/"+item.item.reposity.name;</td></tr><tr class="hit"><td class="line">129</td><td class="hits">2</td><td class="source"> volumes[checkoutpath] = {};</td></tr><tr class="hit"><td class="line">130</td><td class="hits">2</td><td class="source"> var config = item.item;</td></tr><tr class="hit"><td class="line">131</td><td class="hits">2</td><td class="source"> var result = {</td></tr><tr><td class="line">132</td><td class="hits"></td><td class="source"> artifact : {</td></tr><tr><td class="line">133</td><td class="hits"></td><td class="source"> name : [config.reposity.name,config.id].join('_'),</td></tr><tr><td class="line">134</td><td class="hits"></td><td class="source"> path : [dir.path,item.item.artifact_path].join('/')</td></tr><tr><td class="line">135</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">136</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">137</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">138</td><td class="hits">2</td><td class="source"> var secondaryContainers = getSecondaryContainers(config.container.secondary);</td></tr><tr class="hit"><td class="line">139</td><td class="hits">2</td><td class="source"> var secondaryLinks = getSecondaryLinks(config.container.secondary);</td></tr><tr class="hit"><td class="line">140</td><td class="hits">2</td><td class="source"> var primaryContainer = new Container(docker,{</td></tr><tr><td class="line">141</td><td class="hits"></td><td class="source"> stdOut : item,</td></tr><tr><td class="line">142</td><td class="hits"></td><td class="source"> container_name : config.container.primary,</td></tr><tr><td class="line">143</td><td class="hits"></td><td class="source"> name : config.container.name + config.id,</td></tr><tr><td class="line">144</td><td class="hits"></td><td class="source"> command : ['/bin/bash', '-c', prepareScript(item.item,checkoutpath)],</td></tr><tr><td class="line">145</td><td class="hits"></td><td class="source"> timeout : config.config.timeout,</td></tr><tr><td class="line">146</td><td class="hits"></td><td class="source"> volumes : volumes,</td></tr><tr><td class="line">147</td><td class="hits"></td><td class="source"> links : secondaryLinks,</td></tr><tr><td class="line">148</td><td class="hits"></td><td class="source"> binds : dir.path + ":" + checkoutpath</td></tr><tr><td class="line">149</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">150</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">151</td><td class="hits">2</td><td class="source"> primaryContainer.onTimeout(function(data){</td></tr><tr class="miss"><td class="line">152</td><td class="hits">0</td><td class="source"> Promise.all(removeContainers(secondaryContainers)).then(function(){</td></tr><tr class="miss"><td class="line">153</td><td class="hits">0</td><td class="source"> item.emit('timeout',data);</td></tr><tr><td class="line">154</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">155</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">156</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">157</td><td class="hits">2</td><td class="source"> Promise.all(startContainers(secondaryContainers)).then(function(){</td></tr><tr class="hit"><td class="line">158</td><td class="hits">2</td><td class="source"> return primaryContainer.start();</td></tr><tr><td class="line">159</td><td class="hits"></td><td class="source"> }).then(function(){</td></tr><tr class="hit"><td class="line">160</td><td class="hits">2</td><td class="source"> return primaryContainer.wait();</td></tr><tr><td class="line">161</td><td class="hits"></td><td class="source"> }).then(function(data){</td></tr><tr class="hit"><td class="line">162</td><td class="hits">2</td><td class="source"> result = _.merge(result,data);</td></tr><tr class="hit"><td class="line">163</td><td class="hits">2</td><td class="source"> return Promise.all(stopContainers(secondaryContainers));</td></tr><tr><td class="line">164</td><td class="hits"></td><td class="source"> }).then(function(){</td></tr><tr class="hit"><td class="line">165</td><td class="hits">2</td><td class="source"> return Promise.all(removeContainers(secondaryContainers));</td></tr><tr><td class="line">166</td><td class="hits"></td><td class="source"> }).then(function(){</td></tr><tr class="hit"><td class="line">167</td><td class="hits">2</td><td class="source"> return primaryContainer.remove();</td></tr><tr><td class="line">168</td><td class="hits"></td><td class="source"> }).then(function(){</td></tr><tr class="hit"><td class="line">169</td><td class="hits">2</td><td class="source"> return postProcess(result,options.postProcess);</td></tr><tr><td class="line">170</td><td class="hits"></td><td class="source"> }).then(function(){</td></tr><tr class="hit"><td class="line">171</td><td class="hits">2</td><td class="source"> item.emit('complete', result);</td></tr><tr><td class="line">172</td><td class="hits"></td><td class="source"> }).catch(function(status){</td></tr><tr class="miss"><td class="line">173</td><td class="hits">0</td><td class="source"> if(status.statusCode != 404){</td></tr><tr class="miss"><td class="line">174</td><td class="hits">0</td><td class="source"> return item.emit('error', status);</td></tr><tr><td class="line">175</td><td class="hits"></td><td class="source"> }</td></tr><tr class="miss"><td class="line">176</td><td class="hits">0</td><td class="source"> item.emit('complete', result);</td></tr><tr><td class="line">177</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">178</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">179</td><td class="hits"></td><td class="source"> /*</td></tr><tr><td class="line">180</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">181</td><td class="hits"></td><td class="source"> docker.createContainer({</td></tr><tr><td class="line">182</td><td class="hits"></td><td class="source"> Image: item.item.container.primary,</td></tr><tr><td class="line">183</td><td class="hits"></td><td class="source"> AttachStdin: false,</td></tr><tr><td class="line">184</td><td class="hits"></td><td class="source"> AttachStdout: true,</td></tr><tr><td class="line">185</td><td class="hits"></td><td class="source"> AttachStderr: true,</td></tr><tr><td class="line">186</td><td class="hits"></td><td class="source"> Tty: true,</td></tr><tr><td class="line">187</td><td class="hits"></td><td class="source"> Cmd: ['/bin/bash', '-c', script],</td></tr><tr><td class="line">188</td><td class="hits"></td><td class="source"> OpenStdin: false,</td></tr><tr><td class="line">189</td><td class="hits"></td><td class="source"> Volumes : volumes,</td></tr><tr><td class="line">190</td><td class="hits"></td><td class="source"> StdinOnce: false</td></tr><tr><td class="line">191</td><td class="hits"></td><td class="source"> }, function (err, container) {</td></tr><tr><td class="line">192</td><td class="hits"></td><td class="source"> if (err) {</td></tr><tr><td class="line">193</td><td class="hits"></td><td class="source"> item.emit('error', err);</td></tr><tr><td class="line">194</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">195</td><td class="hits"></td><td class="source"> container.attach({stream: true, stdout: true, stderr: true}, function (err, stream) {</td></tr><tr><td class="line">196</td><td class="hits"></td><td class="source"> if (err) {</td></tr><tr><td class="line">197</td><td class="hits"></td><td class="source"> item.emit('error', err);</td></tr><tr><td class="line">198</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">199</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">200</td><td class="hits"></td><td class="source"> stream.setEncoding('utf8');</td></tr><tr><td class="line">201</td><td class="hits"></td><td class="source"> stream.pipe(item, {end: true});</td></tr><tr><td class="line">202</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">203</td><td class="hits"></td><td class="source"> container.start({</td></tr><tr><td class="line">204</td><td class="hits"></td><td class="source"> 'Binds': dir.path+":"+checkoutpath</td></tr><tr><td class="line">205</td><td class="hits"></td><td class="source"> },function (err, data) {</td></tr><tr><td class="line">206</td><td class="hits"></td><td class="source"> if (err) {</td></tr><tr><td class="line">207</td><td class="hits"></td><td class="source"> return item.emit('error', err);</td></tr><tr><td class="line">208</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">209</td><td class="hits"></td><td class="source"> var timeout_handle = setTimeout(function () {</td></tr><tr><td class="line">210</td><td class="hits"></td><td class="source"> container.stop(function (err, data) {</td></tr><tr><td class="line">211</td><td class="hits"></td><td class="source"> item.emit('timeout', {</td></tr><tr><td class="line">212</td><td class="hits"></td><td class="source"> StatusCode: 100</td></tr><tr><td class="line">213</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">214</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">215</td><td class="hits"></td><td class="source"> }, item.item.config.timeout);</td></tr><tr><td class="line">216</td><td class="hits"></td><td class="source"> container.wait(function (err, data) {</td></tr><tr><td class="line">217</td><td class="hits"></td><td class="source"> if (err) {</td></tr><tr><td class="line">218</td><td class="hits"></td><td class="source"> item.emit('error', err);</td></tr><tr><td class="line">219</td><td class="hits"></td><td class="source"> clearTimeout(timeout_handle);</td></tr><tr><td class="line">220</td><td class="hits"></td><td class="source"> } else {</td></tr><tr><td class="line">221</td><td class="hits"></td><td class="source"> clearTimeout(timeout_handle);</td></tr><tr><td class="line">222</td><td class="hits"></td><td class="source"> var completeBuild = function(err,artifact_name){</td></tr><tr><td class="line">223</td><td class="hits"></td><td class="source"> dir.rmdir();</td></tr><tr><td class="line">224</td><td class="hits"></td><td class="source"> item.emit('complete', data, artifact_name);</td></tr><tr><td class="line">225</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">226</td><td class="hits"></td><td class="source"> if(!item.item.artifact_path){</td></tr><tr><td class="line">227</td><td class="hits"></td><td class="source"> completeBuild();</td></tr><tr><td class="line">228</td><td class="hits"></td><td class="source"> }else{</td></tr><tr><td class="line">229</td><td class="hits"></td><td class="source"> var artifact_name = [item.item.reposity.name,item.item.id].join('_');</td></tr><tr><td class="line">230</td><td class="hits"></td><td class="source"> item.emit('handle_artifact', dir.path+"/"+item.item.artifact_path, artifact_name,completeBuild);</td></tr><tr><td class="line">231</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">232</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">233</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">234</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">235</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">236</td><td class="hits"></td><td class="source"> });</td></tr><tr><td class="line">237</td><td class="hits"></td><td class="source"> });*/</td></tr><tr><td class="line">238</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">239</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">240</td><td class="hits">3</td><td class="source"> var putItem = function (item, callback) {</td></tr><tr class="hit"><td class="line">241</td><td class="hits">2</td><td class="source"> var res = new JobItem(item, callback);</td></tr><tr class="hit"><td class="line">242</td><td class="hits">2</td><td class="source"> processItem(res);</td></tr><tr class="hit"><td class="line">243</td><td class="hits">2</td><td class="source"> return res;</td></tr><tr><td class="line">244</td><td class="hits"></td><td class="source"> };</td></tr><tr><td class="line">245</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">246</td><td class="hits"></td><td class="source"> </td></tr><tr><td class="line">247</td><td class="hits"></td><td class="source"> // Exposes public interface</td></tr><tr class="hit"><td class="line">248</td><td class="hits">3</td><td class="source"> return {</td></tr><tr><td class="line">249</td><td class="hits"></td><td class="source"> prepare: prepareScript,</td></tr><tr><td class="line">250</td><td class="hits"></td><td class="source"> put: putItem</td></tr><tr><td class="line">251</td><td class="hits"></td><td class="source"> }</td></tr><tr><td class="line">252</td><td class="hits"></td><td class="source">};</td></tr><tr><td class="line">253</td><td class="hits"></td><td class="source"> </td></tr><tr class="hit"><td class="line">254</td><td class="hits">1</td><td class="source">module.exports = Worker;</td></tr></tbody></table></div></div></div></body></html>