fuel-astute/coverage/rcov/spec-unit-orchestrator_spec...

1329 lines
60 KiB
HTML

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html lang='en' xml:lang='en' xmlns='http://www.w3.org/1999/xhtml'>
<head>
<title>spec/unit/orchestrator_spec.rb</title>
<link href="./assets/0.2.3/screen.css" media="all" rel="stylesheet" type="text/css" />
<link href="./assets/0.2.3/print.css" media="print" rel="stylesheet" type="text/css" />
<meta http-equiv="Content-type" content="text/html;charset=UTF-8" />
<script type="text/javascript" src="./assets/0.2.3/rcov.js"></script>
</head>
<body>
<h1>Astute C0 Coverage Information - Simploco - RCov</h1>
<h2>spec/unit/orchestrator_spec.rb</h2>
<div class="report_table_wrapper">
<table class='report' id='report_table'>
<thead>
<tr>
<th class="left_align">Name</th>
<th class="right_align">Total Lines</th>
<th class="right_align">Lines of Code</th>
<th class="left_align">Total Coverage</th>
<th class="left_align">Code Coverage</th>
</tr>
</thead>
<tbody>
<tr>
<td class="left_align"><a href="spec-unit-orchestrator_spec_rb.html">spec/unit/orchestrator_spec.rb</a></td>
<td class='right_align'><tt>423</tt></td>
<td class='right_align'><tt>183</tt></td>
<td class="left_align"><div class="percent_graph_legend"><tt class=''>98.58%</tt></div>
<div class="percent_graph">
<div class="covered" style="width:99px"></div>
<div class="uncovered" style="width:1px"></div>
</div></td>
<td class="left_align"><div class="percent_graph_legend"><tt class=''>96.72%</tt></div>
<div class="percent_graph">
<div class="covered" style="width:97px"></div>
<div class="uncovered" style="width:3px"></div>
</div></td>
</tr>
</tbody>
</table>
</div>
<h3>Key</h3>
<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>
<h3>Coverage Details</h3>
<table class="details">
<tbody>
<tr class="inferred">
<td><pre><a name="line2">2</a> # Copyright 2013 Mirantis, Inc.</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line3">3</a> #</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line4">4</a> # Licensed under the Apache License, Version 2.0 (the &quot;License&quot;); you may</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line5">5</a> # not use this file except in compliance with the License. You may obtain</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line6">6</a> # a copy of the License at</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line7">7</a> #</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line8">8</a> # http://www.apache.org/licenses/LICENSE-2.0</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line9">9</a> #</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line10">10</a> # Unless required by applicable law or agreed to in writing, software</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line11">11</a> # distributed under the License is distributed on an &quot;AS IS&quot; BASIS, WITHOUT</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line12">12</a> # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line13">13</a> # License for the specific language governing permissions and limitations</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line14">14</a> # under the License.</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line15">15</a> </pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line16">16</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line17">17</a> require File.join(File.dirname(__FILE__), '../spec_helper')</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line18">18</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line19">19</a> describe Astute::Orchestrator do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line20">20</a> include SpecHelpers</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line21">21</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line22">22</a> before(:each) do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line23">23</a> @orchestrator = Astute::Orchestrator.new</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line24">24</a> @reporter = mock('reporter')</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line25">25</a> @reporter.stub_everything</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line26">26</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line27">27</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line28">28</a> describe '#verify_networks' do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line29">29</a> def make_nodes(*uids)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line30">30</a> uids.map do |uid|</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line31">31</a> {</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line32">32</a> 'uid' =&gt; uid.to_s,</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line33">33</a> 'networks' =&gt; [</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line34">34</a> {</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line35">35</a> 'iface' =&gt; 'eth0',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line36">36</a> 'vlans' =&gt; [100, 101]</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line37">37</a> }</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line38">38</a> ]</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line39">39</a> }</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line40">40</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line41">41</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line42">42</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line43">43</a> it &quot;must be able to complete&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line44">44</a> nodes = make_nodes(1, 2)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line45">45</a> res1 = {</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line46">46</a> :data =&gt; {</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line47">47</a> :uid =&gt; &quot;1&quot;,</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line48">48</a> :neighbours =&gt; {</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line49">49</a> &quot;eth0&quot; =&gt; {</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line50">50</a> &quot;100&quot; =&gt; {&quot;1&quot; =&gt; [&quot;eth0&quot;], &quot;2&quot; =&gt; [&quot;eth0&quot;]},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line51">51</a> &quot;101&quot; =&gt; {&quot;1&quot; =&gt; [&quot;eth0&quot;]}}}},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line52">52</a> :sender =&gt; &quot;1&quot;}</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line53">53</a> res2 = {</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line54">54</a> :data =&gt; {</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line55">55</a> :uid =&gt; &quot;2&quot;,</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line56">56</a> :neighbours =&gt; {</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line57">57</a> &quot;eth0&quot; =&gt; {</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line58">58</a> &quot;100&quot; =&gt; {&quot;1&quot; =&gt; [&quot;eth0&quot;], &quot;2&quot; =&gt; [&quot;eth0&quot;]},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line59">59</a> &quot;101&quot; =&gt; {&quot;1&quot; =&gt; [&quot;eth0&quot;], &quot;2&quot; =&gt; [&quot;eth0&quot;]}</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line60">60</a> }}},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line61">61</a> :sender =&gt; &quot;2&quot;}</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line62">62</a> valid_res = {:statuscode =&gt; 0, :sender =&gt; '1'}</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line63">63</a> mc_res1 = mock_mc_result(res1)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line64">64</a> mc_res2 = mock_mc_result(res2)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line65">65</a> mc_valid_res = mock_mc_result</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line66">66</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line67">67</a> rpcclient = mock_rpcclient(nodes)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line68">68</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line69">69</a> rpcclient.expects(:get_probing_info).once.returns([mc_res1, mc_res2])</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line70">70</a> nodes.each do |node|</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line71">71</a> rpcclient.expects(:discover).with(:nodes =&gt; [node['uid']]).at_least_once</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line72">72</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line73">73</a> data_to_send = {}</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line74">74</a> node['networks'].each{ |net| data_to_send[net['iface']] = net['vlans'].join(&quot;,&quot;) }</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line75">75</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line76">76</a> rpcclient.expects(:start_frame_listeners).</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line77">77</a> with(:interfaces =&gt; data_to_send.to_json).</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line78">78</a> returns([mc_valid_res]*2)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line79">79</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line80">80</a> rpcclient.expects(:send_probing_frames).</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line81">81</a> with(:interfaces =&gt; data_to_send.to_json).</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line82">82</a> returns([mc_valid_res]*2)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line83">83</a> end</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line84">84</a> Astute::MClient.any_instance.stubs(:rpcclient).returns(rpcclient)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line85">85</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line86">86</a> res = @orchestrator.verify_networks(@reporter, 'task_uuid', nodes)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line87">87</a> expected = {&quot;nodes&quot; =&gt; [{&quot;networks&quot; =&gt; [{&quot;iface&quot;=&gt;&quot;eth0&quot;, &quot;vlans&quot;=&gt;[100]}], &quot;uid&quot;=&gt;&quot;1&quot;},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line88">88</a> {&quot;networks&quot;=&gt;[{&quot;iface&quot;=&gt;&quot;eth0&quot;, &quot;vlans&quot;=&gt;[100, 101]}], &quot;uid&quot;=&gt;&quot;2&quot;}]}</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line89">89</a> res.should eql(expected)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line90">90</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line91">91</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line92">92</a> it &quot;returns error if nodes list is empty&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line93">93</a> res = @orchestrator.verify_networks(@reporter, 'task_uuid', [])</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line94">94</a> res.should eql({'status' =&gt; 'error', 'error' =&gt; &quot;Network verification requires a minimum of two nodes.&quot;})</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line95">95</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line96">96</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line97">97</a> it &quot;returns all vlans passed if only one node provided&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line98">98</a> nodes = make_nodes(1)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line99">99</a> res = @orchestrator.verify_networks(@reporter, 'task_uuid', nodes)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line100">100</a> expected = {&quot;nodes&quot; =&gt; [{&quot;uid&quot;=&gt;&quot;1&quot;, &quot;networks&quot; =&gt; [{&quot;iface&quot;=&gt;&quot;eth0&quot;, &quot;vlans&quot;=&gt;[100, 101]}]}]}</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line101">101</a> res.should eql(expected)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line102">102</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line103">103</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line104">104</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line105">105</a> it &quot;must be able to return node type&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line106">106</a> nodes = [{'uid' =&gt; '1'}]</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line107">107</a> res = {:data =&gt; {:node_type =&gt; 'target'},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line108">108</a> :sender=&gt;&quot;1&quot;}</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line109">109</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line110">110</a> mc_res = mock_mc_result(res)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line111">111</a> mc_timeout = 5</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line112">112</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line113">113</a> rpcclient = mock_rpcclient(nodes, mc_timeout)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line114">114</a> rpcclient.expects(:get_type).once.returns([mc_res])</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line115">115</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line116">116</a> types = @orchestrator.node_type(@reporter, 'task_uuid', nodes, mc_timeout)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line117">117</a> types.should eql([{&quot;node_type&quot;=&gt;&quot;target&quot;, &quot;uid&quot;=&gt;&quot;1&quot;}])</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line118">118</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line119">119</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line120">120</a> it &quot;in remove_nodes, it returns empty list if nodes are not provided&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line121">121</a> res = @orchestrator.remove_nodes(@reporter, 'task_uuid', [])</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line122">122</a> res.should eql({'nodes' =&gt; []})</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line123">123</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line124">124</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line125">125</a> it &quot;remove_nodes cleans nodes and reboots them&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line126">126</a> removed_hash = {:sender =&gt; '1',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line127">127</a> :data =&gt; {:rebooted =&gt; true}}</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line128">128</a> error_hash = {:sender =&gt; '2',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line129">129</a> :data =&gt; {:rebooted =&gt; false, :error_msg =&gt; 'Could not reboot'}}</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line130">130</a> nodes = [{'uid' =&gt; 1}, {'uid' =&gt; 2}]</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line131">131</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line132">132</a> rpcclient = mock_rpcclient</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line133">133</a> mc_removed_res = mock_mc_result(removed_hash)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line134">134</a> mc_error_res = mock_mc_result(error_hash)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line135">135</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line136">136</a> rpcclient.expects(:erase_node).at_least_once.with(:reboot =&gt; true).returns([mc_removed_res, mc_error_res])</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line137">137</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line138">138</a> res = @orchestrator.remove_nodes(@reporter, 'task_uuid', nodes)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line139">139</a> res.should eql({'nodes' =&gt; [{'uid' =&gt; '1'}], 'status' =&gt; 'error',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line140">140</a> 'error_nodes' =&gt; [{&quot;uid&quot;=&gt;&quot;2&quot;, &quot;error&quot;=&gt;&quot;RPC method 'erase_node' failed &quot;\</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line141">141</a> &quot;with message: Could not reboot&quot;}]})</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line142">142</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line143">143</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line144">144</a> it &quot;it calls deploy method with valid arguments&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line145">145</a> nodes = [{'uid' =&gt; 1}]</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line146">146</a> attrs = {'a' =&gt; 'b'}</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line147">147</a> Astute::DeploymentEngine::NailyFact.any_instance.expects(:deploy).</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line148">148</a> with([{'uid' =&gt; '1'}], attrs)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line149">149</a> @orchestrator.deploy(@reporter, 'task_uuid', nodes, attrs)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line150">150</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line151">151</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line152">152</a> it &quot;deploy method raises error if nodes list is empty&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line153">153</a> expect {@orchestrator.deploy(@reporter, 'task_uuid', [], {})}.</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line154">154</a> to raise_error(/Nodes to deploy are not provided!/)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line155">155</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line156">156</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line157">157</a> it &quot;remove_nodes try to call MCAgent multiple times on error&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line158">158</a> removed_hash = {:sender =&gt; '1',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line159">159</a> :data =&gt; {:rebooted =&gt; true}}</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line160">160</a> error_hash = {:sender =&gt; '2',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line161">161</a> :data =&gt; {:rebooted =&gt; false, :error_msg =&gt; 'Could not reboot'}}</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line162">162</a> nodes = [{'uid' =&gt; 1}, {'uid' =&gt; 2}]</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line163">163</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line164">164</a> rpcclient = mock_rpcclient(nodes)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line165">165</a> mc_removed_res = mock_mc_result(removed_hash)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line166">166</a> mc_error_res = mock_mc_result(error_hash)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line167">167</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line168">168</a> retries = Astute.config[:MC_RETRIES]</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line169">169</a> retries.should == 5</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line170">170</a> rpcclient.expects(:discover).with(:nodes =&gt; ['2']).times(retries)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line171">171</a> rpcclient.expects(:erase_node).times(retries + 1).with(:reboot =&gt; true).returns([mc_removed_res, mc_error_res]).then.returns([mc_error_res])</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line172">172</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line173">173</a> res = @orchestrator.remove_nodes(@reporter, 'task_uuid', nodes)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line174">174</a> res.should eql({'nodes' =&gt; [{'uid' =&gt; '1'}], 'status' =&gt; 'error',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line175">175</a> 'error_nodes' =&gt; [{&quot;uid&quot;=&gt;&quot;2&quot;, &quot;error&quot;=&gt;&quot;RPC method 'erase_node' failed &quot;\</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line176">176</a> &quot;with message: Could not reboot&quot;}]})</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line177">177</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line178">178</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line179">179</a> it &quot;remove_nodes try to call MCAgent multiple times on no response&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line180">180</a> removed_hash = {:sender =&gt; '2', :data =&gt; {:rebooted =&gt; true}}</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line181">181</a> then_removed_hash = {:sender =&gt; '3', :data =&gt; {:rebooted =&gt; true}}</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line182">182</a> nodes = [{'uid' =&gt; 1}, {'uid' =&gt; 2}, {'uid' =&gt; 3}]</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line183">183</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line184">184</a> rpcclient = mock_rpcclient(nodes)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line185">185</a> mc_removed_res = mock_mc_result(removed_hash)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line186">186</a> mc_then_removed_res = mock_mc_result(then_removed_hash)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line187">187</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line188">188</a> retries = Astute.config[:MC_RETRIES]</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line189">189</a> rpcclient.expects(:discover).with(:nodes =&gt; %w(1 3)).times(1)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line190">190</a> rpcclient.expects(:discover).with(:nodes =&gt; %w(1)).times(retries - 1)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line191">191</a> rpcclient.expects(:erase_node).times(retries + 1).with(:reboot =&gt; true).</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line192">192</a> returns([mc_removed_res]).then.returns([mc_then_removed_res]).then.returns([])</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line193">193</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line194">194</a> res = @orchestrator.remove_nodes(@reporter, 'task_uuid', nodes)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line195">195</a> res['nodes'] = res['nodes'].sort_by{|n| n['uid'] }</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line196">196</a> res.should eql({'nodes' =&gt; [{'uid' =&gt; '2'}, {'uid' =&gt; '3'}],</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line197">197</a> 'inaccessible_nodes' =&gt; [{'uid'=&gt;'1', 'error'=&gt;'Node not answered by RPC.'}]})</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line198">198</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line199">199</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line200">200</a> it &quot;remove_nodes and returns early if retries were successful&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line201">201</a> removed_hash = {:sender =&gt; '1', :data =&gt; {:rebooted =&gt; true}}</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line202">202</a> then_removed_hash = {:sender =&gt; '2', :data =&gt; {:rebooted =&gt; true}}</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line203">203</a> nodes = [{'uid' =&gt; 1}, {'uid' =&gt; 2}]</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line204">204</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line205">205</a> rpcclient = mock_rpcclient(nodes)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line206">206</a> mc_removed_res = mock_mc_result(removed_hash)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line207">207</a> mc_then_removed_res = mock_mc_result(then_removed_hash)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line208">208</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line209">209</a> retries = Astute.config[:MC_RETRIES]</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line210">210</a> retries.should_not == 2</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line211">211</a> rpcclient.expects(:discover).with(:nodes =&gt; %w(2)).times(1)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line212">212</a> rpcclient.expects(:erase_node).times(2).with(:reboot =&gt; true).</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line213">213</a> returns([mc_removed_res]).then.returns([mc_then_removed_res])</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line214">214</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line215">215</a> res = @orchestrator.remove_nodes(@reporter, 'task_uuid', nodes)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line216">216</a> res['nodes'] = res['nodes'].sort_by{|n| n['uid'] }</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line217">217</a> res.should eql({'nodes' =&gt; [{'uid' =&gt; '1'}, {'uid' =&gt; '2'}]})</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line218">218</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line219">219</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line220">220</a> it &quot;remove_nodes do not fail if any of nodes failed&quot;</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line221">221</a> </pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line222">222</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line223">223</a> before(:all) do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line224">224</a> @data = {</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line225">225</a> &quot;engine&quot;=&gt;{</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line226">226</a> &quot;url&quot;=&gt;&quot;http://localhost/cobbler_api&quot;, </pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line227">227</a> &quot;username&quot;=&gt;&quot;cobbler&quot;, </pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line228">228</a> &quot;password&quot;=&gt;&quot;cobbler&quot;</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line229">229</a> }, </pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line230">230</a> &quot;task_uuid&quot;=&gt;&quot;a5c44b9a-285a-4a0c-ae65-2ed6b3d250f4&quot;,</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line231">231</a> &quot;nodes&quot; =&gt; [</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line232">232</a> {</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line233">233</a> 'uid' =&gt; '1',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line234">234</a> 'profile' =&gt; 'centos-x86_64',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line235">235</a> &quot;name&quot;=&gt;&quot;controller-1&quot;,</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line236">236</a> 'power_type' =&gt; 'ssh',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line237">237</a> 'power_user' =&gt; 'root',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line238">238</a> 'power_pass' =&gt; '/root/.ssh/bootstrap.rsa',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line239">239</a> 'power-address' =&gt; '1.2.3.5',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line240">240</a> 'hostname' =&gt; 'name.domain.tld',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line241">241</a> 'name_servers' =&gt; '1.2.3.4 1.2.3.100',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line242">242</a> 'name_servers_search' =&gt; 'some.domain.tld domain.tld',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line243">243</a> 'netboot_enabled' =&gt; '1',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line244">244</a> 'ks_meta' =&gt; 'some_param=1 another_param=2',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line245">245</a> 'interfaces' =&gt; {</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line246">246</a> 'eth0' =&gt; {</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line247">247</a> 'mac_address' =&gt; '00:00:00:00:00:00',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line248">248</a> 'static' =&gt; '1',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line249">249</a> 'netmask' =&gt; '255.255.255.0',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line250">250</a> 'ip_address' =&gt; '1.2.3.5',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line251">251</a> 'dns_name' =&gt; 'node.mirantis.net',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line252">252</a> },</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line253">253</a> 'eth1' =&gt; {</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line254">254</a> 'mac_address' =&gt; '00:00:00:00:00:01',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line255">255</a> 'static' =&gt; '0',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line256">256</a> 'netmask' =&gt; '255.255.255.0',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line257">257</a> 'ip_address' =&gt; '1.2.3.6',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line258">258</a> }</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line259">259</a> },</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line260">260</a> 'interfaces_extra' =&gt; {</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line261">261</a> 'eth0' =&gt; {</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line262">262</a> 'peerdns' =&gt; 'no',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line263">263</a> 'onboot' =&gt; 'yes',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line264">264</a> },</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line265">265</a> 'eth1' =&gt; {</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line266">266</a> 'peerdns' =&gt; 'no',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line267">267</a> 'onboot' =&gt; 'yes',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line268">268</a> }</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line269">269</a> }</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line270">270</a> }</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line271">271</a> ]</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line272">272</a> }.freeze</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line273">273</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line274">274</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line275">275</a> describe '#fast_provision' do</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line276">276</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line277">277</a> context 'cobler cases' do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line278">278</a> it &quot;raise error if cobler settings empty&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line279">279</a> expect {@orchestrator.fast_provision(@reporter, {}, @data['nodes'])}.</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line280">280</a> to raise_error(StopIteration)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line281">281</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line282">282</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line283">283</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line284">284</a> context 'node state cases' do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line285">285</a> before(:each) do</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line286">286</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line287">287</a> remote = mock() do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line288">288</a> stubs(:call)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line289">289</a> stubs(:call).with('login', 'cobbler', 'cobbler').returns('remotetoken')</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line290">290</a> end</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line291">291</a> @tmp = XMLRPC::Client</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line292">292</a> XMLRPC::Client = mock() do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line293">293</a> stubs(:new).returns(remote)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line294">294</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line295">295</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line296">296</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line297">297</a> it &quot;raises error if nodes list is empty&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line298">298</a> expect {@orchestrator.fast_provision(@reporter, @data['engine'], {})}.</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line299">299</a> to raise_error(/Nodes to provision are not provided!/)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line300">300</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line301">301</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line302">302</a> it &quot;try to reboot nodes from list&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line303">303</a> Astute::Provision::Cobbler.any_instance do</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line304">304</a> expects(:power_reboot).with('controller-1')</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line305">305</a> end</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line306">306</a> @orchestrator.stubs(:check_reboot_nodes).returns([])</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line307">307</a> @orchestrator.fast_provision(@reporter, @data['engine'], @data['nodes'])</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line308">308</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line309">309</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line310">310</a> before(:each) { Astute::Provision::Cobbler.any_instance.stubs(:power_reboot).returns(333) }</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line311">311</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line312">312</a> context 'node reboot success' do</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line313">313</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line314">314</a> before(:each) { Astute::Provision::Cobbler.any_instance.stubs(:event_status).</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line315">315</a> returns([Time.now.to_f, 'controller-1', 'complete'])}</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line316">316</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line317">317</a> it &quot;does not find failed nodes&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line318">318</a> Astute::Provision::Cobbler.any_instance.stubs(:event_status).</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line319">319</a> returns([Time.now.to_f, 'controller-1', 'complete'])</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line320">320</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line321">321</a> @orchestrator.fast_provision(@reporter, @data['engine'], @data['nodes'])</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line322">322</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line323">323</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line324">324</a> it &quot;report about success&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line325">325</a> @reporter.expects(:report).with({'status' =&gt; 'ready', 'progress' =&gt; 100}).returns(true)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line326">326</a> @orchestrator.fast_provision(@reporter, @data['engine'], @data['nodes'])</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line327">327</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line328">328</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line329">329</a> it &quot;sync engine state&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line330">330</a> Astute::Provision::Cobbler.any_instance do</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line331">331</a> expects(:sync).once</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line332">332</a> end</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line333">333</a> @orchestrator.fast_provision(@reporter, @data['engine'], @data['nodes'])</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line334">334</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line335">335</a> </pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line336">336</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line337">337</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line338">338</a> context 'node reboot fail' do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line339">339</a> before(:each) { Astute::Provision::Cobbler.any_instance.stubs(:event_status).</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line340">340</a> returns([Time.now.to_f, 'controller-1', 'failed'])}</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line341">341</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line342">342</a> it &quot;should sync engine state&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line343">343</a> Astute::Provision::Cobbler.any_instance do</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line344">344</a> expects(:sync).once</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line345">345</a> end</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line346">346</a> begin</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line347">347</a> @orchestrator.fast_provision(@reporter, @data['engine'], @data['nodes'])</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line348">348</a> rescue</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line349">349</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line350">350</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line351">351</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line352">352</a> it &quot;raise error if failed node find&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line353">353</a> expect {@orchestrator.fast_provision(@reporter, @data['engine'], @data['nodes'])}.to raise_error(StopIteration)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line354">354</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line355">355</a> </pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line356">356</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line357">357</a> </pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line358">358</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line359">359</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line360">360</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line361">361</a> describe '#provision' do</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line362">362</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line363">363</a> before(:each) do</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line364">364</a> # Disable sleeping in test env (doubles the test speed)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line365">365</a> def @orchestrator.sleep_not_greater_than(time, &amp;block)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line366">366</a> block.call</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line367">367</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line368">368</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line369">369</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line370">370</a> it &quot;raises error if nodes list is empty&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line371">371</a> expect {@orchestrator.provision(@reporter, @data['task_uuid'], {})}.</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line372">372</a> to raise_error(/Nodes to provision are not provided!/)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line373">373</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line374">374</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line375">375</a> it &quot;prepare provision log for parsing&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line376">376</a> Astute::LogParser::ParseProvisionLogs.any_instance do</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line377">377</a> expects(:prepare).with(@data['nodes']).once</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line378">378</a> end</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line379">379</a> @orchestrator.stubs(:report_about_progress).returns()</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line380">380</a> @orchestrator.stubs(:node_type).returns([{'uid' =&gt; '1', 'node_type' =&gt; 'target' }])</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line381">381</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line382">382</a> @orchestrator.provision(@reporter, @data['task_uuid'], @data['nodes'])</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line383">383</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line384">384</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line385">385</a> it &quot;ignore problem with parsing provision log&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line386">386</a> Astute::LogParser::ParseProvisionLogs.any_instance do</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line387">387</a> stubs(:prepare).with(@data['nodes']).raises</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line388">388</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line389">389</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line390">390</a> @orchestrator.stubs(:report_about_progress).returns()</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line391">391</a> @orchestrator.stubs(:node_type).returns([{'uid' =&gt; '1', 'node_type' =&gt; 'target' }])</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line392">392</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line393">393</a> @orchestrator.provision(@reporter, @data['task_uuid'], @data['nodes'])</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line394">394</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line395">395</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line396">396</a> it 'provision nodes using mclient' do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line397">397</a> @orchestrator.stubs(:report_about_progress).returns()</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line398">398</a> @orchestrator.expects(:node_type).returns([{'uid' =&gt; '1', 'node_type' =&gt; 'target' }])</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line399">399</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line400">400</a> @orchestrator.provision(@reporter, @data['task_uuid'], @data['nodes'])</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line401">401</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line402">402</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line403">403</a> it &quot;fail if timeout of provisioning is exceeded&quot; do</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line404">404</a> Astute::LogParser::ParseProvisionLogs.any_instance do</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line405">405</a> stubs(:prepare).returns()</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line406">406</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line407">407</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line408">408</a> Timeout.stubs(:timeout).raises(Timeout::Error)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line409">409</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line410">410</a> msg = 'Timeout of provisioning is exceeded.' </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line411">411</a> error_mgs = {'status' =&gt; 'error', 'error' =&gt; msg, 'nodes' =&gt; [{ 'uid' =&gt; '1',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line412">412</a> 'status' =&gt; 'error',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line413">413</a> 'error_msg' =&gt; msg,</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line414">414</a> 'progress' =&gt; 100,</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line415">415</a> 'error_type' =&gt; 'provision'}]}</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line416">416</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line417">417</a> @reporter.expects(:report).with(error_mgs).once</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line418">418</a> @orchestrator.provision(@reporter, @data['task_uuid'], @data['nodes'])</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line419">419</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line420">420</a> </pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line421">421</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line422">422</a> </pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line423">423</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line424">424</a> </pre></td>
</tr>
</tbody>
</table>
<p>Generated on 2013-07-19 12:05:31 +0400 with <a href="https://github.com/fguillen/simplecov-rcov">SimpleCov-RCov 0.2.3</a></p>
</body>
</html>