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/mpi_helper.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/mpi_helper.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-mpi_helper_rb.html">/home/cgb/clients/main/main-cgb-research/Neptune/mpi_helper.rb</a></td>
31
<td class='right_align'><tt>214</tt></td>
32
<td class='right_align'><tt>149</tt></td>
33
<td class="left_align"><div class="percent_graph_legend"><tt class=''>19.16%</tt></div>
34
<div class="percent_graph">
35
<div class="covered" style="width:19px"></div>
36
<div class="uncovered" style="width:81px"></div>
38
<td class="left_align"><div class="percent_graph_legend"><tt class=''>12.75%</tt></div>
39
<div class="percent_graph">
40
<div class="covered" style="width:13px"></div>
41
<div class="uncovered" style="width:87px"></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> #!/usr/bin/ruby</pre></td>
66
<td><pre><a name="line2">2</a> # Programmer: Chris Bunch</pre></td>
72
<td><pre><a name="line3">3</a> </pre></td>
78
<td><pre><a name="line4">4</a> </pre></td>
84
<td><pre><a name="line5">5</a> $:.unshift File.join(File.dirname(__FILE__), "..", "AppController")</pre></td>
90
<td><pre><a name="line6">6</a> require 'djinn'</pre></td>
96
<td><pre><a name="line7">7</a> </pre></td>
101
<tr class="inferred">
102
<td><pre><a name="line8">8</a> </pre></td>
108
<td><pre><a name="line9">9</a> $:.unshift File.join(File.dirname(__FILE__), "..", "AppController", "lib")</pre></td>
114
<td><pre><a name="line10">10</a> require 'datastore_factory'</pre></td>
119
<tr class="inferred">
120
<td><pre><a name="line11">11</a> </pre></td>
125
<tr class="inferred">
126
<td><pre><a name="line12">12</a> </pre></td>
132
<td><pre><a name="line13">13</a> MPD_HOSTS = "/tmp/mpd.hosts"</pre></td>
138
<td><pre><a name="line14">14</a> MPI_OUTPUT = "/tmp/thempioutput"</pre></td>
143
<tr class="inferred">
144
<td><pre><a name="line15">15</a> </pre></td>
150
<td><pre><a name="line16">16</a> public </pre></td>
155
<tr class="inferred">
156
<td><pre><a name="line17">17</a> </pre></td>
162
<td><pre><a name="line18">18</a> def neptune_mpi_run_job(nodes, job_data, secret)</pre></td>
167
<tr class="uncovered">
168
<td><pre><a name="line19">19</a> return BAD_SECRET_MSG unless valid_secret?(secret)</pre></td>
173
<tr class="uncovered">
174
<td><pre><a name="line20">20</a> Djinn.log_debug("mpi - run")</pre></td>
179
<tr class="uncovered">
180
<td><pre><a name="line21">21</a> </pre></td>
185
<tr class="uncovered">
186
<td><pre><a name="line22">22</a> Thread.new {</pre></td>
191
<tr class="uncovered">
192
<td><pre><a name="line23">23</a> keyname = @creds['keyname']</pre></td>
197
<tr class="uncovered">
198
<td><pre><a name="line24">24</a> nodes = Djinn.convert_location_array_to_class(nodes, keyname)</pre></td>
203
<tr class="uncovered">
204
<td><pre><a name="line25">25</a> </pre></td>
209
<tr class="uncovered">
210
<td><pre><a name="line26">26</a> ENV['LD_LIBRARY_PATH'] = "/usr/lib"</pre></td>
215
<tr class="uncovered">
216
<td><pre><a name="line27">27</a> Djinn.log_debug("library path = #{ENV['LD_LIBRARY_PATH']}")</pre></td>
221
<tr class="uncovered">
222
<td><pre><a name="line28">28</a> </pre></td>
227
<tr class="uncovered">
228
<td><pre><a name="line29">29</a> start_nfs(nodes)</pre></td>
233
<tr class="uncovered">
234
<td><pre><a name="line30">30</a> </pre></td>
239
<tr class="uncovered">
240
<td><pre><a name="line31">31</a> sleep(5) # CGB</pre></td>
245
<tr class="uncovered">
246
<td><pre><a name="line32">32</a> </pre></td>
251
<tr class="uncovered">
252
<td><pre><a name="line33">33</a> shadow = get_shadow</pre></td>
257
<tr class="uncovered">
258
<td><pre><a name="line34">34</a> shadow_ip = shadow.private_ip</pre></td>
263
<tr class="uncovered">
264
<td><pre><a name="line35">35</a> shadow_key = shadow.ssh_key</pre></td>
269
<tr class="uncovered">
270
<td><pre><a name="line36">36</a> </pre></td>
275
<tr class="uncovered">
276
<td><pre><a name="line37">37</a> Djinn.log_run("rm -rfv /mirrornfs/*")</pre></td>
281
<tr class="uncovered">
282
<td><pre><a name="line38">38</a> </pre></td>
287
<tr class="uncovered">
288
<td><pre><a name="line39">39</a> remote = job_data['@code']</pre></td>
293
<tr class="uncovered">
294
<td><pre><a name="line40">40</a> splitted_code = remote.split('/')</pre></td>
299
<tr class="uncovered">
300
<td><pre><a name="line41">41</a> remote_dir = splitted_code[0..splitted_code.length-2].join('/')</pre></td>
305
<tr class="uncovered">
306
<td><pre><a name="line42">42</a> filename_to_exec = splitted_code[2..splitted_code.length-1].join('/')</pre></td>
311
<tr class="uncovered">
312
<td><pre><a name="line43">43</a> Djinn.log_debug("remote dir is [#{remote_dir}], filename_to_exec is #{filename_to_exec}")</pre></td>
317
<tr class="uncovered">
318
<td><pre><a name="line44">44</a> </pre></td>
323
<tr class="uncovered">
324
<td><pre><a name="line45">45</a> storage = job_data['@storage']</pre></td>
329
<tr class="uncovered">
330
<td><pre><a name="line46">46</a> </pre></td>
335
<tr class="uncovered">
336
<td><pre><a name="line47">47</a> unless my_node.is_shadow?</pre></td>
341
<tr class="uncovered">
342
<td><pre><a name="line48">48</a> Djinn.log_run("rm -fv /tmp/#{filename_to_exec}")</pre></td>
347
<tr class="uncovered">
348
<td><pre><a name="line49">49</a> end</pre></td>
353
<tr class="uncovered">
354
<td><pre><a name="line50">50</a> </pre></td>
359
<tr class="uncovered">
360
<td><pre><a name="line51">51</a> # TODO(cgb): should remote_dir be remote_dir/ to prevent also getting</pre></td>
365
<tr class="uncovered">
366
<td><pre><a name="line52">52</a> # remote_dir2,3, etc?</pre></td>
371
<tr class="uncovered">
372
<td><pre><a name="line53">53</a> datastore = DatastoreFactory.get_datastore(storage, job_data)</pre></td>
377
<tr class="uncovered">
378
<td><pre><a name="line54">54</a> datastore.get_output_and_save_to_fs(remote_dir, "/mirrornfs/")</pre></td>
383
<tr class="uncovered">
384
<td><pre><a name="line55">55</a> sleep(5)</pre></td>
389
<tr class="uncovered">
390
<td><pre><a name="line56">56</a> Djinn.log_run("chmod +x /mirrornfs/#{filename_to_exec}")</pre></td>
395
<tr class="uncovered">
396
<td><pre><a name="line57">57</a> sleep(5)</pre></td>
401
<tr class="uncovered">
402
<td><pre><a name="line58">58</a> </pre></td>
407
<tr class="uncovered">
408
<td><pre><a name="line59">59</a> start_mpd(nodes)</pre></td>
413
<tr class="uncovered">
414
<td><pre><a name="line60">60</a> sleep(5)</pre></td>
419
<tr class="uncovered">
420
<td><pre><a name="line61">61</a> </pre></td>
425
<tr class="uncovered">
426
<td><pre><a name="line62">62</a> if job_data["@procs_to_use"]</pre></td>
431
<tr class="uncovered">
432
<td><pre><a name="line63">63</a> num_of_procs = job_data["@procs_to_use"]</pre></td>
437
<tr class="uncovered">
438
<td><pre><a name="line64">64</a> else</pre></td>
443
<tr class="uncovered">
444
<td><pre><a name="line65">65</a> num_of_procs = nodes.length</pre></td>
449
<tr class="uncovered">
450
<td><pre><a name="line66">66</a> end</pre></td>
455
<tr class="uncovered">
456
<td><pre><a name="line67">67</a> </pre></td>
461
<tr class="uncovered">
462
<td><pre><a name="line68">68</a> # Some job types (e.g., kdt) need to specify something a program to use</pre></td>
467
<tr class="uncovered">
468
<td><pre><a name="line69">69</a> # to run the user's code (e.g., Python), so let them do so via the</pre></td>
473
<tr class="uncovered">
474
<td><pre><a name="line70">70</a> # executable parameter.</pre></td>
479
<tr class="uncovered">
480
<td><pre><a name="line71">71</a> if job_data["@executable"]</pre></td>
485
<tr class="uncovered">
486
<td><pre><a name="line72">72</a> executable = job_data["@executable"]</pre></td>
491
<tr class="uncovered">
492
<td><pre><a name="line73">73</a> else</pre></td>
497
<tr class="uncovered">
498
<td><pre><a name="line74">74</a> executable = ""</pre></td>
503
<tr class="uncovered">
504
<td><pre><a name="line75">75</a> end</pre></td>
509
<tr class="uncovered">
510
<td><pre><a name="line76">76</a> </pre></td>
515
<tr class="uncovered">
516
<td><pre><a name="line77">77</a> # If the user specifies an argv to pass to the code to exec, be sure to</pre></td>
521
<tr class="uncovered">
522
<td><pre><a name="line78">78</a> # capture it and pass it along</pre></td>
527
<tr class="uncovered">
528
<td><pre><a name="line79">79</a> if job_data["@argv"]</pre></td>
533
<tr class="uncovered">
534
<td><pre><a name="line80">80</a> argv = job_data["@argv"]</pre></td>
539
<tr class="uncovered">
540
<td><pre><a name="line81">81</a> # TODO(cgb): filter out colons and other things that malicious users could</pre></td>
545
<tr class="uncovered">
546
<td><pre><a name="line82">82</a> # use to hijack the system</pre></td>
551
<tr class="uncovered">
552
<td><pre><a name="line83">83</a> else</pre></td>
557
<tr class="uncovered">
558
<td><pre><a name="line84">84</a> argv = ""</pre></td>
563
<tr class="uncovered">
564
<td><pre><a name="line85">85</a> end</pre></td>
569
<tr class="uncovered">
570
<td><pre><a name="line86">86</a> </pre></td>
575
<tr class="uncovered">
576
<td><pre><a name="line87">87</a> output_file = "/tmp/mpi-output-#{rand()}"</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> start_time = Time.now</pre></td>
593
<tr class="uncovered">
594
<td><pre><a name="line90">90</a> Djinn.log_run("mpiexec -env X10_NTHREADS 1 -n #{num_of_procs} " +</pre></td>
599
<tr class="uncovered">
600
<td><pre><a name="line91">91</a> "#{executable} /mirrornfs/#{filename_to_exec} #{argv} > #{output_file}")</pre></td>
605
<tr class="uncovered">
606
<td><pre><a name="line92">92</a> end_time = Time.now</pre></td>
611
<tr class="uncovered">
612
<td><pre><a name="line93">93</a> </pre></td>
617
<tr class="uncovered">
618
<td><pre><a name="line94">94</a> total = end_time - start_time</pre></td>
623
<tr class="uncovered">
624
<td><pre><a name="line95">95</a> Djinn.log_debug("MPI: Done running job!")</pre></td>
629
<tr class="uncovered">
630
<td><pre><a name="line96">96</a> Djinn.log_debug("TIMING: Took #{total} seconds")</pre></td>
635
<tr class="uncovered">
636
<td><pre><a name="line97">97</a> </pre></td>
641
<tr class="uncovered">
642
<td><pre><a name="line98">98</a> stop_mpd()</pre></td>
647
<tr class="uncovered">
648
<td><pre><a name="line99">99</a> </pre></td>
653
<tr class="uncovered">
654
<td><pre><a name="line100">100</a> stop_nfs(nodes)</pre></td>
659
<tr class="uncovered">
660
<td><pre><a name="line101">101</a> </pre></td>
665
<tr class="uncovered">
666
<td><pre><a name="line102">102</a> datastore.write_remote_file_from_local_file(job_data['@output'], output_file)</pre></td>
671
<tr class="uncovered">
672
<td><pre><a name="line103">103</a> </pre></td>
677
<tr class="uncovered">
678
<td><pre><a name="line104">104</a> # clean up after ourselves - remove the user's code</pre></td>
683
<tr class="uncovered">
684
<td><pre><a name="line105">105</a> Djinn.log_run("rm -rfv /mirrornfs/*")</pre></td>
689
<tr class="uncovered">
690
<td><pre><a name="line106">106</a> Djinn.log_run("rm -rfv #{output_file}")</pre></td>
695
<tr class="uncovered">
696
<td><pre><a name="line107">107</a> </pre></td>
701
<tr class="uncovered">
702
<td><pre><a name="line108">108</a> remove_lock_file(job_data)</pre></td>
707
<tr class="uncovered">
708
<td><pre><a name="line109">109</a> }</pre></td>
713
<tr class="uncovered">
714
<td><pre><a name="line110">110</a> </pre></td>
719
<tr class="uncovered">
720
<td><pre><a name="line111">111</a> return "OK"</pre></td>
725
<tr class="uncovered">
726
<td><pre><a name="line112">112</a> end</pre></td>
731
<tr class="inferred">
732
<td><pre><a name="line113">113</a> </pre></td>
738
<td><pre><a name="line114">114</a> private</pre></td>
743
<tr class="inferred">
744
<td><pre><a name="line115">115</a> </pre></td>
750
<td><pre><a name="line116">116</a> def neptune_mpi_get_output(job_data)</pre></td>
755
<tr class="uncovered">
756
<td><pre><a name="line117">117</a> return MPI_OUTPUT</pre></td>
761
<tr class="uncovered">
762
<td><pre><a name="line118">118</a> end </pre></td>
767
<tr class="inferred">
768
<td><pre><a name="line119">119</a> </pre></td>
774
<td><pre><a name="line120">120</a> def start_nfs(nodes)</pre></td>
779
<tr class="uncovered">
780
<td><pre><a name="line121">121</a> Djinn.log_run("/etc/init.d/nfs-kernel-server start")</pre></td>
785
<tr class="uncovered">
786
<td><pre><a name="line122">122</a> sleep(10)</pre></td>
791
<tr class="uncovered">
792
<td><pre><a name="line123">123</a> </pre></td>
797
<tr class="uncovered">
798
<td><pre><a name="line124">124</a> slave_nodes = nodes - [my_node]</pre></td>
803
<tr class="uncovered">
804
<td><pre><a name="line125">125</a> return if slave_nodes.empty?</pre></td>
809
<tr class="uncovered">
810
<td><pre><a name="line126">126</a> </pre></td>
815
<tr class="uncovered">
816
<td><pre><a name="line127">127</a> slave_mount = "mount #{my_node.private_ip}:/mirrornfs /mirrornfs"</pre></td>
821
<tr class="uncovered">
822
<td><pre><a name="line128">128</a> slave_nodes.each { |node|</pre></td>
827
<tr class="uncovered">
828
<td><pre><a name="line129">129</a> Djinn.log_debug("[nfs master] node at #{node.private_ip} is currently doing #{node.jobs.join(', ')}")</pre></td>
833
<tr class="uncovered">
834
<td><pre><a name="line130">130</a> next if node.private_ip == my_node.private_ip</pre></td>
839
<tr class="uncovered">
840
<td><pre><a name="line131">131</a> Djinn.log_debug("mounting /mirrornfs on machine located at [#{node.private_ip}]")</pre></td>
845
<tr class="uncovered">
846
<td><pre><a name="line132">132</a> HelperFunctions.run_remote_command(node.private_ip, slave_mount, node.ssh_key, NO_OUTPUT)</pre></td>
851
<tr class="uncovered">
852
<td><pre><a name="line133">133</a> }</pre></td>
857
<tr class="uncovered">
858
<td><pre><a name="line134">134</a> </pre></td>
863
<tr class="uncovered">
864
<td><pre><a name="line135">135</a> sleep(10)</pre></td>
869
<tr class="uncovered">
870
<td><pre><a name="line136">136</a> end</pre></td>
875
<tr class="inferred">
876
<td><pre><a name="line137">137</a> </pre></td>
882
<td><pre><a name="line138">138</a> def stop_nfs(nodes)</pre></td>
887
<tr class="uncovered">
888
<td><pre><a name="line139">139</a> slave_nodes = nodes - [my_node]</pre></td>
893
<tr class="uncovered">
894
<td><pre><a name="line140">140</a> </pre></td>
899
<tr class="uncovered">
900
<td><pre><a name="line141">141</a> unless slave_nodes.empty?</pre></td>
905
<tr class="uncovered">
906
<td><pre><a name="line142">142</a> slave_nodes.each { |node|</pre></td>
911
<tr class="uncovered">
912
<td><pre><a name="line143">143</a> next if node.private_ip == my_node.private_ip</pre></td>
917
<tr class="uncovered">
918
<td><pre><a name="line144">144</a> unmount_nfs_store(node.private_ip, node.ssh_key)</pre></td>
923
<tr class="uncovered">
924
<td><pre><a name="line145">145</a> }</pre></td>
929
<tr class="uncovered">
930
<td><pre><a name="line146">146</a> end</pre></td>
935
<tr class="uncovered">
936
<td><pre><a name="line147">147</a> </pre></td>
941
<tr class="uncovered">
942
<td><pre><a name="line148">148</a> Djinn.log_run("/etc/init.d/nfs-kernel-server stop")</pre></td>
947
<tr class="uncovered">
948
<td><pre><a name="line149">149</a> </pre></td>
953
<tr class="uncovered">
954
<td><pre><a name="line150">150</a> nodes.each { |node|</pre></td>
959
<tr class="uncovered">
960
<td><pre><a name="line151">151</a> Djinn.log_run("ssh #{node.private_ip} 'ps ax | grep nfs'")</pre></td>
965
<tr class="uncovered">
966
<td><pre><a name="line152">152</a> sleep(1)</pre></td>
971
<tr class="uncovered">
972
<td><pre><a name="line153">153</a> }</pre></td>
977
<tr class="uncovered">
978
<td><pre><a name="line154">154</a> end</pre></td>
983
<tr class="inferred">
984
<td><pre><a name="line155">155</a> </pre></td>
990
<td><pre><a name="line156">156</a> def unmount_nfs_store(ip, ssh_key)</pre></td>
995
<tr class="uncovered">
996
<td><pre><a name="line157">157</a> slave_umount = "umount /mirrornfs"</pre></td>
1001
<tr class="uncovered">
1002
<td><pre><a name="line158">158</a> </pre></td>
1007
<tr class="uncovered">
1008
<td><pre><a name="line159">159</a> loop {</pre></td>
1013
<tr class="uncovered">
1014
<td><pre><a name="line160">160</a> Djinn.log_debug("unmounting mirrornfs at #{ip} with ssh key #{ssh_key}")</pre></td>
1019
<tr class="uncovered">
1020
<td><pre><a name="line161">161</a> HelperFunctions.run_remote_command(ip, slave_umount, ssh_key, NO_OUTPUT)</pre></td>
1025
<tr class="uncovered">
1026
<td><pre><a name="line162">162</a> sleep(5)</pre></td>
1031
<tr class="uncovered">
1032
<td><pre><a name="line163">163</a> mount_status = `ssh root@#{ip} 'mount'`</pre></td>
1037
<tr class="uncovered">
1038
<td><pre><a name="line164">164</a> nfs_mounted = mount_status.scan(/mirrornfs/)</pre></td>
1043
<tr class="uncovered">
1044
<td><pre><a name="line165">165</a> Djinn.log_debug("NFS mount status at #{ip} is [#{nfs_mounted}]")</pre></td>
1049
<tr class="uncovered">
1050
<td><pre><a name="line166">166</a> </pre></td>
1055
<tr class="uncovered">
1056
<td><pre><a name="line167">167</a> if nfs_mounted == []</pre></td>
1061
<tr class="uncovered">
1062
<td><pre><a name="line168">168</a> Djinn.log_debug("NFS is stopped at #{ip}")</pre></td>
1067
<tr class="uncovered">
1068
<td><pre><a name="line169">169</a> break</pre></td>
1073
<tr class="uncovered">
1074
<td><pre><a name="line170">170</a> else</pre></td>
1079
<tr class="uncovered">
1080
<td><pre><a name="line171">171</a> Djinn.log_debug("NFS still not stopped at #{ip}")</pre></td>
1085
<tr class="uncovered">
1086
<td><pre><a name="line172">172</a> end</pre></td>
1091
<tr class="uncovered">
1092
<td><pre><a name="line173">173</a> }</pre></td>
1097
<tr class="uncovered">
1098
<td><pre><a name="line174">174</a> end</pre></td>
1103
<tr class="inferred">
1104
<td><pre><a name="line175">175</a> </pre></td>
1110
<td><pre><a name="line176">176</a> def start_mpd(nodes)</pre></td>
1115
<tr class="uncovered">
1116
<td><pre><a name="line177">177</a> mpd_hosts_contents = ""</pre></td>
1121
<tr class="uncovered">
1122
<td><pre><a name="line178">178</a> nodes.each { |node|</pre></td>
1127
<tr class="uncovered">
1128
<td><pre><a name="line179">179</a> mpd_hosts_contents << "#{node.private_ip}\n"</pre></td>
1133
<tr class="uncovered">
1134
<td><pre><a name="line180">180</a> }</pre></td>
1139
<tr class="uncovered">
1140
<td><pre><a name="line181">181</a> mpd_hosts_contents.chomp!</pre></td>
1145
<tr class="uncovered">
1146
<td><pre><a name="line182">182</a> Djinn.log_debug("MPD Hosts are: #{mpd_hosts_contents}")</pre></td>
1151
<tr class="uncovered">
1152
<td><pre><a name="line183">183</a> HelperFunctions.write_file(MPD_HOSTS, mpd_hosts_contents) </pre></td>
1157
<tr class="uncovered">
1158
<td><pre><a name="line184">184</a> </pre></td>
1163
<tr class="uncovered">
1164
<td><pre><a name="line185">185</a> ssh_keys = []</pre></td>
1169
<tr class="uncovered">
1170
<td><pre><a name="line186">186</a> nodes.each { |node|</pre></td>
1175
<tr class="uncovered">
1176
<td><pre><a name="line187">187</a> ssh_keys << node.ssh_key</pre></td>
1181
<tr class="uncovered">
1182
<td><pre><a name="line188">188</a> }</pre></td>
1187
<tr class="uncovered">
1188
<td><pre><a name="line189">189</a> ssh_keys.uniq!</pre></td>
1193
<tr class="uncovered">
1194
<td><pre><a name="line190">190</a> </pre></td>
1199
<tr class="uncovered">
1200
<td><pre><a name="line191">191</a> Djinn.log_run("mpdboot -r 'ssh -o StrictHostkeyChecking=no -i #{ssh_keys.join(' -i ')}' -f #{MPD_HOSTS} -n #{nodes.length}")</pre></td>
1205
<tr class="uncovered">
1206
<td><pre><a name="line192">192</a> end</pre></td>
1211
<tr class="inferred">
1212
<td><pre><a name="line193">193</a> </pre></td>
1218
<td><pre><a name="line194">194</a> def stop_mpd()</pre></td>
1223
<tr class="uncovered">
1224
<td><pre><a name="line195">195</a> Djinn.log_run("mpdallexit")</pre></td>
1229
<tr class="uncovered">
1230
<td><pre><a name="line196">196</a> `rm -fv #{MPD_HOSTS}`</pre></td>
1235
<tr class="uncovered">
1236
<td><pre><a name="line197">197</a> end</pre></td>
1241
<tr class="inferred">
1242
<td><pre><a name="line198">198</a> </pre></td>
1248
<td><pre><a name="line199">199</a> def start_mpi_master()</pre></td>
1253
<tr class="uncovered">
1254
<td><pre><a name="line200">200</a> Djinn.log_debug("#{my_node.private_ip} is starting mpi master")</pre></td>
1259
<tr class="uncovered">
1260
<td><pre><a name="line201">201</a> end</pre></td>
1265
<tr class="inferred">
1266
<td><pre><a name="line202">202</a> </pre></td>
1272
<td><pre><a name="line203">203</a> def start_mpi_slave()</pre></td>
1277
<tr class="uncovered">
1278
<td><pre><a name="line204">204</a> Djinn.log_debug("#{my_node.private_ip} is starting mpi slave")</pre></td>
1283
<tr class="uncovered">
1284
<td><pre><a name="line205">205</a> end</pre></td>
1289
<tr class="inferred">
1290
<td><pre><a name="line206">206</a> </pre></td>
1296
<td><pre><a name="line207">207</a> def stop_mpi_master()</pre></td>
1301
<tr class="uncovered">
1302
<td><pre><a name="line208">208</a> Djinn.log_debug("#{my_node.private_ip} is stopping mpi master")</pre></td>
1307
<tr class="uncovered">
1308
<td><pre><a name="line209">209</a> end</pre></td>
1313
<tr class="inferred">
1314
<td><pre><a name="line210">210</a> </pre></td>
1320
<td><pre><a name="line211">211</a> def stop_mpi_slave()</pre></td>
1325
<tr class="uncovered">
1326
<td><pre><a name="line212">212</a> Djinn.log_debug("#{my_node.private_ip} is stopping mpi slave")</pre></td>
1331
<tr class="uncovered">
1332
<td><pre><a name="line213">213</a> end</pre></td>
1337
<tr class="inferred">
1338
<td><pre><a name="line214">214</a> </pre></td>
1344
<p>Generated on Sun Feb 26 23:19:26 -0800 2012 with <a href="http://github.com/relevance/rcov">rcov 0.9.8</a></p>