1
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
2
<html lang='en' xml:lang='en' xmlns='http://www.w3.org/1999/xhtml'>
4
<title>/home/cgb/clients/main/main-cgb-research/Neptune/task_engine.rb</title>
5
<link href="screen.css" media="all" rel="stylesheet" type="text/css" />
6
<link href="print.css" media="print" rel="stylesheet" type="text/css" />
8
<meta http-equiv="Content-type" content="text/html;charset=UTF-8" />
9
<script type="text/javascript" src="rcov.js"></script>
12
<h1>Appcontroller C0 Coverage Information - RCov</h1>
13
<h2>/home/cgb/clients/main/main-cgb-research/Neptune/task_engine.rb</h2>
17
<div class="report_table_wrapper">
18
<table class='report' id='report_table'>
21
<th class="left_align">Name</th>
22
<th class="right_align">Total Lines</th>
23
<th class="right_align">Lines of Code</th>
24
<th class="left_align">Total Coverage</th>
25
<th class="left_align">Code Coverage</th>
30
<td class="left_align"><a href="-home-cgb-clients-main-main-cgb-research-Neptune-task_engine_rb.html">/home/cgb/clients/main/main-cgb-research/Neptune/task_engine.rb</a></td>
31
<td class='right_align'><tt>103</tt></td>
32
<td class='right_align'><tt>72</tt></td>
33
<td class="left_align"><div class="percent_graph_legend"><tt class=''>32.04%</tt></div>
34
<div class="percent_graph">
35
<div class="covered" style="width:32px"></div>
36
<div class="uncovered" style="width:68px"></div>
38
<td class="left_align"><div class="percent_graph_legend"><tt class=''>16.67%</tt></div>
39
<div class="percent_graph">
40
<div class="covered" style="width:17px"></div>
41
<div class="uncovered" style="width:83px"></div>
50
<div class="key"><pre><span class='marked'>Code reported as executed by Ruby looks like this...</span><span class='marked1'>and this: this line is also marked as covered.</span><span class='inferred'>Lines considered as run by rcov, but not reported by Ruby, look like this,</span><span class='inferred1'>and this: these lines were inferred by rcov (using simple heuristics).</span><span class='uncovered'>Finally, here's a line marked as not executed.</span></pre></div>
52
<h3>Coverage Details</h3>
54
<table class="details">
60
<td><pre><a name="line1">1</a> </pre></td>
66
<td><pre><a name="line2">2</a> class TaskEngine</pre></td>
72
<td><pre><a name="line3">3</a> def initialize(credentials)</pre></td>
77
<tr class="uncovered">
78
<td><pre><a name="line4">4</a> raise NotImplementedError</pre></td>
83
<tr class="uncovered">
84
<td><pre><a name="line5">5</a> end</pre></td>
90
<td><pre><a name="line6">6</a> </pre></td>
96
<td><pre><a name="line7">7</a> </pre></td>
102
<td><pre><a name="line8">8</a> def push(job_data)</pre></td>
107
<tr class="uncovered">
108
<td><pre><a name="line9">9</a> dir = Djinn.create_temp_dir()</pre></td>
113
<tr class="uncovered">
114
<td><pre><a name="line10">10</a> Djinn.copy_code_to_dir(job_data, dir)</pre></td>
119
<tr class="uncovered">
120
<td><pre><a name="line11">11</a> </pre></td>
125
<tr class="uncovered">
126
<td><pre><a name="line12">12</a> if app_needs_uploading?(job_data)</pre></td>
131
<tr class="uncovered">
132
<td><pre><a name="line13">13</a> app_location = build_app_via_oration(job_data, dir)</pre></td>
137
<tr class="uncovered">
138
<td><pre><a name="line14">14</a> upload_app(job_data, app_location)</pre></td>
143
<tr class="uncovered">
144
<td><pre><a name="line15">15</a> end</pre></td>
149
<tr class="uncovered">
150
<td><pre><a name="line16">16</a> </pre></td>
155
<tr class="uncovered">
156
<td><pre><a name="line17">17</a> job_data['@host'] = get_app_url(job_data)</pre></td>
161
<tr class="uncovered">
162
<td><pre><a name="line18">18</a> task_id = run_task(job_data)</pre></td>
167
<tr class="uncovered">
168
<td><pre><a name="line19">19</a> wait_for_task_to_finish(job_data, task_id)</pre></td>
173
<tr class="uncovered">
174
<td><pre><a name="line20">20</a> save_output_to_datastore(job_data)</pre></td>
179
<tr class="uncovered">
180
<td><pre><a name="line21">21</a> Djinn.cleanup(dir)</pre></td>
185
<tr class="uncovered">
186
<td><pre><a name="line22">22</a> end</pre></td>
191
<tr class="inferred">
192
<td><pre><a name="line23">23</a> </pre></td>
197
<tr class="inferred">
198
<td><pre><a name="line24">24</a> </pre></td>
204
<td><pre><a name="line25">25</a> def app_needs_uploading?(job_data)</pre></td>
209
<tr class="uncovered">
210
<td><pre><a name="line26">26</a> raise NotImplementedError</pre></td>
215
<tr class="uncovered">
216
<td><pre><a name="line27">27</a> end</pre></td>
221
<tr class="inferred">
222
<td><pre><a name="line28">28</a> </pre></td>
227
<tr class="inferred">
228
<td><pre><a name="line29">29</a> </pre></td>
234
<td><pre><a name="line30">30</a> def build_app_via_oration(job_data, dir)</pre></td>
239
<tr class="uncovered">
240
<td><pre><a name="line31">31</a> Djinn.log_debug("building app via oration")</pre></td>
245
<tr class="uncovered">
246
<td><pre><a name="line32">32</a> Djinn.log_debug("job data is #{job_data.inspect}")</pre></td>
251
<tr class="uncovered">
252
<td><pre><a name="line33">33</a> file = job_data['@code']</pre></td>
257
<tr class="uncovered">
258
<td><pre><a name="line34">34</a> output = dir + "/appengine-app"</pre></td>
263
<tr class="uncovered">
264
<td><pre><a name="line35">35</a> </pre></td>
269
<tr class="uncovered">
270
<td><pre><a name="line36">36</a> # TODO(cgb) - definitely check the return val here</pre></td>
275
<tr class="uncovered">
276
<td><pre><a name="line37">37</a> Djinn.log_run("oration --file #{file} --function #{@function} " +</pre></td>
281
<tr class="uncovered">
282
<td><pre><a name="line38">38</a> "--appid #{@appid} --output #{output}")</pre></td>
287
<tr class="uncovered">
288
<td><pre><a name="line39">39</a> return output</pre></td>
293
<tr class="uncovered">
294
<td><pre><a name="line40">40</a> end</pre></td>
299
<tr class="inferred">
300
<td><pre><a name="line41">41</a> </pre></td>
305
<tr class="inferred">
306
<td><pre><a name="line42">42</a> </pre></td>
312
<td><pre><a name="line43">43</a> def upload_app(job_data, app_location)</pre></td>
317
<tr class="uncovered">
318
<td><pre><a name="line44">44</a> raise NotImplementedError</pre></td>
323
<tr class="uncovered">
324
<td><pre><a name="line45">45</a> end</pre></td>
329
<tr class="inferred">
330
<td><pre><a name="line46">46</a> </pre></td>
335
<tr class="inferred">
336
<td><pre><a name="line47">47</a> </pre></td>
342
<td><pre><a name="line48">48</a> def get_app_url(job_data)</pre></td>
347
<tr class="uncovered">
348
<td><pre><a name="line49">49</a> raise NotImplementedError</pre></td>
353
<tr class="uncovered">
354
<td><pre><a name="line50">50</a> end</pre></td>
359
<tr class="inferred">
360
<td><pre><a name="line51">51</a> </pre></td>
365
<tr class="inferred">
366
<td><pre><a name="line52">52</a> </pre></td>
372
<td><pre><a name="line53">53</a> def run_task(job_data)</pre></td>
377
<tr class="uncovered">
378
<td><pre><a name="line54">54</a> Djinn.log_debug("running a task in #{engine_name()}")</pre></td>
383
<tr class="uncovered">
384
<td><pre><a name="line55">55</a> host = job_data['@host']</pre></td>
389
<tr class="uncovered">
390
<td><pre><a name="line56">56</a> </pre></td>
395
<tr class="uncovered">
396
<td><pre><a name="line57">57</a> if job_data['@argv'].nil? or job_data['@argv'].empty?</pre></td>
401
<tr class="uncovered">
402
<td><pre><a name="line58">58</a> inputs = []</pre></td>
407
<tr class="uncovered">
408
<td><pre><a name="line59">59</a> else</pre></td>
413
<tr class="uncovered">
414
<td><pre><a name="line60">60</a> inputs = job_data['@argv']</pre></td>
419
<tr class="uncovered">
420
<td><pre><a name="line61">61</a> end</pre></td>
425
<tr class="uncovered">
426
<td><pre><a name="line62">62</a> </pre></td>
431
<tr class="uncovered">
432
<td><pre><a name="line63">63</a> return Djinn.execute_task(host, job_data['@function'], inputs, </pre></td>
437
<tr class="uncovered">
438
<td><pre><a name="line64">64</a> job_data['@output'])</pre></td>
443
<tr class="uncovered">
444
<td><pre><a name="line65">65</a> end</pre></td>
449
<tr class="inferred">
450
<td><pre><a name="line66">66</a> </pre></td>
455
<tr class="inferred">
456
<td><pre><a name="line67">67</a> </pre></td>
462
<td><pre><a name="line68">68</a> def wait_for_task_to_finish(job_data, task_id)</pre></td>
467
<tr class="uncovered">
468
<td><pre><a name="line69">69</a> Djinn.log_debug("waiting for #{engine_name()} task to finish")</pre></td>
473
<tr class="uncovered">
474
<td><pre><a name="line70">70</a> host = job_data['@host']</pre></td>
479
<tr class="uncovered">
480
<td><pre><a name="line71">71</a> Djinn.wait_for_task_to_complete(host, task_id)</pre></td>
485
<tr class="uncovered">
486
<td><pre><a name="line72">72</a> end</pre></td>
491
<tr class="inferred">
492
<td><pre><a name="line73">73</a> </pre></td>
497
<tr class="inferred">
498
<td><pre><a name="line74">74</a> </pre></td>
504
<td><pre><a name="line75">75</a> def save_output_to_datastore(job_data)</pre></td>
509
<tr class="uncovered">
510
<td><pre><a name="line76">76</a> Djinn.log_debug("copying output from #{engine_name()} to remote datastore")</pre></td>
515
<tr class="uncovered">
516
<td><pre><a name="line77">77</a> </pre></td>
521
<tr class="uncovered">
522
<td><pre><a name="line78">78</a> host = job_data['@host']</pre></td>
527
<tr class="uncovered">
528
<td><pre><a name="line79">79</a> output_location = job_data['@output']</pre></td>
533
<tr class="uncovered">
534
<td><pre><a name="line80">80</a> output = Djinn.get_output(host, output_location)</pre></td>
539
<tr class="uncovered">
540
<td><pre><a name="line81">81</a> </pre></td>
545
<tr class="uncovered">
546
<td><pre><a name="line82">82</a> Djinn.log_debug("got output from #{engine_name()} app at [#{host}], " +</pre></td>
551
<tr class="uncovered">
552
<td><pre><a name="line83">83</a> "stored at [#{output_location}], storing to remote datastore")</pre></td>
557
<tr class="uncovered">
558
<td><pre><a name="line84">84</a> </pre></td>
563
<tr class="uncovered">
564
<td><pre><a name="line85">85</a> local_output = "/tmp/babel-#{rand()}.txt"</pre></td>
569
<tr class="uncovered">
570
<td><pre><a name="line86">86</a> HelperFunctions.write_file(local_output, output)</pre></td>
575
<tr class="uncovered">
576
<td><pre><a name="line87">87</a> Djinn.save_output(local_output, job_data)</pre></td>
581
<tr class="uncovered">
582
<td><pre><a name="line88">88</a> </pre></td>
587
<tr class="uncovered">
588
<td><pre><a name="line89">89</a> return if DEBUG</pre></td>
593
<tr class="uncovered">
594
<td><pre><a name="line90">90</a> Djinn.log_debug("cleaning up local output at #{local_output}")</pre></td>
599
<tr class="uncovered">
600
<td><pre><a name="line91">91</a> FileUtils.rm_f(local_output)</pre></td>
605
<tr class="uncovered">
606
<td><pre><a name="line92">92</a> end</pre></td>
611
<tr class="inferred">
612
<td><pre><a name="line93">93</a> </pre></td>
617
<tr class="inferred">
618
<td><pre><a name="line94">94</a> </pre></td>
624
<td><pre><a name="line95">95</a> def to_s()</pre></td>
629
<tr class="uncovered">
630
<td><pre><a name="line96">96</a> return "Engine type: #{engine_name()}"</pre></td>
635
<tr class="uncovered">
636
<td><pre><a name="line97">97</a> end</pre></td>
641
<tr class="inferred">
642
<td><pre><a name="line98">98</a> </pre></td>
647
<tr class="inferred">
648
<td><pre><a name="line99">99</a> </pre></td>
654
<td><pre><a name="line100">100</a> def engine_name()</pre></td>
659
<tr class="uncovered">
660
<td><pre><a name="line101">101</a> raise NotImplementedError</pre></td>
665
<tr class="uncovered">
666
<td><pre><a name="line102">102</a> end</pre></td>
671
<tr class="uncovered">
672
<td><pre><a name="line103">103</a> end</pre></td>
678
<p>Generated on Sun Feb 26 23:19:27 -0800 2012 with <a href="http://github.com/relevance/rcov">rcov 0.9.8</a></p>