fuel-astute/coverage/rcov/lib-astute-logparser-provis...

822 lines
38 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>lib/astute/logparser/provision.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>lib/astute/logparser/provision.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="lib-astute-logparser-provision_rb.html">lib/astute/logparser/provision.rb</a></td>
<td class='right_align'><tt>254</tt></td>
<td class='right_align'><tt>122</tt></td>
<td class="left_align"><div class="percent_graph_legend"><tt class=''>86.61%</tt></div>
<div class="percent_graph">
<div class="covered" style="width:87px"></div>
<div class="uncovered" style="width:13px"></div>
</div></td>
<td class="left_align"><div class="percent_graph_legend"><tt class=''>72.13%</tt></div>
<div class="percent_graph">
<div class="covered" style="width:72px"></div>
<div class="uncovered" style="width:28px"></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 'date'</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> module Astute</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line20">20</a> module LogParser</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line21">21</a> class ParseProvisionLogs &lt;ParseNodeLogs</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line22">22</a> def initialize</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line23">23</a> pattern_spec = Patterns::get_default_pattern('anaconda-log-supposed-time-kvm')</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line24">24</a> super(pattern_spec)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line25">25</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line26">26</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line27">27</a> def progress_calculate(uids_to_calc, nodes)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line28">28</a> # Just create correct pattern for each node and then call parent method.</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line29">29</a> uids_to_calc.each do |uid|</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line30">30</a> node = nodes.select {|n| n['uid'] == uid}[0]</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line31">31</a> unless @nodes_states[uid]</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line32">32</a> @nodes_states[uid] = get_pattern_for_node(node)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line33">33</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line34">34</a> end</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line35">35</a> super(uids_to_calc, nodes)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line36">36</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line37">37</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line38">38</a> private</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line39">39</a> def calculate(fo, node_pattern_spec)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line40">40</a> case node_pattern_spec['type']</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line41">41</a> when 'pattern-list'</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line42">42</a> progress = simple_pattern_finder(fo, node_pattern_spec)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line43">43</a> when 'supposed-time'</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line44">44</a> progress = supposed_time_parser(fo, node_pattern_spec)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line45">45</a> end</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line46">46</a> return progress</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line47">47</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line48">48</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line49">49</a> def get_pattern_for_node(node)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line50">50</a> if node['manufacturer'] == 'KVM'</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line51">51</a> pattern_spec = Patterns::get_default_pattern('anaconda-log-supposed-time-kvm')</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line52">52</a> else</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line53">53</a> pattern_spec = Patterns::get_default_pattern('anaconda-log-supposed-time-baremetal')</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line54">54</a> end</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line55">55</a> pattern_spec['path_prefix'] ||= PATH_PREFIX.to_s</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line56">56</a> pattern_spec['separator'] ||= SEPARATOR.to_s</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line57">57</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line58">58</a> hdd = node['meta']['disks'].select{|disk| not disk['removable']}[0]</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line59">59</a> if hdd</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line60">60</a> # Convert size from bytes to GB</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line61">61</a> hdd_size = hdd['size'] / 10 ** 9</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line62">62</a> else</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line63">63</a> # Default hdd size is 20 GB</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line64">64</a> hdd_size = 20</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line65">65</a> end</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> hdd_pattern = pattern_spec['pattern_list'].select {|el| el['hdd_size_multiplier']}[0]</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line68">68</a> hdd_pattern['supposed_time'] = (hdd_pattern['hdd_size_multiplier'] * hdd_size).to_i</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line69">69</a> return pattern_spec</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line70">70</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line71">71</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line72">72</a> def supposed_time_parser(fo, pattern_spec)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line73">73</a> # Pattern specification example:</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line74">74</a> # pattern_spec = {'type' =&gt; 'supposed-time',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line75">75</a> # 'chunk_size' =&gt; 10000,</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line76">76</a> # 'date_format' =&gt; '%Y-%m-%dT%H:%M:%S',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line77">77</a> # 'date_regexp' =&gt; '^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line78">78</a> # 'pattern_list' =&gt; [</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line79">79</a> # {'pattern' =&gt; 'Running anaconda script', 'supposed_time' =&gt; 60},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line80">80</a> # {'pattern' =&gt; 'moving (1) to step enablefilesystems', 'supposed_time' =&gt; 3},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line81">81</a> # {'pattern' =&gt; &quot;notifying kernel of 'change' event on device&quot;, 'supposed_time' =&gt; 200},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line82">82</a> # {'pattern' =&gt; 'Preparing to install packages', 'supposed_time' =&gt; 9},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line83">83</a> # {'pattern' =&gt; 'Installing glibc-common-2.12', 'supposed_time' =&gt; 9},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line84">84</a> # {'pattern' =&gt; 'Installing bash-4.1.2', 'supposed_time' =&gt; 11},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line85">85</a> # {'pattern' =&gt; 'Installing coreutils-8.4-19', 'supposed_time' =&gt; 20},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line86">86</a> # {'pattern' =&gt; 'Installing centos-release-6-3', 'supposed_time' =&gt; 21},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line87">87</a> # {'pattern' =&gt; 'Installing attr-2.4.44', 'supposed_time' =&gt; 23},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line88">88</a> # {'pattern' =&gt; 'leaving (1) step installpackages', 'supposed_time' =&gt; 60},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line89">89</a> # {'pattern' =&gt; 'moving (1) to step postscripts', 'supposed_time' =&gt; 4},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line90">90</a> # {'pattern' =&gt; 'leaving (1) step postscripts', 'supposed_time' =&gt; 130},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line91">91</a> # ].reverse,</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line92">92</a> # 'filename' =&gt; 'install/anaconda.log'</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line93">93</a> # }</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line94">94</a> # Use custom separator if defined.</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line95">95</a> separator = pattern_spec['separator']</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line96">96</a> log_patterns = pattern_spec['pattern_list']</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line97">97</a> date_format = pattern_spec['date_format']</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line98">98</a> date_regexp = pattern_spec['date_regexp']</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line99">99</a> unless date_regexp and date_format and log_patterns</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line100">100</a> Astute.logger.warn(&quot;Wrong pattern_spec #{pattern_spec.inspect} defined for calculating progress via logs.&quot;)</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line101">101</a> return 0</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> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line104">104</a> def self.get_elapsed_time(patterns)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line105">105</a> elapsed_time = 0</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line106">106</a> patterns.each do |p|</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line107">107</a> if p['_progress']</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line108">108</a> break</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line109">109</a> else</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line110">110</a> elapsed_time += p['supposed_time']</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line111">111</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line112">112</a> end</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line113">113</a> return elapsed_time</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line114">114</a> end</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> def self.get_progress(base_progress, elapsed_time, delta_time, supposed_time=nil)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line117">117</a> return 1.0 if elapsed_time.zero?</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line118">118</a> k = (1.0 - base_progress) / elapsed_time</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line119">119</a> supposed_time ? surplus = delta_time - supposed_time : surplus = nil</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line120">120</a> if surplus and surplus &gt; 0</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line121">121</a> progress = supposed_time * k + surplus * k/3 + base_progress</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line122">122</a> else</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line123">123</a> progress = delta_time * k + base_progress</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line124">124</a> end</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line125">125</a> progress = 1.0 if progress &gt; 1</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line126">126</a> return progress</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line127">127</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line128">128</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line129">129</a> def self.get_seconds_from_time(date)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line130">130</a> hours, mins, secs, frac = Date::day_fraction_to_time(date)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line131">131</a> return hours*60*60 + mins*60 + secs</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line132">132</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line133">133</a> </pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line134">134</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line135">135</a> chunk = get_chunk(fo, pattern_spec['chunk_size'])</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line136">136</a> return 0 unless chunk</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line137">137</a> pos = chunk.rindex(separator)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line138">138</a> chunk = chunk.slice((pos + separator.size)..-1) if pos</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line139">139</a> block = chunk.split(&quot;\n&quot;)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line140">140</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line141">141</a> now = DateTime.now()</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line142">142</a> prev_time = pattern_spec['_prev_time'] ||= now</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line143">143</a> prev_progress = pattern_spec['_prev_progress'] ||= 0</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line144">144</a> elapsed_time = pattern_spec['_elapsed_time'] ||= get_elapsed_time(log_patterns)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line145">145</a> seconds_since_prev = get_seconds_from_time(now - prev_time)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line146">146</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line147">147</a> until block.empty?</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line148">148</a> string = block.pop</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line149">149</a> log_patterns.each do |pattern|</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line150">150</a> if string.include?(pattern['pattern'])</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line151">151</a> if pattern['_progress']</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line152">152</a> # We not found any new messages. Calculate progress with old data.</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line153">153</a> progress = get_progress(prev_progress, elapsed_time,</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line154">154</a> seconds_since_prev, pattern['supposed_time'])</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line155">155</a> return progress</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line156">156</a> </pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line157">157</a> else</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line158">158</a> # We found message that we never find before. We need to: </pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line159">159</a> # calculate progress for this message;</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line160">160</a> # recalculate control point and elapsed_time;</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line161">161</a> # calculate progress for current time.</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line162">162</a> </pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line163">163</a> # Trying to find timestamp of message.</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line164">164</a> date_string = string.match(date_regexp)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line165">165</a> if date_string</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line166">166</a> # Get relative time when the message realy occured.</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line167">167</a> date = DateTime.strptime(date_string[0], date_format) - prev_time.offset</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line168">168</a> real_time = get_seconds_from_time(date - prev_time)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line169">169</a> # Update progress of the message.</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line170">170</a> prev_supposed_time = log_patterns.select{|n| n['_progress'] == prev_progress}[0]</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line171">171</a> prev_supposed_time = prev_supposed_time['supposed_time'] if prev_supposed_time</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line172">172</a> progress = get_progress(prev_progress, elapsed_time, real_time, prev_supposed_time)</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line173">173</a> pattern['_progress'] = progress</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line174">174</a> # Recalculate elapsed time.</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line175">175</a> elapsed_time = pattern_spec['_elapsed_time'] = get_elapsed_time(log_patterns)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line176">176</a> # Update time and progress for control point.</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line177">177</a> prev_time = pattern_spec['_prev_time'] = date</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line178">178</a> prev_progress = pattern_spec['_prev_progress'] = progress</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line179">179</a> seconds_since_prev = get_seconds_from_time(now - date)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line180">180</a> # Calculate progress for current time.</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line181">181</a> progress = get_progress(prev_progress, elapsed_time,</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line182">182</a> seconds_since_prev, pattern['supposed_time'])</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line183">183</a> return progress</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line184">184</a> else</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line185">185</a> Astute.logger.info(&quot;Can't gather date (format: '#{date_regexp}') from string: #{string}&quot;)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line186">186</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line187">187</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line188">188</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line189">189</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line190">190</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line191">191</a> # We found nothing.</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line192">192</a> progress = get_progress(prev_progress, elapsed_time, seconds_since_prev, log_patterns[0]['supposed_time'])</pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line193">193</a> return progress</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line194">194</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line195">195</a> </pre></td>
</tr>
<tr class="marked">
<td><pre><a name="line196">196</a> def simple_pattern_finder(fo, pattern_spec)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line197">197</a> # Pattern specification example:</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line198">198</a> # pattern_spec = {'type' =&gt; 'pattern-list', 'separator' =&gt; &quot;custom separator\n&quot;,</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line199">199</a> # 'chunk_size' =&gt; 40000,</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line200">200</a> # 'pattern_list' =&gt; [</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line201">201</a> # {'pattern' =&gt; 'Running kickstart %%pre script', 'progress' =&gt; 0.08},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line202">202</a> # {'pattern' =&gt; 'to step enablefilesystems', 'progress' =&gt; 0.09},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line203">203</a> # {'pattern' =&gt; 'to step reposetup', 'progress' =&gt; 0.13},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line204">204</a> # {'pattern' =&gt; 'to step installpackages', 'progress' =&gt; 0.16},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line205">205</a> # {'pattern' =&gt; 'Installing',</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line206">206</a> # 'number' =&gt; 210, # Now it install 205 packets. Add 5 packets for growth in future.</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line207">207</a> # 'p_min' =&gt; 0.16, # min percent</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line208">208</a> # 'p_max' =&gt; 0.87 # max percent</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line209">209</a> # },</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line210">210</a> # {'pattern' =&gt; 'to step postinstallconfig', 'progress' =&gt; 0.87},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line211">211</a> # {'pattern' =&gt; 'to step dopostaction', 'progress' =&gt; 0.92},</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line212">212</a> # ]</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line213">213</a> # }</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line214">214</a> # Use custom separator if defined.</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line215">215</a> separator = pattern_spec['separator']</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line216">216</a> log_patterns = pattern_spec['pattern_list']</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line217">217</a> unless log_patterns</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line218">218</a> Astute.logger.warn(&quot;Wrong pattern #{pattern_spec.inspect} defined for calculating progress via logs.&quot;)</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line219">219</a> return 0</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line220">220</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line221">221</a> </pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line222">222</a> chunk = get_chunk(fo, pattern_spec['chunk_size'])</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line223">223</a> # NOTE(mihgen): Following line fixes &quot;undefined method `rindex' for nil:NilClass&quot; for empty log file</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line224">224</a> return 0 unless chunk</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line225">225</a> pos = chunk.rindex(separator)</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line226">226</a> chunk = chunk.slice((pos + separator.size)..-1) if pos</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line227">227</a> block = chunk.split(&quot;\n&quot;)</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line228">228</a> return 0 unless block</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line229">229</a> while true</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line230">230</a> string = block.pop</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line231">231</a> return 0 unless string # If we found nothing</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line232">232</a> log_patterns.each do |pattern|</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line233">233</a> if string.include?(pattern['pattern'])</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line234">234</a> return pattern['progress'] if pattern['progress']</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line235">235</a> if pattern['number']</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line236">236</a> string = block.pop</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line237">237</a> counter = 1</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line238">238</a> while string</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line239">239</a> counter += 1 if string.include?(pattern['pattern'])</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line240">240</a> string = block.pop</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line241">241</a> end</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line242">242</a> progress = counter.to_f / pattern['number']</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line243">243</a> progress = 1 if progress &gt; 1</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line244">244</a> progress = pattern['p_min'] + progress * (pattern['p_max'] - pattern['p_min'])</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line245">245</a> return progress</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line246">246</a> end</pre></td>
</tr>
<tr class="uncovered">
<td><pre><a name="line247">247</a> Astute.logger.warn(&quot;Wrong pattern #{pattern_spec.inspect} defined for calculating progress via log.&quot;)</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line248">248</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line249">249</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line250">250</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line251">251</a> end</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> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line254">254</a> end</pre></td>
</tr>
<tr class="inferred">
<td><pre><a name="line255">255</a> end</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>