| OLD | NEW |
| (Empty) | |
| 1 <!doctype html PUBLIC "-//W3C//DTD html 4.01//EN" "http://www.w3.org/TR/html4/st
rict.dtd"> |
| 2 <html> |
| 3 <head> |
| 4 <meta http-equiv='Content-Type' content='text/html; charset=utf-8'> |
| 5 |
| 6 |
| 7 <meta http-equiv='X-UA-Compatible' content='IE=emulateIE7' /> |
| 8 <title>Coverage for appengine/findit/waterfall/build_failure_analysis: 100%<
/title> |
| 9 <link rel='stylesheet' href='style.css' type='text/css'> |
| 10 |
| 11 <script type='text/javascript' src='jquery.min.js'></script> |
| 12 <script type='text/javascript' src='jquery.hotkeys.js'></script> |
| 13 <script type='text/javascript' src='jquery.isonscreen.js'></script> |
| 14 <script type='text/javascript' src='coverage_html.js'></script> |
| 15 <script type='text/javascript' charset='utf-8'> |
| 16 jQuery(document).ready(coverage.pyfile_ready); |
| 17 </script> |
| 18 </head> |
| 19 <body id='pyfile'> |
| 20 |
| 21 <div id='header'> |
| 22 <div class='content'> |
| 23 <h1>Coverage for <b>appengine/findit/waterfall/build_failure_analysis</b
> : |
| 24 <span class='pc_cov'>100%</span> |
| 25 </h1> |
| 26 <img id='keyboard_icon' src='keybd_closed.png'> |
| 27 <h2 class='stats'> |
| 28 290 statements |
| 29 <span class='run hide_run shortkey_r button_toggle_run'>290 run</spa
n> |
| 30 <span class='mis shortkey_m button_toggle_mis'>0 missing</span> |
| 31 <span class='exc shortkey_x button_toggle_exc'>0 excluded</span> |
| 32 |
| 33 <span class='par run hide_run shortkey_p button_toggle_par'>0 pa
rtial</span> |
| 34 |
| 35 </h2> |
| 36 </div> |
| 37 </div> |
| 38 |
| 39 <div class='help_panel'> |
| 40 <img id='panel_icon' src='keybd_open.png'> |
| 41 <p class='legend'>Hot-keys on this page</p> |
| 42 <div> |
| 43 <p class='keyhelp'> |
| 44 <span class='key'>r</span> |
| 45 <span class='key'>m</span> |
| 46 <span class='key'>x</span> |
| 47 <span class='key'>p</span> toggle line displays |
| 48 </p> |
| 49 <p class='keyhelp'> |
| 50 <span class='key'>j</span> |
| 51 <span class='key'>k</span> next/prev highlighted chunk |
| 52 </p> |
| 53 <p class='keyhelp'> |
| 54 <span class='key'>0</span> (zero) top of page |
| 55 </p> |
| 56 <p class='keyhelp'> |
| 57 <span class='key'>1</span> (one) first highlighted chunk |
| 58 </p> |
| 59 </div> |
| 60 </div> |
| 61 |
| 62 <div id='source'> |
| 63 <table cellspacing='0' cellpadding='0'> |
| 64 <tr> |
| 65 <td class='linenos' valign='top'> |
| 66 <p id='n1' class='pln'><a href='#n1'>1</a></p> |
| 67 <p id='n2' class='pln'><a href='#n2'>2</a></p> |
| 68 <p id='n3' class='pln'><a href='#n3'>3</a></p> |
| 69 <p id='n4' class='pln'><a href='#n4'>4</a></p> |
| 70 <p id='n5' class='stm run hide_run'><a href='#n5'>5</a></p> |
| 71 <p id='n6' class='stm run hide_run'><a href='#n6'>6</a></p> |
| 72 <p id='n7' class='stm run hide_run'><a href='#n7'>7</a></p> |
| 73 <p id='n8' class='pln'><a href='#n8'>8</a></p> |
| 74 <p id='n9' class='stm run hide_run'><a href='#n9'>9</a></p> |
| 75 <p id='n10' class='stm run hide_run'><a href='#n10'>10</a></p> |
| 76 <p id='n11' class='stm run hide_run'><a href='#n11'>11</a></p> |
| 77 <p id='n12' class='stm run hide_run'><a href='#n12'>12</a></p> |
| 78 <p id='n13' class='stm run hide_run'><a href='#n13'>13</a></p> |
| 79 <p id='n14' class='pln'><a href='#n14'>14</a></p> |
| 80 <p id='n15' class='pln'><a href='#n15'>15</a></p> |
| 81 <p id='n16' class='stm run hide_run'><a href='#n16'>16</a></p> |
| 82 <p id='n17' class='pln'><a href='#n17'>17</a></p> |
| 83 <p id='n18' class='pln'><a href='#n18'>18</a></p> |
| 84 <p id='n19' class='pln'><a href='#n19'>19</a></p> |
| 85 <p id='n20' class='pln'><a href='#n20'>20</a></p> |
| 86 <p id='n21' class='pln'><a href='#n21'>21</a></p> |
| 87 <p id='n22' class='pln'><a href='#n22'>22</a></p> |
| 88 <p id='n23' class='pln'><a href='#n23'>23</a></p> |
| 89 <p id='n24' class='pln'><a href='#n24'>24</a></p> |
| 90 <p id='n25' class='pln'><a href='#n25'>25</a></p> |
| 91 <p id='n26' class='pln'><a href='#n26'>26</a></p> |
| 92 <p id='n27' class='pln'><a href='#n27'>27</a></p> |
| 93 <p id='n28' class='pln'><a href='#n28'>28</a></p> |
| 94 <p id='n29' class='pln'><a href='#n29'>29</a></p> |
| 95 <p id='n30' class='stm run hide_run'><a href='#n30'>30</a></p> |
| 96 <p id='n31' class='stm run hide_run'><a href='#n31'>31</a></p> |
| 97 <p id='n32' class='pln'><a href='#n32'>32</a></p> |
| 98 <p id='n33' class='stm run hide_run'><a href='#n33'>33</a></p> |
| 99 <p id='n34' class='stm run hide_run'><a href='#n34'>34</a></p> |
| 100 <p id='n35' class='stm run hide_run'><a href='#n35'>35</a></p> |
| 101 <p id='n36' class='pln'><a href='#n36'>36</a></p> |
| 102 <p id='n37' class='pln'><a href='#n37'>37</a></p> |
| 103 <p id='n38' class='stm run hide_run'><a href='#n38'>38</a></p> |
| 104 <p id='n39' class='pln'><a href='#n39'>39</a></p> |
| 105 <p id='n40' class='pln'><a href='#n40'>40</a></p> |
| 106 <p id='n41' class='pln'><a href='#n41'>41</a></p> |
| 107 <p id='n42' class='pln'><a href='#n42'>42</a></p> |
| 108 <p id='n43' class='pln'><a href='#n43'>43</a></p> |
| 109 <p id='n44' class='pln'><a href='#n44'>44</a></p> |
| 110 <p id='n45' class='stm run hide_run'><a href='#n45'>45</a></p> |
| 111 <p id='n46' class='stm run hide_run'><a href='#n46'>46</a></p> |
| 112 <p id='n47' class='stm run hide_run'><a href='#n47'>47</a></p> |
| 113 <p id='n48' class='stm run hide_run'><a href='#n48'>48</a></p> |
| 114 <p id='n49' class='stm run hide_run'><a href='#n49'>49</a></p> |
| 115 <p id='n50' class='pln'><a href='#n50'>50</a></p> |
| 116 <p id='n51' class='pln'><a href='#n51'>51</a></p> |
| 117 <p id='n52' class='stm run hide_run'><a href='#n52'>52</a></p> |
| 118 <p id='n53' class='pln'><a href='#n53'>53</a></p> |
| 119 <p id='n54' class='pln'><a href='#n54'>54</a></p> |
| 120 <p id='n55' class='pln'><a href='#n55'>55</a></p> |
| 121 <p id='n56' class='pln'><a href='#n56'>56</a></p> |
| 122 <p id='n57' class='pln'><a href='#n57'>57</a></p> |
| 123 <p id='n58' class='pln'><a href='#n58'>58</a></p> |
| 124 <p id='n59' class='pln'><a href='#n59'>59</a></p> |
| 125 <p id='n60' class='pln'><a href='#n60'>60</a></p> |
| 126 <p id='n61' class='pln'><a href='#n61'>61</a></p> |
| 127 <p id='n62' class='pln'><a href='#n62'>62</a></p> |
| 128 <p id='n63' class='pln'><a href='#n63'>63</a></p> |
| 129 <p id='n64' class='pln'><a href='#n64'>64</a></p> |
| 130 <p id='n65' class='stm run hide_run'><a href='#n65'>65</a></p> |
| 131 <p id='n66' class='stm run hide_run'><a href='#n66'>66</a></p> |
| 132 <p id='n67' class='stm run hide_run'><a href='#n67'>67</a></p> |
| 133 <p id='n68' class='stm run hide_run'><a href='#n68'>68</a></p> |
| 134 <p id='n69' class='stm run hide_run'><a href='#n69'>69</a></p> |
| 135 <p id='n70' class='stm run hide_run'><a href='#n70'>70</a></p> |
| 136 <p id='n71' class='stm run hide_run'><a href='#n71'>71</a></p> |
| 137 <p id='n72' class='stm run hide_run'><a href='#n72'>72</a></p> |
| 138 <p id='n73' class='pln'><a href='#n73'>73</a></p> |
| 139 <p id='n74' class='stm run hide_run'><a href='#n74'>74</a></p> |
| 140 <p id='n75' class='pln'><a href='#n75'>75</a></p> |
| 141 <p id='n76' class='stm run hide_run'><a href='#n76'>76</a></p> |
| 142 <p id='n77' class='pln'><a href='#n77'>77</a></p> |
| 143 <p id='n78' class='pln'><a href='#n78'>78</a></p> |
| 144 <p id='n79' class='stm run hide_run'><a href='#n79'>79</a></p> |
| 145 <p id='n80' class='pln'><a href='#n80'>80</a></p> |
| 146 <p id='n81' class='pln'><a href='#n81'>81</a></p> |
| 147 <p id='n82' class='pln'><a href='#n82'>82</a></p> |
| 148 <p id='n83' class='pln'><a href='#n83'>83</a></p> |
| 149 <p id='n84' class='pln'><a href='#n84'>84</a></p> |
| 150 <p id='n85' class='pln'><a href='#n85'>85</a></p> |
| 151 <p id='n86' class='pln'><a href='#n86'>86</a></p> |
| 152 <p id='n87' class='pln'><a href='#n87'>87</a></p> |
| 153 <p id='n88' class='pln'><a href='#n88'>88</a></p> |
| 154 <p id='n89' class='pln'><a href='#n89'>89</a></p> |
| 155 <p id='n90' class='stm run hide_run'><a href='#n90'>90</a></p> |
| 156 <p id='n91' class='stm run hide_run'><a href='#n91'>91</a></p> |
| 157 <p id='n92' class='stm run hide_run'><a href='#n92'>92</a></p> |
| 158 <p id='n93' class='stm run hide_run'><a href='#n93'>93</a></p> |
| 159 <p id='n94' class='stm run hide_run'><a href='#n94'>94</a></p> |
| 160 <p id='n95' class='stm run hide_run'><a href='#n95'>95</a></p> |
| 161 <p id='n96' class='stm run hide_run'><a href='#n96'>96</a></p> |
| 162 <p id='n97' class='stm run hide_run'><a href='#n97'>97</a></p> |
| 163 <p id='n98' class='pln'><a href='#n98'>98</a></p> |
| 164 <p id='n99' class='stm run hide_run'><a href='#n99'>99</a></p> |
| 165 <p id='n100' class='stm run hide_run'><a href='#n100'>100</a></p> |
| 166 <p id='n101' class='pln'><a href='#n101'>101</a></p> |
| 167 <p id='n102' class='stm run hide_run'><a href='#n102'>102</a></p> |
| 168 <p id='n103' class='stm run hide_run'><a href='#n103'>103</a></p> |
| 169 <p id='n104' class='pln'><a href='#n104'>104</a></p> |
| 170 <p id='n105' class='stm run hide_run'><a href='#n105'>105</a></p> |
| 171 <p id='n106' class='pln'><a href='#n106'>106</a></p> |
| 172 <p id='n107' class='pln'><a href='#n107'>107</a></p> |
| 173 <p id='n108' class='stm run hide_run'><a href='#n108'>108</a></p> |
| 174 <p id='n109' class='pln'><a href='#n109'>109</a></p> |
| 175 <p id='n110' class='pln'><a href='#n110'>110</a></p> |
| 176 <p id='n111' class='pln'><a href='#n111'>111</a></p> |
| 177 <p id='n112' class='pln'><a href='#n112'>112</a></p> |
| 178 <p id='n113' class='pln'><a href='#n113'>113</a></p> |
| 179 <p id='n114' class='pln'><a href='#n114'>114</a></p> |
| 180 <p id='n115' class='pln'><a href='#n115'>115</a></p> |
| 181 <p id='n116' class='pln'><a href='#n116'>116</a></p> |
| 182 <p id='n117' class='pln'><a href='#n117'>117</a></p> |
| 183 <p id='n118' class='stm run hide_run'><a href='#n118'>118</a></p> |
| 184 <p id='n119' class='pln'><a href='#n119'>119</a></p> |
| 185 <p id='n120' class='pln'><a href='#n120'>120</a></p> |
| 186 <p id='n121' class='pln'><a href='#n121'>121</a></p> |
| 187 <p id='n122' class='pln'><a href='#n122'>122</a></p> |
| 188 <p id='n123' class='stm run hide_run'><a href='#n123'>123</a></p> |
| 189 <p id='n124' class='pln'><a href='#n124'>124</a></p> |
| 190 <p id='n125' class='pln'><a href='#n125'>125</a></p> |
| 191 <p id='n126' class='pln'><a href='#n126'>126</a></p> |
| 192 <p id='n127' class='stm run hide_run'><a href='#n127'>127</a></p> |
| 193 <p id='n128' class='pln'><a href='#n128'>128</a></p> |
| 194 <p id='n129' class='pln'><a href='#n129'>129</a></p> |
| 195 <p id='n130' class='pln'><a href='#n130'>130</a></p> |
| 196 <p id='n131' class='stm run hide_run'><a href='#n131'>131</a></p> |
| 197 <p id='n132' class='pln'><a href='#n132'>132</a></p> |
| 198 <p id='n133' class='pln'><a href='#n133'>133</a></p> |
| 199 <p id='n134' class='pln'><a href='#n134'>134</a></p> |
| 200 <p id='n135' class='pln'><a href='#n135'>135</a></p> |
| 201 <p id='n136' class='pln'><a href='#n136'>136</a></p> |
| 202 <p id='n137' class='pln'><a href='#n137'>137</a></p> |
| 203 <p id='n138' class='stm run hide_run'><a href='#n138'>138</a></p> |
| 204 <p id='n139' class='pln'><a href='#n139'>139</a></p> |
| 205 <p id='n140' class='stm run hide_run'><a href='#n140'>140</a></p> |
| 206 <p id='n141' class='pln'><a href='#n141'>141</a></p> |
| 207 <p id='n142' class='stm run hide_run'><a href='#n142'>142</a></p> |
| 208 <p id='n143' class='pln'><a href='#n143'>143</a></p> |
| 209 <p id='n144' class='stm run hide_run'><a href='#n144'>144</a></p> |
| 210 <p id='n145' class='stm run hide_run'><a href='#n145'>145</a></p> |
| 211 <p id='n146' class='pln'><a href='#n146'>146</a></p> |
| 212 <p id='n147' class='stm run hide_run'><a href='#n147'>147</a></p> |
| 213 <p id='n148' class='stm run hide_run'><a href='#n148'>148</a></p> |
| 214 <p id='n149' class='stm run hide_run'><a href='#n149'>149</a></p> |
| 215 <p id='n150' class='stm run hide_run'><a href='#n150'>150</a></p> |
| 216 <p id='n151' class='stm run hide_run'><a href='#n151'>151</a></p> |
| 217 <p id='n152' class='pln'><a href='#n152'>152</a></p> |
| 218 <p id='n153' class='stm run hide_run'><a href='#n153'>153</a></p> |
| 219 <p id='n154' class='pln'><a href='#n154'>154</a></p> |
| 220 <p id='n155' class='pln'><a href='#n155'>155</a></p> |
| 221 <p id='n156' class='stm run hide_run'><a href='#n156'>156</a></p> |
| 222 <p id='n157' class='pln'><a href='#n157'>157</a></p> |
| 223 <p id='n158' class='pln'><a href='#n158'>158</a></p> |
| 224 <p id='n159' class='pln'><a href='#n159'>159</a></p> |
| 225 <p id='n160' class='pln'><a href='#n160'>160</a></p> |
| 226 <p id='n161' class='pln'><a href='#n161'>161</a></p> |
| 227 <p id='n162' class='stm run hide_run'><a href='#n162'>162</a></p> |
| 228 <p id='n163' class='stm run hide_run'><a href='#n163'>163</a></p> |
| 229 <p id='n164' class='stm run hide_run'><a href='#n164'>164</a></p> |
| 230 <p id='n165' class='stm run hide_run'><a href='#n165'>165</a></p> |
| 231 <p id='n166' class='stm run hide_run'><a href='#n166'>166</a></p> |
| 232 <p id='n167' class='stm run hide_run'><a href='#n167'>167</a></p> |
| 233 <p id='n168' class='stm run hide_run'><a href='#n168'>168</a></p> |
| 234 <p id='n169' class='stm run hide_run'><a href='#n169'>169</a></p> |
| 235 <p id='n170' class='stm run hide_run'><a href='#n170'>170</a></p> |
| 236 <p id='n171' class='pln'><a href='#n171'>171</a></p> |
| 237 <p id='n172' class='stm run hide_run'><a href='#n172'>172</a></p> |
| 238 <p id='n173' class='stm run hide_run'><a href='#n173'>173</a></p> |
| 239 <p id='n174' class='pln'><a href='#n174'>174</a></p> |
| 240 <p id='n175' class='stm run hide_run'><a href='#n175'>175</a></p> |
| 241 <p id='n176' class='pln'><a href='#n176'>176</a></p> |
| 242 <p id='n177' class='pln'><a href='#n177'>177</a></p> |
| 243 <p id='n178' class='stm run hide_run'><a href='#n178'>178</a></p> |
| 244 <p id='n179' class='stm run hide_run'><a href='#n179'>179</a></p> |
| 245 <p id='n180' class='stm run hide_run'><a href='#n180'>180</a></p> |
| 246 <p id='n181' class='stm run hide_run'><a href='#n181'>181</a></p> |
| 247 <p id='n182' class='stm run hide_run'><a href='#n182'>182</a></p> |
| 248 <p id='n183' class='pln'><a href='#n183'>183</a></p> |
| 249 <p id='n184' class='pln'><a href='#n184'>184</a></p> |
| 250 <p id='n185' class='stm run hide_run'><a href='#n185'>185</a></p> |
| 251 <p id='n186' class='pln'><a href='#n186'>186</a></p> |
| 252 <p id='n187' class='pln'><a href='#n187'>187</a></p> |
| 253 <p id='n188' class='pln'><a href='#n188'>188</a></p> |
| 254 <p id='n189' class='pln'><a href='#n189'>189</a></p> |
| 255 <p id='n190' class='pln'><a href='#n190'>190</a></p> |
| 256 <p id='n191' class='pln'><a href='#n191'>191</a></p> |
| 257 <p id='n192' class='pln'><a href='#n192'>192</a></p> |
| 258 <p id='n193' class='pln'><a href='#n193'>193</a></p> |
| 259 <p id='n194' class='pln'><a href='#n194'>194</a></p> |
| 260 <p id='n195' class='pln'><a href='#n195'>195</a></p> |
| 261 <p id='n196' class='pln'><a href='#n196'>196</a></p> |
| 262 <p id='n197' class='pln'><a href='#n197'>197</a></p> |
| 263 <p id='n198' class='pln'><a href='#n198'>198</a></p> |
| 264 <p id='n199' class='stm run hide_run'><a href='#n199'>199</a></p> |
| 265 <p id='n200' class='stm run hide_run'><a href='#n200'>200</a></p> |
| 266 <p id='n201' class='pln'><a href='#n201'>201</a></p> |
| 267 <p id='n202' class='stm run hide_run'><a href='#n202'>202</a></p> |
| 268 <p id='n203' class='pln'><a href='#n203'>203</a></p> |
| 269 <p id='n204' class='stm run hide_run'><a href='#n204'>204</a></p> |
| 270 <p id='n205' class='pln'><a href='#n205'>205</a></p> |
| 271 <p id='n206' class='stm run hide_run'><a href='#n206'>206</a></p> |
| 272 <p id='n207' class='stm run hide_run'><a href='#n207'>207</a></p> |
| 273 <p id='n208' class='pln'><a href='#n208'>208</a></p> |
| 274 <p id='n209' class='stm run hide_run'><a href='#n209'>209</a></p> |
| 275 <p id='n210' class='stm run hide_run'><a href='#n210'>210</a></p> |
| 276 <p id='n211' class='pln'><a href='#n211'>211</a></p> |
| 277 <p id='n212' class='stm run hide_run'><a href='#n212'>212</a></p> |
| 278 <p id='n213' class='pln'><a href='#n213'>213</a></p> |
| 279 <p id='n214' class='stm run hide_run'><a href='#n214'>214</a></p> |
| 280 <p id='n215' class='pln'><a href='#n215'>215</a></p> |
| 281 <p id='n216' class='stm run hide_run'><a href='#n216'>216</a></p> |
| 282 <p id='n217' class='pln'><a href='#n217'>217</a></p> |
| 283 <p id='n218' class='pln'><a href='#n218'>218</a></p> |
| 284 <p id='n219' class='stm run hide_run'><a href='#n219'>219</a></p> |
| 285 <p id='n220' class='pln'><a href='#n220'>220</a></p> |
| 286 <p id='n221' class='pln'><a href='#n221'>221</a></p> |
| 287 <p id='n222' class='pln'><a href='#n222'>222</a></p> |
| 288 <p id='n223' class='pln'><a href='#n223'>223</a></p> |
| 289 <p id='n224' class='pln'><a href='#n224'>224</a></p> |
| 290 <p id='n225' class='pln'><a href='#n225'>225</a></p> |
| 291 <p id='n226' class='pln'><a href='#n226'>226</a></p> |
| 292 <p id='n227' class='pln'><a href='#n227'>227</a></p> |
| 293 <p id='n228' class='pln'><a href='#n228'>228</a></p> |
| 294 <p id='n229' class='pln'><a href='#n229'>229</a></p> |
| 295 <p id='n230' class='pln'><a href='#n230'>230</a></p> |
| 296 <p id='n231' class='pln'><a href='#n231'>231</a></p> |
| 297 <p id='n232' class='pln'><a href='#n232'>232</a></p> |
| 298 <p id='n233' class='pln'><a href='#n233'>233</a></p> |
| 299 <p id='n234' class='stm run hide_run'><a href='#n234'>234</a></p> |
| 300 <p id='n235' class='stm run hide_run'><a href='#n235'>235</a></p> |
| 301 <p id='n236' class='stm run hide_run'><a href='#n236'>236</a></p> |
| 302 <p id='n237' class='pln'><a href='#n237'>237</a></p> |
| 303 <p id='n238' class='stm run hide_run'><a href='#n238'>238</a></p> |
| 304 <p id='n239' class='pln'><a href='#n239'>239</a></p> |
| 305 <p id='n240' class='stm run hide_run'><a href='#n240'>240</a></p> |
| 306 <p id='n241' class='pln'><a href='#n241'>241</a></p> |
| 307 <p id='n242' class='stm run hide_run'><a href='#n242'>242</a></p> |
| 308 <p id='n243' class='pln'><a href='#n243'>243</a></p> |
| 309 <p id='n244' class='pln'><a href='#n244'>244</a></p> |
| 310 <p id='n245' class='pln'><a href='#n245'>245</a></p> |
| 311 <p id='n246' class='pln'><a href='#n246'>246</a></p> |
| 312 <p id='n247' class='pln'><a href='#n247'>247</a></p> |
| 313 <p id='n248' class='pln'><a href='#n248'>248</a></p> |
| 314 <p id='n249' class='pln'><a href='#n249'>249</a></p> |
| 315 <p id='n250' class='pln'><a href='#n250'>250</a></p> |
| 316 <p id='n251' class='pln'><a href='#n251'>251</a></p> |
| 317 <p id='n252' class='pln'><a href='#n252'>252</a></p> |
| 318 <p id='n253' class='pln'><a href='#n253'>253</a></p> |
| 319 <p id='n254' class='pln'><a href='#n254'>254</a></p> |
| 320 <p id='n255' class='pln'><a href='#n255'>255</a></p> |
| 321 <p id='n256' class='pln'><a href='#n256'>256</a></p> |
| 322 <p id='n257' class='stm run hide_run'><a href='#n257'>257</a></p> |
| 323 <p id='n258' class='stm run hide_run'><a href='#n258'>258</a></p> |
| 324 <p id='n259' class='stm run hide_run'><a href='#n259'>259</a></p> |
| 325 <p id='n260' class='pln'><a href='#n260'>260</a></p> |
| 326 <p id='n261' class='stm run hide_run'><a href='#n261'>261</a></p> |
| 327 <p id='n262' class='stm run hide_run'><a href='#n262'>262</a></p> |
| 328 <p id='n263' class='pln'><a href='#n263'>263</a></p> |
| 329 <p id='n264' class='pln'><a href='#n264'>264</a></p> |
| 330 <p id='n265' class='stm run hide_run'><a href='#n265'>265</a></p> |
| 331 <p id='n266' class='stm run hide_run'><a href='#n266'>266</a></p> |
| 332 <p id='n267' class='pln'><a href='#n267'>267</a></p> |
| 333 <p id='n268' class='pln'><a href='#n268'>268</a></p> |
| 334 <p id='n269' class='pln'><a href='#n269'>269</a></p> |
| 335 <p id='n270' class='stm run hide_run'><a href='#n270'>270</a></p> |
| 336 <p id='n271' class='pln'><a href='#n271'>271</a></p> |
| 337 <p id='n272' class='pln'><a href='#n272'>272</a></p> |
| 338 <p id='n273' class='stm run hide_run'><a href='#n273'>273</a></p> |
| 339 <p id='n274' class='stm run hide_run'><a href='#n274'>274</a></p> |
| 340 <p id='n275' class='pln'><a href='#n275'>275</a></p> |
| 341 <p id='n276' class='stm run hide_run'><a href='#n276'>276</a></p> |
| 342 <p id='n277' class='pln'><a href='#n277'>277</a></p> |
| 343 <p id='n278' class='pln'><a href='#n278'>278</a></p> |
| 344 <p id='n279' class='stm run hide_run'><a href='#n279'>279</a></p> |
| 345 <p id='n280' class='stm run hide_run'><a href='#n280'>280</a></p> |
| 346 <p id='n281' class='pln'><a href='#n281'>281</a></p> |
| 347 <p id='n282' class='stm run hide_run'><a href='#n282'>282</a></p> |
| 348 <p id='n283' class='stm run hide_run'><a href='#n283'>283</a></p> |
| 349 <p id='n284' class='pln'><a href='#n284'>284</a></p> |
| 350 <p id='n285' class='stm run hide_run'><a href='#n285'>285</a></p> |
| 351 <p id='n286' class='pln'><a href='#n286'>286</a></p> |
| 352 <p id='n287' class='stm run hide_run'><a href='#n287'>287</a></p> |
| 353 <p id='n288' class='stm run hide_run'><a href='#n288'>288</a></p> |
| 354 <p id='n289' class='pln'><a href='#n289'>289</a></p> |
| 355 <p id='n290' class='pln'><a href='#n290'>290</a></p> |
| 356 <p id='n291' class='pln'><a href='#n291'>291</a></p> |
| 357 <p id='n292' class='stm run hide_run'><a href='#n292'>292</a></p> |
| 358 <p id='n293' class='stm run hide_run'><a href='#n293'>293</a></p> |
| 359 <p id='n294' class='pln'><a href='#n294'>294</a></p> |
| 360 <p id='n295' class='pln'><a href='#n295'>295</a></p> |
| 361 <p id='n296' class='pln'><a href='#n296'>296</a></p> |
| 362 <p id='n297' class='stm run hide_run'><a href='#n297'>297</a></p> |
| 363 <p id='n298' class='stm run hide_run'><a href='#n298'>298</a></p> |
| 364 <p id='n299' class='pln'><a href='#n299'>299</a></p> |
| 365 <p id='n300' class='pln'><a href='#n300'>300</a></p> |
| 366 <p id='n301' class='pln'><a href='#n301'>301</a></p> |
| 367 <p id='n302' class='stm run hide_run'><a href='#n302'>302</a></p> |
| 368 <p id='n303' class='pln'><a href='#n303'>303</a></p> |
| 369 <p id='n304' class='pln'><a href='#n304'>304</a></p> |
| 370 <p id='n305' class='stm run hide_run'><a href='#n305'>305</a></p> |
| 371 <p id='n306' class='stm run hide_run'><a href='#n306'>306</a></p> |
| 372 <p id='n307' class='pln'><a href='#n307'>307</a></p> |
| 373 <p id='n308' class='stm run hide_run'><a href='#n308'>308</a></p> |
| 374 <p id='n309' class='stm run hide_run'><a href='#n309'>309</a></p> |
| 375 <p id='n310' class='pln'><a href='#n310'>310</a></p> |
| 376 <p id='n311' class='pln'><a href='#n311'>311</a></p> |
| 377 <p id='n312' class='pln'><a href='#n312'>312</a></p> |
| 378 <p id='n313' class='pln'><a href='#n313'>313</a></p> |
| 379 <p id='n314' class='pln'><a href='#n314'>314</a></p> |
| 380 <p id='n315' class='stm run hide_run'><a href='#n315'>315</a></p> |
| 381 <p id='n316' class='pln'><a href='#n316'>316</a></p> |
| 382 <p id='n317' class='pln'><a href='#n317'>317</a></p> |
| 383 <p id='n318' class='pln'><a href='#n318'>318</a></p> |
| 384 <p id='n319' class='pln'><a href='#n319'>319</a></p> |
| 385 <p id='n320' class='pln'><a href='#n320'>320</a></p> |
| 386 <p id='n321' class='pln'><a href='#n321'>321</a></p> |
| 387 <p id='n322' class='pln'><a href='#n322'>322</a></p> |
| 388 <p id='n323' class='pln'><a href='#n323'>323</a></p> |
| 389 <p id='n324' class='pln'><a href='#n324'>324</a></p> |
| 390 <p id='n325' class='pln'><a href='#n325'>325</a></p> |
| 391 <p id='n326' class='pln'><a href='#n326'>326</a></p> |
| 392 <p id='n327' class='pln'><a href='#n327'>327</a></p> |
| 393 <p id='n328' class='pln'><a href='#n328'>328</a></p> |
| 394 <p id='n329' class='pln'><a href='#n329'>329</a></p> |
| 395 <p id='n330' class='pln'><a href='#n330'>330</a></p> |
| 396 <p id='n331' class='pln'><a href='#n331'>331</a></p> |
| 397 <p id='n332' class='pln'><a href='#n332'>332</a></p> |
| 398 <p id='n333' class='pln'><a href='#n333'>333</a></p> |
| 399 <p id='n334' class='pln'><a href='#n334'>334</a></p> |
| 400 <p id='n335' class='stm run hide_run'><a href='#n335'>335</a></p> |
| 401 <p id='n336' class='pln'><a href='#n336'>336</a></p> |
| 402 <p id='n337' class='stm run hide_run'><a href='#n337'>337</a></p> |
| 403 <p id='n338' class='stm run hide_run'><a href='#n338'>338</a></p> |
| 404 <p id='n339' class='stm run hide_run'><a href='#n339'>339</a></p> |
| 405 <p id='n340' class='pln'><a href='#n340'>340</a></p> |
| 406 <p id='n341' class='stm run hide_run'><a href='#n341'>341</a></p> |
| 407 <p id='n342' class='stm run hide_run'><a href='#n342'>342</a></p> |
| 408 <p id='n343' class='stm run hide_run'><a href='#n343'>343</a></p> |
| 409 <p id='n344' class='stm run hide_run'><a href='#n344'>344</a></p> |
| 410 <p id='n345' class='pln'><a href='#n345'>345</a></p> |
| 411 <p id='n346' class='stm run hide_run'><a href='#n346'>346</a></p> |
| 412 <p id='n347' class='stm run hide_run'><a href='#n347'>347</a></p> |
| 413 <p id='n348' class='pln'><a href='#n348'>348</a></p> |
| 414 <p id='n349' class='stm run hide_run'><a href='#n349'>349</a></p> |
| 415 <p id='n350' class='stm run hide_run'><a href='#n350'>350</a></p> |
| 416 <p id='n351' class='stm run hide_run'><a href='#n351'>351</a></p> |
| 417 <p id='n352' class='pln'><a href='#n352'>352</a></p> |
| 418 <p id='n353' class='stm run hide_run'><a href='#n353'>353</a></p> |
| 419 <p id='n354' class='stm run hide_run'><a href='#n354'>354</a></p> |
| 420 <p id='n355' class='pln'><a href='#n355'>355</a></p> |
| 421 <p id='n356' class='pln'><a href='#n356'>356</a></p> |
| 422 <p id='n357' class='pln'><a href='#n357'>357</a></p> |
| 423 <p id='n358' class='pln'><a href='#n358'>358</a></p> |
| 424 <p id='n359' class='pln'><a href='#n359'>359</a></p> |
| 425 <p id='n360' class='pln'><a href='#n360'>360</a></p> |
| 426 <p id='n361' class='stm run hide_run'><a href='#n361'>361</a></p> |
| 427 <p id='n362' class='stm run hide_run'><a href='#n362'>362</a></p> |
| 428 <p id='n363' class='stm run hide_run'><a href='#n363'>363</a></p> |
| 429 <p id='n364' class='pln'><a href='#n364'>364</a></p> |
| 430 <p id='n365' class='stm run hide_run'><a href='#n365'>365</a></p> |
| 431 <p id='n366' class='stm run hide_run'><a href='#n366'>366</a></p> |
| 432 <p id='n367' class='stm run hide_run'><a href='#n367'>367</a></p> |
| 433 <p id='n368' class='stm run hide_run'><a href='#n368'>368</a></p> |
| 434 <p id='n369' class='stm run hide_run'><a href='#n369'>369</a></p> |
| 435 <p id='n370' class='pln'><a href='#n370'>370</a></p> |
| 436 <p id='n371' class='stm run hide_run'><a href='#n371'>371</a></p> |
| 437 <p id='n372' class='stm run hide_run'><a href='#n372'>372</a></p> |
| 438 <p id='n373' class='pln'><a href='#n373'>373</a></p> |
| 439 <p id='n374' class='pln'><a href='#n374'>374</a></p> |
| 440 <p id='n375' class='pln'><a href='#n375'>375</a></p> |
| 441 <p id='n376' class='pln'><a href='#n376'>376</a></p> |
| 442 <p id='n377' class='pln'><a href='#n377'>377</a></p> |
| 443 <p id='n378' class='stm run hide_run'><a href='#n378'>378</a></p> |
| 444 <p id='n379' class='stm run hide_run'><a href='#n379'>379</a></p> |
| 445 <p id='n380' class='stm run hide_run'><a href='#n380'>380</a></p> |
| 446 <p id='n381' class='pln'><a href='#n381'>381</a></p> |
| 447 <p id='n382' class='stm run hide_run'><a href='#n382'>382</a></p> |
| 448 <p id='n383' class='stm run hide_run'><a href='#n383'>383</a></p> |
| 449 <p id='n384' class='stm run hide_run'><a href='#n384'>384</a></p> |
| 450 <p id='n385' class='stm run hide_run'><a href='#n385'>385</a></p> |
| 451 <p id='n386' class='stm run hide_run'><a href='#n386'>386</a></p> |
| 452 <p id='n387' class='pln'><a href='#n387'>387</a></p> |
| 453 <p id='n388' class='stm run hide_run'><a href='#n388'>388</a></p> |
| 454 <p id='n389' class='stm run hide_run'><a href='#n389'>389</a></p> |
| 455 <p id='n390' class='pln'><a href='#n390'>390</a></p> |
| 456 <p id='n391' class='pln'><a href='#n391'>391</a></p> |
| 457 <p id='n392' class='pln'><a href='#n392'>392</a></p> |
| 458 <p id='n393' class='pln'><a href='#n393'>393</a></p> |
| 459 <p id='n394' class='pln'><a href='#n394'>394</a></p> |
| 460 <p id='n395' class='pln'><a href='#n395'>395</a></p> |
| 461 <p id='n396' class='stm run hide_run'><a href='#n396'>396</a></p> |
| 462 <p id='n397' class='pln'><a href='#n397'>397</a></p> |
| 463 <p id='n398' class='pln'><a href='#n398'>398</a></p> |
| 464 <p id='n399' class='stm run hide_run'><a href='#n399'>399</a></p> |
| 465 <p id='n400' class='stm run hide_run'><a href='#n400'>400</a></p> |
| 466 <p id='n401' class='stm run hide_run'><a href='#n401'>401</a></p> |
| 467 <p id='n402' class='pln'><a href='#n402'>402</a></p> |
| 468 <p id='n403' class='pln'><a href='#n403'>403</a></p> |
| 469 <p id='n404' class='stm run hide_run'><a href='#n404'>404</a></p> |
| 470 <p id='n405' class='pln'><a href='#n405'>405</a></p> |
| 471 <p id='n406' class='pln'><a href='#n406'>406</a></p> |
| 472 <p id='n407' class='pln'><a href='#n407'>407</a></p> |
| 473 <p id='n408' class='pln'><a href='#n408'>408</a></p> |
| 474 <p id='n409' class='pln'><a href='#n409'>409</a></p> |
| 475 <p id='n410' class='pln'><a href='#n410'>410</a></p> |
| 476 <p id='n411' class='pln'><a href='#n411'>411</a></p> |
| 477 <p id='n412' class='pln'><a href='#n412'>412</a></p> |
| 478 <p id='n413' class='pln'><a href='#n413'>413</a></p> |
| 479 <p id='n414' class='pln'><a href='#n414'>414</a></p> |
| 480 <p id='n415' class='pln'><a href='#n415'>415</a></p> |
| 481 <p id='n416' class='pln'><a href='#n416'>416</a></p> |
| 482 <p id='n417' class='stm run hide_run'><a href='#n417'>417</a></p> |
| 483 <p id='n418' class='pln'><a href='#n418'>418</a></p> |
| 484 <p id='n419' class='pln'><a href='#n419'>419</a></p> |
| 485 <p id='n420' class='stm run hide_run'><a href='#n420'>420</a></p> |
| 486 <p id='n421' class='stm run hide_run'><a href='#n421'>421</a></p> |
| 487 <p id='n422' class='stm run hide_run'><a href='#n422'>422</a></p> |
| 488 <p id='n423' class='stm run hide_run'><a href='#n423'>423</a></p> |
| 489 <p id='n424' class='pln'><a href='#n424'>424</a></p> |
| 490 <p id='n425' class='stm run hide_run'><a href='#n425'>425</a></p> |
| 491 <p id='n426' class='pln'><a href='#n426'>426</a></p> |
| 492 <p id='n427' class='stm run hide_run'><a href='#n427'>427</a></p> |
| 493 <p id='n428' class='pln'><a href='#n428'>428</a></p> |
| 494 <p id='n429' class='pln'><a href='#n429'>429</a></p> |
| 495 <p id='n430' class='stm run hide_run'><a href='#n430'>430</a></p> |
| 496 <p id='n431' class='pln'><a href='#n431'>431</a></p> |
| 497 <p id='n432' class='pln'><a href='#n432'>432</a></p> |
| 498 <p id='n433' class='pln'><a href='#n433'>433</a></p> |
| 499 <p id='n434' class='pln'><a href='#n434'>434</a></p> |
| 500 <p id='n435' class='pln'><a href='#n435'>435</a></p> |
| 501 <p id='n436' class='stm run hide_run'><a href='#n436'>436</a></p> |
| 502 <p id='n437' class='pln'><a href='#n437'>437</a></p> |
| 503 <p id='n438' class='pln'><a href='#n438'>438</a></p> |
| 504 <p id='n439' class='stm run hide_run'><a href='#n439'>439</a></p> |
| 505 <p id='n440' class='pln'><a href='#n440'>440</a></p> |
| 506 <p id='n441' class='pln'><a href='#n441'>441</a></p> |
| 507 <p id='n442' class='pln'><a href='#n442'>442</a></p> |
| 508 <p id='n443' class='pln'><a href='#n443'>443</a></p> |
| 509 <p id='n444' class='pln'><a href='#n444'>444</a></p> |
| 510 <p id='n445' class='stm run hide_run'><a href='#n445'>445</a></p> |
| 511 <p id='n446' class='stm run hide_run'><a href='#n446'>446</a></p> |
| 512 <p id='n447' class='stm run hide_run'><a href='#n447'>447</a></p> |
| 513 <p id='n448' class='stm run hide_run'><a href='#n448'>448</a></p> |
| 514 <p id='n449' class='stm run hide_run'><a href='#n449'>449</a></p> |
| 515 <p id='n450' class='stm run hide_run'><a href='#n450'>450</a></p> |
| 516 <p id='n451' class='stm run hide_run'><a href='#n451'>451</a></p> |
| 517 <p id='n452' class='pln'><a href='#n452'>452</a></p> |
| 518 <p id='n453' class='stm run hide_run'><a href='#n453'>453</a></p> |
| 519 <p id='n454' class='stm run hide_run'><a href='#n454'>454</a></p> |
| 520 <p id='n455' class='pln'><a href='#n455'>455</a></p> |
| 521 <p id='n456' class='stm run hide_run'><a href='#n456'>456</a></p> |
| 522 <p id='n457' class='pln'><a href='#n457'>457</a></p> |
| 523 <p id='n458' class='stm run hide_run'><a href='#n458'>458</a></p> |
| 524 <p id='n459' class='pln'><a href='#n459'>459</a></p> |
| 525 <p id='n460' class='stm run hide_run'><a href='#n460'>460</a></p> |
| 526 <p id='n461' class='pln'><a href='#n461'>461</a></p> |
| 527 <p id='n462' class='pln'><a href='#n462'>462</a></p> |
| 528 <p id='n463' class='stm run hide_run'><a href='#n463'>463</a></p> |
| 529 <p id='n464' class='pln'><a href='#n464'>464</a></p> |
| 530 <p id='n465' class='pln'><a href='#n465'>465</a></p> |
| 531 <p id='n466' class='stm run hide_run'><a href='#n466'>466</a></p> |
| 532 <p id='n467' class='pln'><a href='#n467'>467</a></p> |
| 533 <p id='n468' class='stm run hide_run'><a href='#n468'>468</a></p> |
| 534 <p id='n469' class='pln'><a href='#n469'>469</a></p> |
| 535 <p id='n470' class='stm run hide_run'><a href='#n470'>470</a></p> |
| 536 <p id='n471' class='pln'><a href='#n471'>471</a></p> |
| 537 <p id='n472' class='pln'><a href='#n472'>472</a></p> |
| 538 <p id='n473' class='stm run hide_run'><a href='#n473'>473</a></p> |
| 539 <p id='n474' class='pln'><a href='#n474'>474</a></p> |
| 540 <p id='n475' class='stm run hide_run'><a href='#n475'>475</a></p> |
| 541 <p id='n476' class='stm run hide_run'><a href='#n476'>476</a></p> |
| 542 <p id='n477' class='pln'><a href='#n477'>477</a></p> |
| 543 <p id='n478' class='stm run hide_run'><a href='#n478'>478</a></p> |
| 544 <p id='n479' class='stm run hide_run'><a href='#n479'>479</a></p> |
| 545 <p id='n480' class='stm run hide_run'><a href='#n480'>480</a></p> |
| 546 <p id='n481' class='stm run hide_run'><a href='#n481'>481</a></p> |
| 547 <p id='n482' class='pln'><a href='#n482'>482</a></p> |
| 548 <p id='n483' class='pln'><a href='#n483'>483</a></p> |
| 549 <p id='n484' class='pln'><a href='#n484'>484</a></p> |
| 550 <p id='n485' class='pln'><a href='#n485'>485</a></p> |
| 551 <p id='n486' class='stm run hide_run'><a href='#n486'>486</a></p> |
| 552 <p id='n487' class='pln'><a href='#n487'>487</a></p> |
| 553 <p id='n488' class='stm run hide_run'><a href='#n488'>488</a></p> |
| 554 <p id='n489' class='pln'><a href='#n489'>489</a></p> |
| 555 <p id='n490' class='pln'><a href='#n490'>490</a></p> |
| 556 <p id='n491' class='stm run hide_run'><a href='#n491'>491</a></p> |
| 557 <p id='n492' class='pln'><a href='#n492'>492</a></p> |
| 558 <p id='n493' class='pln'><a href='#n493'>493</a></p> |
| 559 <p id='n494' class='pln'><a href='#n494'>494</a></p> |
| 560 <p id='n495' class='pln'><a href='#n495'>495</a></p> |
| 561 <p id='n496' class='pln'><a href='#n496'>496</a></p> |
| 562 <p id='n497' class='pln'><a href='#n497'>497</a></p> |
| 563 <p id='n498' class='pln'><a href='#n498'>498</a></p> |
| 564 <p id='n499' class='pln'><a href='#n499'>499</a></p> |
| 565 <p id='n500' class='pln'><a href='#n500'>500</a></p> |
| 566 <p id='n501' class='pln'><a href='#n501'>501</a></p> |
| 567 <p id='n502' class='pln'><a href='#n502'>502</a></p> |
| 568 <p id='n503' class='pln'><a href='#n503'>503</a></p> |
| 569 <p id='n504' class='pln'><a href='#n504'>504</a></p> |
| 570 <p id='n505' class='pln'><a href='#n505'>505</a></p> |
| 571 <p id='n506' class='pln'><a href='#n506'>506</a></p> |
| 572 <p id='n507' class='pln'><a href='#n507'>507</a></p> |
| 573 <p id='n508' class='stm run hide_run'><a href='#n508'>508</a></p> |
| 574 <p id='n509' class='stm run hide_run'><a href='#n509'>509</a></p> |
| 575 <p id='n510' class='pln'><a href='#n510'>510</a></p> |
| 576 <p id='n511' class='pln'><a href='#n511'>511</a></p> |
| 577 <p id='n512' class='pln'><a href='#n512'>512</a></p> |
| 578 <p id='n513' class='pln'><a href='#n513'>513</a></p> |
| 579 <p id='n514' class='stm run hide_run'><a href='#n514'>514</a></p> |
| 580 <p id='n515' class='pln'><a href='#n515'>515</a></p> |
| 581 <p id='n516' class='stm run hide_run'><a href='#n516'>516</a></p> |
| 582 <p id='n517' class='stm run hide_run'><a href='#n517'>517</a></p> |
| 583 <p id='n518' class='stm run hide_run'><a href='#n518'>518</a></p> |
| 584 <p id='n519' class='stm run hide_run'><a href='#n519'>519</a></p> |
| 585 <p id='n520' class='pln'><a href='#n520'>520</a></p> |
| 586 <p id='n521' class='stm run hide_run'><a href='#n521'>521</a></p> |
| 587 <p id='n522' class='stm run hide_run'><a href='#n522'>522</a></p> |
| 588 <p id='n523' class='stm run hide_run'><a href='#n523'>523</a></p> |
| 589 <p id='n524' class='stm run hide_run'><a href='#n524'>524</a></p> |
| 590 <p id='n525' class='pln'><a href='#n525'>525</a></p> |
| 591 <p id='n526' class='pln'><a href='#n526'>526</a></p> |
| 592 <p id='n527' class='stm run hide_run'><a href='#n527'>527</a></p> |
| 593 <p id='n528' class='stm run hide_run'><a href='#n528'>528</a></p> |
| 594 <p id='n529' class='pln'><a href='#n529'>529</a></p> |
| 595 <p id='n530' class='stm run hide_run'><a href='#n530'>530</a></p> |
| 596 <p id='n531' class='stm run hide_run'><a href='#n531'>531</a></p> |
| 597 <p id='n532' class='pln'><a href='#n532'>532</a></p> |
| 598 <p id='n533' class='pln'><a href='#n533'>533</a></p> |
| 599 <p id='n534' class='stm run hide_run'><a href='#n534'>534</a></p> |
| 600 <p id='n535' class='stm run hide_run'><a href='#n535'>535</a></p> |
| 601 <p id='n536' class='pln'><a href='#n536'>536</a></p> |
| 602 <p id='n537' class='stm run hide_run'><a href='#n537'>537</a></p> |
| 603 <p id='n538' class='pln'><a href='#n538'>538</a></p> |
| 604 <p id='n539' class='pln'><a href='#n539'>539</a></p> |
| 605 <p id='n540' class='stm run hide_run'><a href='#n540'>540</a></p> |
| 606 <p id='n541' class='stm run hide_run'><a href='#n541'>541</a></p> |
| 607 <p id='n542' class='stm run hide_run'><a href='#n542'>542</a></p> |
| 608 <p id='n543' class='stm run hide_run'><a href='#n543'>543</a></p> |
| 609 <p id='n544' class='pln'><a href='#n544'>544</a></p> |
| 610 <p id='n545' class='stm run hide_run'><a href='#n545'>545</a></p> |
| 611 <p id='n546' class='stm run hide_run'><a href='#n546'>546</a></p> |
| 612 <p id='n547' class='pln'><a href='#n547'>547</a></p> |
| 613 <p id='n548' class='stm run hide_run'><a href='#n548'>548</a></p> |
| 614 <p id='n549' class='pln'><a href='#n549'>549</a></p> |
| 615 <p id='n550' class='pln'><a href='#n550'>550</a></p> |
| 616 <p id='n551' class='pln'><a href='#n551'>551</a></p> |
| 617 <p id='n552' class='pln'><a href='#n552'>552</a></p> |
| 618 <p id='n553' class='pln'><a href='#n553'>553</a></p> |
| 619 <p id='n554' class='stm run hide_run'><a href='#n554'>554</a></p> |
| 620 <p id='n555' class='pln'><a href='#n555'>555</a></p> |
| 621 <p id='n556' class='pln'><a href='#n556'>556</a></p> |
| 622 <p id='n557' class='pln'><a href='#n557'>557</a></p> |
| 623 <p id='n558' class='pln'><a href='#n558'>558</a></p> |
| 624 <p id='n559' class='pln'><a href='#n559'>559</a></p> |
| 625 <p id='n560' class='pln'><a href='#n560'>560</a></p> |
| 626 <p id='n561' class='pln'><a href='#n561'>561</a></p> |
| 627 <p id='n562' class='pln'><a href='#n562'>562</a></p> |
| 628 <p id='n563' class='pln'><a href='#n563'>563</a></p> |
| 629 <p id='n564' class='pln'><a href='#n564'>564</a></p> |
| 630 <p id='n565' class='pln'><a href='#n565'>565</a></p> |
| 631 <p id='n566' class='pln'><a href='#n566'>566</a></p> |
| 632 <p id='n567' class='pln'><a href='#n567'>567</a></p> |
| 633 <p id='n568' class='stm run hide_run'><a href='#n568'>568</a></p> |
| 634 <p id='n569' class='stm run hide_run'><a href='#n569'>569</a></p> |
| 635 <p id='n570' class='stm run hide_run'><a href='#n570'>570</a></p> |
| 636 <p id='n571' class='stm run hide_run'><a href='#n571'>571</a></p> |
| 637 <p id='n572' class='pln'><a href='#n572'>572</a></p> |
| 638 <p id='n573' class='stm run hide_run'><a href='#n573'>573</a></p> |
| 639 <p id='n574' class='stm run hide_run'><a href='#n574'>574</a></p> |
| 640 <p id='n575' class='pln'><a href='#n575'>575</a></p> |
| 641 <p id='n576' class='stm run hide_run'><a href='#n576'>576</a></p> |
| 642 <p id='n577' class='stm run hide_run'><a href='#n577'>577</a></p> |
| 643 <p id='n578' class='stm run hide_run'><a href='#n578'>578</a></p> |
| 644 <p id='n579' class='pln'><a href='#n579'>579</a></p> |
| 645 <p id='n580' class='stm run hide_run'><a href='#n580'>580</a></p> |
| 646 <p id='n581' class='pln'><a href='#n581'>581</a></p> |
| 647 <p id='n582' class='stm run hide_run'><a href='#n582'>582</a></p> |
| 648 <p id='n583' class='stm run hide_run'><a href='#n583'>583</a></p> |
| 649 <p id='n584' class='pln'><a href='#n584'>584</a></p> |
| 650 <p id='n585' class='stm run hide_run'><a href='#n585'>585</a></p> |
| 651 <p id='n586' class='stm run hide_run'><a href='#n586'>586</a></p> |
| 652 <p id='n587' class='pln'><a href='#n587'>587</a></p> |
| 653 <p id='n588' class='stm run hide_run'><a href='#n588'>588</a></p> |
| 654 <p id='n589' class='stm run hide_run'><a href='#n589'>589</a></p> |
| 655 <p id='n590' class='pln'><a href='#n590'>590</a></p> |
| 656 <p id='n591' class='pln'><a href='#n591'>591</a></p> |
| 657 <p id='n592' class='pln'><a href='#n592'>592</a></p> |
| 658 <p id='n593' class='pln'><a href='#n593'>593</a></p> |
| 659 <p id='n594' class='stm run hide_run'><a href='#n594'>594</a></p> |
| 660 <p id='n595' class='pln'><a href='#n595'>595</a></p> |
| 661 <p id='n596' class='pln'><a href='#n596'>596</a></p> |
| 662 <p id='n597' class='stm run hide_run'><a href='#n597'>597</a></p> |
| 663 <p id='n598' class='stm run hide_run'><a href='#n598'>598</a></p> |
| 664 <p id='n599' class='pln'><a href='#n599'>599</a></p> |
| 665 <p id='n600' class='stm run hide_run'><a href='#n600'>600</a></p> |
| 666 <p id='n601' class='pln'><a href='#n601'>601</a></p> |
| 667 <p id='n602' class='pln'><a href='#n602'>602</a></p> |
| 668 <p id='n603' class='stm run hide_run'><a href='#n603'>603</a></p> |
| 669 <p id='n604' class='pln'><a href='#n604'>604</a></p> |
| 670 <p id='n605' class='pln'><a href='#n605'>605</a></p> |
| 671 <p id='n606' class='pln'><a href='#n606'>606</a></p> |
| 672 <p id='n607' class='pln'><a href='#n607'>607</a></p> |
| 673 <p id='n608' class='pln'><a href='#n608'>608</a></p> |
| 674 <p id='n609' class='pln'><a href='#n609'>609</a></p> |
| 675 <p id='n610' class='pln'><a href='#n610'>610</a></p> |
| 676 <p id='n611' class='pln'><a href='#n611'>611</a></p> |
| 677 <p id='n612' class='pln'><a href='#n612'>612</a></p> |
| 678 <p id='n613' class='pln'><a href='#n613'>613</a></p> |
| 679 <p id='n614' class='pln'><a href='#n614'>614</a></p> |
| 680 <p id='n615' class='pln'><a href='#n615'>615</a></p> |
| 681 <p id='n616' class='pln'><a href='#n616'>616</a></p> |
| 682 <p id='n617' class='pln'><a href='#n617'>617</a></p> |
| 683 <p id='n618' class='pln'><a href='#n618'>618</a></p> |
| 684 <p id='n619' class='pln'><a href='#n619'>619</a></p> |
| 685 <p id='n620' class='pln'><a href='#n620'>620</a></p> |
| 686 <p id='n621' class='pln'><a href='#n621'>621</a></p> |
| 687 <p id='n622' class='pln'><a href='#n622'>622</a></p> |
| 688 <p id='n623' class='pln'><a href='#n623'>623</a></p> |
| 689 <p id='n624' class='pln'><a href='#n624'>624</a></p> |
| 690 <p id='n625' class='pln'><a href='#n625'>625</a></p> |
| 691 <p id='n626' class='pln'><a href='#n626'>626</a></p> |
| 692 <p id='n627' class='pln'><a href='#n627'>627</a></p> |
| 693 <p id='n628' class='pln'><a href='#n628'>628</a></p> |
| 694 <p id='n629' class='pln'><a href='#n629'>629</a></p> |
| 695 <p id='n630' class='pln'><a href='#n630'>630</a></p> |
| 696 <p id='n631' class='pln'><a href='#n631'>631</a></p> |
| 697 <p id='n632' class='pln'><a href='#n632'>632</a></p> |
| 698 <p id='n633' class='pln'><a href='#n633'>633</a></p> |
| 699 <p id='n634' class='pln'><a href='#n634'>634</a></p> |
| 700 <p id='n635' class='pln'><a href='#n635'>635</a></p> |
| 701 <p id='n636' class='pln'><a href='#n636'>636</a></p> |
| 702 <p id='n637' class='pln'><a href='#n637'>637</a></p> |
| 703 <p id='n638' class='pln'><a href='#n638'>638</a></p> |
| 704 <p id='n639' class='pln'><a href='#n639'>639</a></p> |
| 705 <p id='n640' class='pln'><a href='#n640'>640</a></p> |
| 706 <p id='n641' class='pln'><a href='#n641'>641</a></p> |
| 707 <p id='n642' class='pln'><a href='#n642'>642</a></p> |
| 708 <p id='n643' class='stm run hide_run'><a href='#n643'>643</a></p> |
| 709 <p id='n644' class='pln'><a href='#n644'>644</a></p> |
| 710 <p id='n645' class='pln'><a href='#n645'>645</a></p> |
| 711 <p id='n646' class='pln'><a href='#n646'>646</a></p> |
| 712 <p id='n647' class='stm run hide_run'><a href='#n647'>647</a></p> |
| 713 <p id='n648' class='pln'><a href='#n648'>648</a></p> |
| 714 <p id='n649' class='stm run hide_run'><a href='#n649'>649</a></p> |
| 715 <p id='n650' class='pln'><a href='#n650'>650</a></p> |
| 716 <p id='n651' class='stm run hide_run'><a href='#n651'>651</a></p> |
| 717 <p id='n652' class='pln'><a href='#n652'>652</a></p> |
| 718 <p id='n653' class='pln'><a href='#n653'>653</a></p> |
| 719 <p id='n654' class='stm run hide_run'><a href='#n654'>654</a></p> |
| 720 <p id='n655' class='pln'><a href='#n655'>655</a></p> |
| 721 <p id='n656' class='pln'><a href='#n656'>656</a></p> |
| 722 <p id='n657' class='pln'><a href='#n657'>657</a></p> |
| 723 <p id='n658' class='pln'><a href='#n658'>658</a></p> |
| 724 <p id='n659' class='pln'><a href='#n659'>659</a></p> |
| 725 <p id='n660' class='pln'><a href='#n660'>660</a></p> |
| 726 <p id='n661' class='pln'><a href='#n661'>661</a></p> |
| 727 <p id='n662' class='pln'><a href='#n662'>662</a></p> |
| 728 <p id='n663' class='stm run hide_run'><a href='#n663'>663</a></p> |
| 729 <p id='n664' class='stm run hide_run'><a href='#n664'>664</a></p> |
| 730 <p id='n665' class='pln'><a href='#n665'>665</a></p> |
| 731 <p id='n666' class='stm run hide_run'><a href='#n666'>666</a></p> |
| 732 <p id='n667' class='stm run hide_run'><a href='#n667'>667</a></p> |
| 733 <p id='n668' class='stm run hide_run'><a href='#n668'>668</a></p> |
| 734 <p id='n669' class='pln'><a href='#n669'>669</a></p> |
| 735 <p id='n670' class='stm run hide_run'><a href='#n670'>670</a></p> |
| 736 <p id='n671' class='stm run hide_run'><a href='#n671'>671</a></p> |
| 737 <p id='n672' class='pln'><a href='#n672'>672</a></p> |
| 738 <p id='n673' class='stm run hide_run'><a href='#n673'>673</a></p> |
| 739 <p id='n674' class='stm run hide_run'><a href='#n674'>674</a></p> |
| 740 <p id='n675' class='stm run hide_run'><a href='#n675'>675</a></p> |
| 741 <p id='n676' class='pln'><a href='#n676'>676</a></p> |
| 742 <p id='n677' class='stm run hide_run'><a href='#n677'>677</a></p> |
| 743 <p id='n678' class='stm run hide_run'><a href='#n678'>678</a></p> |
| 744 <p id='n679' class='pln'><a href='#n679'>679</a></p> |
| 745 <p id='n680' class='pln'><a href='#n680'>680</a></p> |
| 746 <p id='n681' class='pln'><a href='#n681'>681</a></p> |
| 747 <p id='n682' class='pln'><a href='#n682'>682</a></p> |
| 748 <p id='n683' class='pln'><a href='#n683'>683</a></p> |
| 749 <p id='n684' class='pln'><a href='#n684'>684</a></p> |
| 750 <p id='n685' class='pln'><a href='#n685'>685</a></p> |
| 751 <p id='n686' class='pln'><a href='#n686'>686</a></p> |
| 752 <p id='n687' class='stm run hide_run'><a href='#n687'>687</a></p> |
| 753 <p id='n688' class='stm run hide_run'><a href='#n688'>688</a></p> |
| 754 <p id='n689' class='stm run hide_run'><a href='#n689'>689</a></p> |
| 755 <p id='n690' class='stm run hide_run'><a href='#n690'>690</a></p> |
| 756 <p id='n691' class='pln'><a href='#n691'>691</a></p> |
| 757 <p id='n692' class='pln'><a href='#n692'>692</a></p> |
| 758 <p id='n693' class='pln'><a href='#n693'>693</a></p> |
| 759 <p id='n694' class='pln'><a href='#n694'>694</a></p> |
| 760 <p id='n695' class='pln'><a href='#n695'>695</a></p> |
| 761 <p id='n696' class='stm run hide_run'><a href='#n696'>696</a></p> |
| 762 <p id='n697' class='pln'><a href='#n697'>697</a></p> |
| 763 <p id='n698' class='stm run hide_run'><a href='#n698'>698</a></p> |
| 764 <p id='n699' class='stm run hide_run'><a href='#n699'>699</a></p> |
| 765 <p id='n700' class='stm run hide_run'><a href='#n700'>700</a></p> |
| 766 <p id='n701' class='stm run hide_run'><a href='#n701'>701</a></p> |
| 767 <p id='n702' class='pln'><a href='#n702'>702</a></p> |
| 768 <p id='n703' class='stm run hide_run'><a href='#n703'>703</a></p> |
| 769 <p id='n704' class='stm run hide_run'><a href='#n704'>704</a></p> |
| 770 <p id='n705' class='stm run hide_run'><a href='#n705'>705</a></p> |
| 771 <p id='n706' class='pln'><a href='#n706'>706</a></p> |
| 772 <p id='n707' class='pln'><a href='#n707'>707</a></p> |
| 773 <p id='n708' class='stm run hide_run'><a href='#n708'>708</a></p> |
| 774 <p id='n709' class='pln'><a href='#n709'>709</a></p> |
| 775 <p id='n710' class='pln'><a href='#n710'>710</a></p> |
| 776 <p id='n711' class='stm run hide_run'><a href='#n711'>711</a></p> |
| 777 <p id='n712' class='stm run hide_run'><a href='#n712'>712</a></p> |
| 778 <p id='n713' class='pln'><a href='#n713'>713</a></p> |
| 779 <p id='n714' class='stm run hide_run'><a href='#n714'>714</a></p> |
| 780 <p id='n715' class='pln'><a href='#n715'>715</a></p> |
| 781 <p id='n716' class='stm run hide_run'><a href='#n716'>716</a></p> |
| 782 <p id='n717' class='pln'><a href='#n717'>717</a></p> |
| 783 <p id='n718' class='pln'><a href='#n718'>718</a></p> |
| 784 <p id='n719' class='pln'><a href='#n719'>719</a></p> |
| 785 <p id='n720' class='pln'><a href='#n720'>720</a></p> |
| 786 <p id='n721' class='pln'><a href='#n721'>721</a></p> |
| 787 <p id='n722' class='stm run hide_run'><a href='#n722'>722</a></p> |
| 788 <p id='n723' class='stm run hide_run'><a href='#n723'>723</a></p> |
| 789 <p id='n724' class='pln'><a href='#n724'>724</a></p> |
| 790 <p id='n725' class='pln'><a href='#n725'>725</a></p> |
| 791 <p id='n726' class='stm run hide_run'><a href='#n726'>726</a></p> |
| 792 <p id='n727' class='stm run hide_run'><a href='#n727'>727</a></p> |
| 793 <p id='n728' class='pln'><a href='#n728'>728</a></p> |
| 794 <p id='n729' class='stm run hide_run'><a href='#n729'>729</a></p> |
| 795 <p id='n730' class='pln'><a href='#n730'>730</a></p> |
| 796 <p id='n731' class='pln'><a href='#n731'>731</a></p> |
| 797 <p id='n732' class='pln'><a href='#n732'>732</a></p> |
| 798 <p id='n733' class='pln'><a href='#n733'>733</a></p> |
| 799 <p id='n734' class='stm run hide_run'><a href='#n734'>734</a></p> |
| 800 <p id='n735' class='pln'><a href='#n735'>735</a></p> |
| 801 <p id='n736' class='stm run hide_run'><a href='#n736'>736</a></p> |
| 802 |
| 803 </td> |
| 804 <td class='text' valign='top'> |
| 805 <p id='t1' class='pln'><span class='com'># Copyright 2015 The Chromium Authors.
All rights reserved.</span><span class='strut'> </span></p> |
| 806 <p id='t2' class='pln'><span class='com'># Use of this source code is governed b
y a BSD-style license that can be</span><span class='strut'> </span></p> |
| 807 <p id='t3' class='pln'><span class='com'># found in the LICENSE file.</span><spa
n class='strut'> </span></p> |
| 808 <p id='t4' class='pln'><span class='strut'> </span></p> |
| 809 <p id='t5' class='stm run hide_run'><span class='key'>import</span> <span class=
'nam'>collections</span><span class='strut'> </span></p> |
| 810 <p id='t6' class='stm run hide_run'><span class='key'>import</span> <span class=
'nam'>os</span><span class='strut'> </span></p> |
| 811 <p id='t7' class='stm run hide_run'><span class='key'>import</span> <span class=
'nam'>re</span><span class='strut'> </span></p> |
| 812 <p id='t8' class='pln'><span class='strut'> </span></p> |
| 813 <p id='t9' class='stm run hide_run'><span class='key'>from</span> <span class='n
am'>common</span><span class='op'>.</span><span class='nam'>diff</span> <span cl
ass='key'>import</span> <span class='nam'>ChangeType</span><span class='strut'>&
nbsp;</span></p> |
| 814 <p id='t10' class='stm run hide_run'><span class='key'>from</span> <span class='
nam'>common</span><span class='op'>.</span><span class='nam'>git_repository</spa
n> <span class='key'>import</span> <span class='nam'>GitRepository</span><span c
lass='strut'> </span></p> |
| 815 <p id='t11' class='stm run hide_run'><span class='key'>from</span> <span class='
nam'>common</span><span class='op'>.</span><span class='nam'>http_client_appengi
ne</span> <span class='key'>import</span> <span class='nam'>HttpClientAppengine<
/span> <span class='key'>as</span> <span class='nam'>HttpClient</span><span clas
s='strut'> </span></p> |
| 816 <p id='t12' class='stm run hide_run'><span class='key'>from</span> <span class='
nam'>waterfall</span> <span class='key'>import</span> <span class='nam'>waterfal
l_config</span><span class='strut'> </span></p> |
| 817 <p id='t13' class='stm run hide_run'><span class='key'>from</span> <span class='
nam'>waterfall</span><span class='op'>.</span><span class='nam'>failure_signal</
span> <span class='key'>import</span> <span class='nam'>FailureSignal</span><spa
n class='strut'> </span></p> |
| 818 <p id='t14' class='pln'><span class='strut'> </span></p> |
| 819 <p id='t15' class='pln'><span class='strut'> </span></p> |
| 820 <p id='t16' class='stm run hide_run'><span class='key'>def</span> <span class='n
am'>_IsSameFile</span><span class='op'>(</span><span class='nam'>changed_src_fil
e_path</span><span class='op'>,</span> <span class='nam'>file_path_in_log</span>
<span class='op'>)</span><span class='op'>:</span><span class='strut'> </sp
an></p> |
| 821 <p id='t17' class='pln'> <span class='str'>"""Guesses if th
e two files are the same.</span><span class='strut'> </span></p> |
| 822 <p id='t18' class='pln'><span class='strut'> </span></p> |
| 823 <p id='t19' class='pln'><span class='str'> Args:</span><span class='strut'
> </span></p> |
| 824 <p id='t20' class='pln'><span class='str'> changed_src_file_path (s
tr): Full path of a file committed to git repo.</span><span class='strut'>
</span></p> |
| 825 <p id='t21' class='pln'><span class='str'> file_path_in_log (str):
Path of a file appearing in a failure log. It might</span><span class='strut'>&n
bsp;</span></p> |
| 826 <p id='t22' class='pln'><span class='str'> not be a f
ull path.</span><span class='strut'> </span></p> |
| 827 <p id='t23' class='pln'><span class='strut'> </span></p> |
| 828 <p id='t24' class='pln'><span class='str'> Returns:</span><span class='str
ut'> </span></p> |
| 829 <p id='t25' class='pln'><span class='str'> True if the two files ar
e likely the same, otherwise False. Eg.:</span><span class='strut'> </span>
</p> |
| 830 <p id='t26' class='pln'><span class='str'> True: (chrome/tes
t/base/chrome_process_util.h, base/chrome_process_util.h)</span><span class='str
ut'> </span></p> |
| 831 <p id='t27' class='pln'><span class='str'> True: (a/b/x.cc,
a/b/x.cc)</span><span class='strut'> </span></p> |
| 832 <p id='t28' class='pln'><span class='str'> False: (c/x.cc, a
/b/c/x.cc)</span><span class='strut'> </span></p> |
| 833 <p id='t29' class='pln'><span class='str'> """</span><span
class='strut'> </span></p> |
| 834 <p id='t30' class='stm run hide_run'> <span class='nam'>changed_src_file_p
ath_lower</span> <span class='op'>=</span> <span class='nam'>changed_src_file_pa
th</span><span class='op'>.</span><span class='nam'>lower</span><span class='op'
>(</span><span class='op'>)</span><span class='strut'> </span></p> |
| 835 <p id='t31' class='stm run hide_run'> <span class='nam'>file_path_in_log_l
ower</span> <span class='op'>=</span> <span class='nam'>file_path_in_log</span><
span class='op'>.</span><span class='nam'>lower</span><span class='op'>(</span><
span class='op'>)</span><span class='strut'> </span></p> |
| 836 <p id='t32' class='pln'><span class='strut'> </span></p> |
| 837 <p id='t33' class='stm run hide_run'> <span class='key'>if</span> <span cl
ass='nam'>changed_src_file_path_lower</span> <span class='op'>==</span> <span cl
ass='nam'>file_path_in_log_lower</span><span class='op'>:</span><span class='str
ut'> </span></p> |
| 838 <p id='t34' class='stm run hide_run'> <span class='key'>return</spa
n> <span class='nam'>True</span><span class='strut'> </span></p> |
| 839 <p id='t35' class='stm run hide_run'> <span class='key'>return</span> <spa
n class='nam'>changed_src_file_path_lower</span><span class='op'>.</span><span c
lass='nam'>endswith</span><span class='op'>(</span><span class='str'>'/%s
9;</span> <span class='op'>%</span> <span class='nam'>file_path_in_log_lower</sp
an><span class='op'>)</span><span class='strut'> </span></p> |
| 840 <p id='t36' class='pln'><span class='strut'> </span></p> |
| 841 <p id='t37' class='pln'><span class='strut'> </span></p> |
| 842 <p id='t38' class='stm run hide_run'><span class='key'>def</span> <span class='n
am'>_GetGitBlame</span><span class='op'>(</span><span class='nam'>repo_info</spa
n><span class='op'>,</span> <span class='nam'>touched_file_path</span><span clas
s='op'>)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 843 <p id='t39' class='pln'> <span class='str'>"""Gets git blam
es of touched_file.</span><span class='strut'> </span></p> |
| 844 <p id='t40' class='pln'><span class='strut'> </span></p> |
| 845 <p id='t41' class='pln'><span class='str'> Args:</span><span class='strut'
> </span></p> |
| 846 <p id='t42' class='pln'><span class='str'> repo_info (dict): The re
po_url and revision for the build cycle.</span><span class='strut'> </span>
</p> |
| 847 <p id='t43' class='pln'><span class='str'> touched_file_path (str):
Full path of a file in change_log.</span><span class='strut'> </span></p> |
| 848 <p id='t44' class='pln'><span class='str'> """</span><span
class='strut'> </span></p> |
| 849 <p id='t45' class='stm run hide_run'> <span class='key'>if</span> <span cl
ass='nam'>repo_info</span><span class='op'>:</span><span class='strut'> </s
pan></p> |
| 850 <p id='t46' class='stm run hide_run'> <span class='nam'>repo_url</s
pan> <span class='op'>=</span> <span class='nam'>repo_info</span><span class='op
'>[</span><span class='str'>'repo_url'</span><span class='op'>]</span><s
pan class='strut'> </span></p> |
| 851 <p id='t47' class='stm run hide_run'> <span class='nam'>git_repo</s
pan> <span class='op'>=</span> <span class='nam'>GitRepository</span><span class
='op'>(</span><span class='nam'>repo_url</span><span class='op'>,</span> <span c
lass='nam'>HttpClient</span><span class='op'>(</span><span class='op'>)</span><s
pan class='op'>)</span><span class='strut'> </span></p> |
| 852 <p id='t48' class='stm run hide_run'> <span class='nam'>revision</s
pan> <span class='op'>=</span> <span class='nam'>repo_info</span><span class='op
'>[</span><span class='str'>'revision'</span><span class='op'>]</span><s
pan class='strut'> </span></p> |
| 853 <p id='t49' class='stm run hide_run'> <span class='key'>return</spa
n> <span class='nam'>git_repo</span><span class='op'>.</span><span class='nam'>G
etBlame</span><span class='op'>(</span><span class='nam'>touched_file_path</span
><span class='op'>,</span> <span class='nam'>revision</span><span class='op'>)</
span><span class='strut'> </span></p> |
| 854 <p id='t50' class='pln'><span class='strut'> </span></p> |
| 855 <p id='t51' class='pln'><span class='strut'> </span></p> |
| 856 <p id='t52' class='stm run hide_run'><span class='key'>def</span> <span class='n
am'>_GetChangedLinesForChromiumRepo</span><span class='op'>(</span><span class='
nam'>repo_info</span><span class='op'>,</span> <span class='nam'>touched_file</s
pan><span class='op'>,</span> <span class='nam'>line_numbers</span><span class='
op'>,</span><span class='strut'> </span></p> |
| 857 <p id='t53' class='pln'>
<span clas
s='nam'>suspected_revision</span><span class='op'>)</span><span class='op'>:</sp
an><span class='strut'> </span></p> |
| 858 <p id='t54' class='pln'> <span class='str'>"""Checks if the
CL made change close to the failed line in log.</span><span class='strut'> 
;</span></p> |
| 859 <p id='t55' class='pln'><span class='strut'> </span></p> |
| 860 <p id='t56' class='pln'><span class='str'> Args:</span><span class='strut'
> </span></p> |
| 861 <p id='t57' class='pln'><span class='str'> repo_info (dict): The re
po_url and revision for the build cycle.</span><span class='strut'> </span>
</p> |
| 862 <p id='t58' class='pln'><span class='str'> touched_file (dict): The
touched file found in the change log.</span><span class='strut'> </span></
p> |
| 863 <p id='t59' class='pln'><span class='str'> line_numbers (list): Lis
t of line_numbers mentioned in the failure log.</span><span class='strut'>
</span></p> |
| 864 <p id='t60' class='pln'><span class='str'> suspected_revision (str)
: Git hash revision of the suspected CL.</span><span class='strut'> </span>
</p> |
| 865 <p id='t61' class='pln'><span class='strut'> </span></p> |
| 866 <p id='t62' class='pln'><span class='str'> Returns:</span><span class='str
ut'> </span></p> |
| 867 <p id='t63' class='pln'><span class='str'> A list of lines which ar
e mentioned in log and changed in cl.</span><span class='strut'> </span></p
> |
| 868 <p id='t64' class='pln'><span class='str'> """</span><span
class='strut'> </span></p> |
| 869 <p id='t65' class='stm run hide_run'> <span class='nam'>changed_line_numbe
rs</span> <span class='op'>=</span> <span class='op'>[</span><span class='op'>]<
/span><span class='strut'> </span></p> |
| 870 <p id='t66' class='stm run hide_run'> <span class='key'>if</span> <span cl
ass='nam'>line_numbers</span><span class='op'>:</span><span class='strut'>
</span></p> |
| 871 <p id='t67' class='stm run hide_run'> <span class='nam'>blame</span
> <span class='op'>=</span> <span class='nam'>_GetGitBlame</span><span class='op
'>(</span><span class='nam'>repo_info</span><span class='op'>,</span> <span clas
s='nam'>touched_file</span><span class='op'>[</span><span class='str'>'new_p
ath'</span><span class='op'>]</span><span class='op'>)</span><span class='st
rut'> </span></p> |
| 872 <p id='t68' class='stm run hide_run'> <span class='key'>if</span> <
span class='nam'>blame</span><span class='op'>:</span><span class='strut'>
</span></p> |
| 873 <p id='t69' class='stm run hide_run'> <span class='key'>for<
/span> <span class='nam'>line_number</span> <span class='key'>in</span> <span cl
ass='nam'>line_numbers</span><span class='op'>:</span><span class='strut'>
</span></p> |
| 874 <p id='t70' class='stm run hide_run'> <span class='ke
y'>for</span> <span class='nam'>region</span> <span class='key'>in</span> <span
class='nam'>blame</span><span class='op'>:</span><span class='strut'> </spa
n></p> |
| 875 <p id='t71' class='stm run hide_run'> <span cl
ass='key'>if</span> <span class='nam'>region</span><span class='op'>.</span><spa
n class='nam'>revision</span> <span class='op'>==</span> <span class='nam'>suspe
cted_revision</span><span class='op'>:</span><span class='strut'> </span></
p> |
| 876 <p id='t72' class='stm run hide_run'> <
span class='key'>if</span> <span class='op'>(</span><span class='nam'>line_numbe
r</span> <span class='op'>>=</span> <span class='nam'>region</span><span clas
s='op'>.</span><span class='nam'>start</span> <span class='key'>and</span><span
class='strut'> </span></p> |
| 877 <p id='t73' class='pln'>
<span class='nam'>line_number</span> <span class='op'><=</span> <span class='
nam'>region</span><span class='op'>.</span><span class='nam'>start</span> <span
class='op'>+</span> <span class='nam'>region</span><span class='op'>.</span><spa
n class='nam'>count</span> <span class='op'>-</span> <span class='num'>1</span><
span class='op'>)</span><span class='op'>:</span><span class='strut'> </spa
n></p> |
| 878 <p id='t74' class='stm run hide_run'> &
nbsp; <span class='nam'>changed_line_numbers</span><span class='op'>.</span><spa
n class='nam'>append</span><span class='op'>(</span><span class='nam'>line_numbe
r</span><span class='op'>)</span><span class='strut'> </span></p> |
| 879 <p id='t75' class='pln'><span class='strut'> </span></p> |
| 880 <p id='t76' class='stm run hide_run'> <span class='key'>return</span> <spa
n class='nam'>changed_line_numbers</span><span class='strut'> </span></p> |
| 881 <p id='t77' class='pln'><span class='strut'> </span></p> |
| 882 <p id='t78' class='pln'><span class='strut'> </span></p> |
| 883 <p id='t79' class='stm run hide_run'><span class='key'>def</span> <span class='n
am'>_NormalizeObjectFilePath</span><span class='op'>(</span><span class='nam'>fi
le_path</span><span class='op'>)</span><span class='op'>:</span><span class='str
ut'> </span></p> |
| 884 <p id='t80' class='pln'> <span class='str'>"""Normalize the
file path to an c/c++ object file.</span><span class='strut'> </span></p> |
| 885 <p id='t81' class='pln'><span class='strut'> </span></p> |
| 886 <p id='t82' class='pln'><span class='str'> During compile, a/b/c/file.cc i
n TARGET will be compiled into object file</span><span class='strut'> </spa
n></p> |
| 887 <p id='t83' class='pln'><span class='str'> obj/a/b/c/TARGET.file.o, thus &
#39;obj/' and TARGET need to be removed from path.</span><span class='strut'
> </span></p> |
| 888 <p id='t84' class='pln'><span class='strut'> </span></p> |
| 889 <p id='t85' class='pln'><span class='str'> Args:</span><span class='strut'
> </span></p> |
| 890 <p id='t86' class='pln'><span class='str'> file_path (str): A path
to an object file (.o or .obj) after compile.</span><span class='strut'> </
span></p> |
| 891 <p id='t87' class='pln'><span class='str'> Returns:</span><span class='str
ut'> </span></p> |
| 892 <p id='t88' class='pln'><span class='str'> A normalized file path.<
/span><span class='strut'> </span></p> |
| 893 <p id='t89' class='pln'><span class='str'> """</span><span
class='strut'> </span></p> |
| 894 <p id='t90' class='stm run hide_run'> <span class='key'>if</span> <span cl
ass='nam'>file_path</span><span class='op'>.</span><span class='nam'>startswith<
/span><span class='op'>(</span><span class='str'>'obj/'</span><span clas
s='op'>)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 895 <p id='t91' class='stm run hide_run'> <span class='nam'>file_path</
span> <span class='op'>=</span> <span class='nam'>file_path</span><span class='o
p'>[</span><span class='num'>4</span><span class='op'>:</span><span class='op'>]
</span><span class='strut'> </span></p> |
| 896 <p id='t92' class='stm run hide_run'> <span class='nam'>file_dir</span> <s
pan class='op'>=</span> <span class='nam'>os</span><span class='op'>.</span><spa
n class='nam'>path</span><span class='op'>.</span><span class='nam'>dirname</spa
n><span class='op'>(</span><span class='nam'>file_path</span><span class='op'>)<
/span><span class='strut'> </span></p> |
| 897 <p id='t93' class='stm run hide_run'> <span class='nam'>file_name</span> <
span class='op'>=</span> <span class='nam'>os</span><span class='op'>.</span><sp
an class='nam'>path</span><span class='op'>.</span><span class='nam'>basename</s
pan><span class='op'>(</span><span class='nam'>file_path</span><span class='op'>
)</span><span class='strut'> </span></p> |
| 898 <p id='t94' class='stm run hide_run'> <span class='nam'>parts</span> <span
class='op'>=</span> <span class='nam'>file_name</span><span class='op'>.</span>
<span class='nam'>split</span><span class='op'>(</span><span class='str'>'.&
#39;</span><span class='op'>,</span> <span class='num'>1</span><span class='op'>
)</span><span class='strut'> </span></p> |
| 899 <p id='t95' class='stm run hide_run'> <span class='key'>if</span> <span cl
ass='nam'>len</span><span class='op'>(</span><span class='nam'>parts</span><span
class='op'>)</span> <span class='op'>==</span> <span class='num'>2</span> <span
class='key'>and</span> <span class='op'>(</span><span class='nam'>parts</span><
span class='op'>[</span><span class='num'>1</span><span class='op'>]</span><span
class='op'>.</span><span class='nam'>endswith</span><span class='op'>(</span><s
pan class='str'>'.o'</span><span class='op'>)</span> <span class='key'>o
r</span> <span class='nam'>parts</span><span class='op'>[</span><span class='num
'>1</span><span class='op'>]</span><span class='op'>.</span><span class='nam'>en
dswith</span><span class='op'>(</span><span class='str'>'.obj'</span><sp
an class='op'>)</span><span class='op'>)</span><span class='op'>:</span><span cl
ass='strut'> </span></p> |
| 900 <p id='t96' class='stm run hide_run'> <span class='nam'>object_file
</span> <span class='op'>=</span> <span class='nam'>parts</span><span class='op'
>[</span><span class='num'>1</span><span class='op'>]</span><span class='strut'>
</span></p> |
| 901 <p id='t97' class='stm run hide_run'> <span class='nam'>name</span>
<span class='op'>=</span> <span class='nam'>os</span><span class='op'>.</span><
span class='nam'>path</span><span class='op'>.</span><span class='nam'>splitext<
/span><span class='op'>(</span><span class='nam'>object_file</span><span class='
op'>)</span><span class='op'>[</span><span class='num'>0</span><span class='op'>
]</span><span class='strut'> </span></p> |
| 902 <p id='t98' class='pln'> <span class='com'># Special case for file.
cc.obj and similar cases.</span><span class='strut'> </span></p> |
| 903 <p id='t99' class='stm run hide_run'> <span class='key'>if</span> <
span class='nam'>name</span> <span class='key'>not</span> <span class='key'>in</
span> <span class='op'>[</span><span class='str'>'c'</span><span class='
op'>,</span> <span class='str'>'cc'</span><span class='op'>,</span> <spa
n class='str'>'cpp'</span><span class='op'>,</span> <span class='str'>&#
39;m'</span><span class='op'>,</span> <span class='str'>'mm'</span><
span class='op'>]</span><span class='op'>:</span><span class='strut'> </spa
n></p> |
| 904 <p id='t100' class='stm run hide_run'> <span class='nam'>fil
e_name</span> <span class='op'>=</span> <span class='nam'>parts</span><span clas
s='op'>[</span><span class='num'>1</span><span class='op'>]</span><span class='s
trut'> </span></p> |
| 905 <p id='t101' class='pln'><span class='strut'> </span></p> |
| 906 <p id='t102' class='stm run hide_run'> <span class='key'>if</span> <span c
lass='nam'>file_dir</span><span class='op'>:</span><span class='strut'> </s
pan></p> |
| 907 <p id='t103' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='str'>'%s/%s'</span> <span class='op'>%</span> <span cla
ss='op'>(</span><span class='nam'>file_dir</span><span class='op'>,</span> <span
class='nam'>file_name</span><span class='op'>)</span><span class='strut'>
</span></p> |
| 908 <p id='t104' class='pln'> <span class='key'>else</span><span class='op'>:<
/span><span class='strut'> </span></p> |
| 909 <p id='t105' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>file_name</span><span class='strut'> </span></p> |
| 910 <p id='t106' class='pln'><span class='strut'> </span></p> |
| 911 <p id='t107' class='pln'><span class='strut'> </span></p> |
| 912 <p id='t108' class='stm run hide_run'><span class='nam'>_COMMON_SUFFIXES</span>
<span class='op'>=</span> <span class='op'>[</span><span class='strut'> </s
pan></p> |
| 913 <p id='t109' class='pln'> <span class='str'>'impl'</span><s
pan class='op'>,</span><span class='strut'> </span></p> |
| 914 <p id='t110' class='pln'> <span class='str'>'browser_tests'
</span><span class='op'>,</span> <span class='str'>'browser_test'</span>
<span class='op'>,</span> <span class='str'>'browsertest'</span><span cl
ass='op'>,</span> <span class='str'>'browsertests'</span><span class='op
'>,</span><span class='strut'> </span></p> |
| 915 <p id='t111' class='pln'> <span class='str'>'unittests'</sp
an><span class='op'>,</span> <span class='str'>'unittest'</span><span cl
ass='op'>,</span> <span class='str'>'tests'</span><span class='op'>,</sp
an> <span class='str'>'test'</span><span class='op'>,</span><span class=
'strut'> </span></p> |
| 916 <p id='t112' class='pln'> <span class='str'>'gcc'</span><sp
an class='op'>,</span> <span class='str'>'msvc'</span><span class='op'>,
</span><span class='strut'> </span></p> |
| 917 <p id='t113' class='pln'> <span class='str'>'arm'</span><sp
an class='op'>,</span> <span class='str'>'arm64'</span><span class='op'>
,</span> <span class='str'>'mips'</span><span class='op'>,</span> <span
class='str'>'portable'</span><span class='op'>,</span> <span class='str'
>'x86'</span><span class='op'>,</span><span class='strut'> </span><
/p> |
| 918 <p id='t114' class='pln'> <span class='str'>'android'</span
><span class='op'>,</span> <span class='str'>'ios'</span><span class='op
'>,</span> <span class='str'>'linux'</span><span class='op'>,</span> <sp
an class='str'>'mac'</span><span class='op'>,</span> <span class='str'>&
#39;ozone'</span><span class='op'>,</span> <span class='str'>'posix'
</span><span class='op'>,</span> <span class='str'>'win'</span><span cla
ss='op'>,</span><span class='strut'> </span></p> |
| 919 <p id='t115' class='pln'> <span class='str'>'aura'</span><s
pan class='op'>,</span> <span class='str'>'x'</span><span class='op'>,</
span> <span class='str'>'x11'</span><span class='op'>,</span><span class
='strut'> </span></p> |
| 920 <p id='t116' class='pln'><span class='op'>]</span><span class='strut'> </sp
an></p> |
| 921 <p id='t117' class='pln'><span class='strut'> </span></p> |
| 922 <p id='t118' class='stm run hide_run'><span class='nam'>_COMMON_TEST_SUFFIXES</s
pan> <span class='op'>=</span> <span class='op'>[</span><span class='strut'>&nbs
p;</span></p> |
| 923 <p id='t119' class='pln'> <span class='str'>'browser_tests'
</span><span class='op'>,</span> <span class='str'>'browser_test'</span>
<span class='op'>,</span> <span class='str'>'browsertest'</span><span cl
ass='op'>,</span> <span class='str'>'browsertests'</span><span class='op
'>,</span><span class='strut'> </span></p> |
| 924 <p id='t120' class='pln'> <span class='str'>'unittests'</sp
an><span class='op'>,</span> <span class='str'>'unittest'</span><span cl
ass='op'>,</span> <span class='str'>'tests'</span><span class='op'>,</sp
an> <span class='str'>'test'</span><span class='op'>,</span><span class=
'strut'> </span></p> |
| 925 <p id='t121' class='pln'><span class='op'>]</span><span class='strut'> </sp
an></p> |
| 926 <p id='t122' class='pln'><span class='strut'> </span></p> |
| 927 <p id='t123' class='stm run hide_run'><span class='nam'>_COMMON_SUFFIX_PATTERNS<
/span> <span class='op'>=</span> <span class='op'>[</span><span class='strut'>&n
bsp;</span></p> |
| 928 <p id='t124' class='pln'> <span class='nam'>re</span><span class='o
p'>.</span><span class='nam'>compile</span><span class='op'>(</span><span class=
'str'>'.*(_%s)$'</span> <span class='op'>%</span> <span class='nam'>suff
ix</span><span class='op'>)</span> <span class='key'>for</span> <span class='nam
'>suffix</span> <span class='key'>in</span> <span class='nam'>_COMMON_SUFFIXES</
span><span class='strut'> </span></p> |
| 929 <p id='t125' class='pln'><span class='op'>]</span><span class='strut'> </sp
an></p> |
| 930 <p id='t126' class='pln'><span class='strut'> </span></p> |
| 931 <p id='t127' class='stm run hide_run'><span class='nam'>_COMMON_TEST_SUFFIX_PATT
ERNS</span> <span class='op'>=</span> <span class='op'>[</span><span class='stru
t'> </span></p> |
| 932 <p id='t128' class='pln'> <span class='nam'>re</span><span class='o
p'>.</span><span class='nam'>compile</span><span class='op'>(</span><span class=
'str'>'.*(_%s)$'</span> <span class='op'>%</span> <span class='nam'>suff
ix</span><span class='op'>)</span> <span class='key'>for</span> <span class='nam
'>suffix</span> <span class='key'>in</span> <span class='nam'>_COMMON_TEST_SUFFI
XES</span><span class='strut'> </span></p> |
| 933 <p id='t129' class='pln'><span class='op'>]</span><span class='strut'> </sp
an></p> |
| 934 <p id='t130' class='pln'><span class='strut'> </span></p> |
| 935 <p id='t131' class='stm run hide_run'><span class='nam'>_RELATED_FILETYPES</span
> <span class='op'>=</span> <span class='op'>[</span><span class='strut'> <
/span></p> |
| 936 <p id='t132' class='pln'> <span class='op'>[</span><span class='str
'>'h'</span><span class='op'>,</span> <span class='str'>'hh'</sp
an> <span class='str'>'c'</span><span class='op'>,</span> <span class='s
tr'>'cc'</span><span class='op'>,</span> <span class='str'>'cpp'
</span><span class='op'>,</span> <span class='str'>'m'</span><span class
='op'>,</span> <span class='str'>'mm'</span><span class='op'>,</span> <s
pan class='str'>'o'</span><span class='op'>,</span> <span class='str'>&#
39;obj'</span><span class='op'>]</span><span class='op'>,</span><span class=
'strut'> </span></p> |
| 937 <p id='t133' class='pln'> <span class='op'>[</span><span class='str
'>'py'</span><span class='op'>,</span> <span class='str'>'pyc'</
span><span class='op'>]</span><span class='op'>,</span><span class='strut'> 
;</span></p> |
| 938 <p id='t134' class='pln'> <span class='op'>[</span><span class='str
'>'gyp'</span><span class='op'>,</span> <span class='str'>'gypi'
</span><span class='op'>]</span><span class='strut'> </span></p> |
| 939 <p id='t135' class='pln'><span class='op'>]</span><span class='strut'> </sp
an></p> |
| 940 <p id='t136' class='pln'><span class='strut'> </span></p> |
| 941 <p id='t137' class='pln'><span class='strut'> </span></p> |
| 942 <p id='t138' class='stm run hide_run'><span class='key'>def</span> <span class='
nam'>_AreBothFilesTestRelated</span><span class='op'>(</span><span class='nam'>c
hanged_src_file_path</span><span class='op'>,</span> <span class='nam'>file_in_l
og_path</span><span class='op'>)</span><span class='op'>:</span><span class='str
ut'> </span></p> |
| 943 <p id='t139' class='pln'> <span class='str'>"""Tests if bot
h file names contain test-related suffixes."""</span><span class=
'strut'> </span></p> |
| 944 <p id='t140' class='stm run hide_run'> <span class='nam'>changed_file_name
</span> <span class='op'>=</span> <span class='nam'>os</span><span class='op'>.<
/span><span class='nam'>path</span><span class='op'>.</span><span class='nam'>sp
litext</span><span class='op'>(</span><span class='strut'> </span></p> |
| 945 <p id='t141' class='pln'> <span class='nam'>os</span><span c
lass='op'>.</span><span class='nam'>path</span><span class='op'>.</span><span cl
ass='nam'>basename</span><span class='op'>(</span><span class='nam'>changed_src_
file_path</span><span class='op'>)</span><span class='op'>)</span><span class='o
p'>[</span><span class='num'>0</span><span class='op'>]</span><span class='strut
'> </span></p> |
| 946 <p id='t142' class='stm run hide_run'> <span class='nam'>file_in_log_name<
/span> <span class='op'>=</span> <span class='nam'>os</span><span class='op'>.</
span><span class='nam'>path</span><span class='op'>.</span><span class='nam'>spl
itext</span><span class='op'>(</span><span class='nam'>os</span><span class='op'
>.</span><span class='nam'>path</span><span class='op'>.</span><span class='nam'
>basename</span><span class='op'>(</span><span class='nam'>file_in_log_path</spa
n><span class='op'>)</span><span class='op'>)</span><span class='op'>[</span><sp
an class='num'>0</span><span class='op'>]</span><span class='strut'> </span
></p> |
| 947 <p id='t143' class='pln'><span class='strut'> </span></p> |
| 948 <p id='t144' class='stm run hide_run'> <span class='nam'>is_changed_file_t
est_related</span> <span class='op'>=</span> <span class='nam'>False</span><span
class='strut'> </span></p> |
| 949 <p id='t145' class='stm run hide_run'> <span class='nam'>is_file_in_log_te
st_related</span> <span class='op'>=</span> <span class='nam'>False</span><span
class='strut'> </span></p> |
| 950 <p id='t146' class='pln'><span class='strut'> </span></p> |
| 951 <p id='t147' class='stm run hide_run'> <span class='key'>for</span> <span
class='nam'>test_suffix_patten</span> <span class='key'>in</span> <span class='n
am'>_COMMON_TEST_SUFFIX_PATTERNS</span><span class='op'>:</span><span class='str
ut'> </span></p> |
| 952 <p id='t148' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>test_suffix_patten</span><span class='op'>.</span><span class=
'nam'>match</span><span class='op'>(</span><span class='nam'>changed_file_name</
span><span class='op'>)</span><span class='op'>:</span><span class='strut'> 
;</span></p> |
| 953 <p id='t149' class='stm run hide_run'> <span class='nam'>is_
changed_file_test_related</span> <span class='op'>=</span> <span class='nam'>Tru
e</span><span class='strut'> </span></p> |
| 954 <p id='t150' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>test_suffix_patten</span><span class='op'>.</span><span class=
'nam'>match</span><span class='op'>(</span><span class='nam'>file_in_log_name</s
pan><span class='op'>)</span><span class='op'>:</span><span class='strut'>
</span></p> |
| 955 <p id='t151' class='stm run hide_run'> <span class='nam'>is_
file_in_log_test_related</span> <span class='op'>=</span> <span class='nam'>True
</span><span class='strut'> </span></p> |
| 956 <p id='t152' class='pln'><span class='strut'> </span></p> |
| 957 <p id='t153' class='stm run hide_run'> <span class='key'>return</span> <sp
an class='nam'>is_changed_file_test_related</span> <span class='key'>and</span>
<span class='nam'>is_file_in_log_test_related</span><span class='strut'> </
span></p> |
| 958 <p id='t154' class='pln'><span class='strut'> </span></p> |
| 959 <p id='t155' class='pln'><span class='strut'> </span></p> |
| 960 <p id='t156' class='stm run hide_run'><span class='key'>def</span> <span class='
nam'>_StripExtensionAndCommonSuffix</span><span class='op'>(</span><span class='
nam'>file_path</span><span class='op'>)</span><span class='op'>:</span><span cla
ss='strut'> </span></p> |
| 961 <p id='t157' class='pln'> <span class='str'>"""Strips exten
sion and common suffixes from file name to guess relation.</span><span class='st
rut'> </span></p> |
| 962 <p id='t158' class='pln'><span class='strut'> </span></p> |
| 963 <p id='t159' class='pln'><span class='str'> Examples:</span><span class='s
trut'> </span></p> |
| 964 <p id='t160' class='pln'><span class='str'> file_impl.cc, file_unit
test.cc, file_impl_mac.h -> file</span><span class='strut'> </span></p> |
| 965 <p id='t161' class='pln'><span class='str'> """</span><span
class='strut'> </span></p> |
| 966 <p id='t162' class='stm run hide_run'> <span class='nam'>file_dir</span> <
span class='op'>=</span> <span class='nam'>os</span><span class='op'>.</span><sp
an class='nam'>path</span><span class='op'>.</span><span class='nam'>dirname</sp
an><span class='op'>(</span><span class='nam'>file_path</span><span class='op'>)
</span><span class='strut'> </span></p> |
| 967 <p id='t163' class='stm run hide_run'> <span class='nam'>file_name</span>
<span class='op'>=</span> <span class='nam'>os</span><span class='op'>.</span><s
pan class='nam'>path</span><span class='op'>.</span><span class='nam'>splitext</
span><span class='op'>(</span><span class='nam'>os</span><span class='op'>.</spa
n><span class='nam'>path</span><span class='op'>.</span><span class='nam'>basena
me</span><span class='op'>(</span><span class='nam'>file_path</span><span class=
'op'>)</span><span class='op'>)</span><span class='op'>[</span><span class='num'
>0</span><span class='op'>]</span><span class='strut'> </span></p> |
| 968 <p id='t164' class='stm run hide_run'> <span class='key'>while</span> <spa
n class='nam'>True</span><span class='op'>:</span><span class='strut'> </sp
an></p> |
| 969 <p id='t165' class='stm run hide_run'> <span class='nam'>match</spa
n> <span class='op'>=</span> <span class='nam'>None</span><span class='strut'>&n
bsp;</span></p> |
| 970 <p id='t166' class='stm run hide_run'> <span class='key'>for</span>
<span class='nam'>suffix_patten</span> <span class='key'>in</span> <span class=
'nam'>_COMMON_SUFFIX_PATTERNS</span><span class='op'>:</span><span class='strut'
> </span></p> |
| 971 <p id='t167' class='stm run hide_run'> <span class='nam'>mat
ch</span> <span class='op'>=</span> <span class='nam'>suffix_patten</span><span
class='op'>.</span><span class='nam'>match</span><span class='op'>(</span><span
class='nam'>file_name</span><span class='op'>)</span><span class='strut'> <
/span></p> |
| 972 <p id='t168' class='stm run hide_run'> <span class='key'>if<
/span> <span class='nam'>match</span><span class='op'>:</span><span class='strut
'> </span></p> |
| 973 <p id='t169' class='stm run hide_run'> <span class='n
am'>file_name</span> <span class='op'>=</span> <span class='nam'>file_name</span
><span class='op'>[</span><span class='op'>:</span><span class='op'>-</span><spa
n class='nam'>len</span><span class='op'>(</span><span class='nam'>match</span><
span class='op'>.</span><span class='nam'>group</span><span class='op'>(</span><
span class='num'>1</span><span class='op'>)</span><span class='op'>)</span><span
class='op'>]</span><span class='strut'> </span></p> |
| 974 <p id='t170' class='stm run hide_run'> <span class='k
ey'>break</span><span class='strut'> </span></p> |
| 975 <p id='t171' class='pln'><span class='strut'> </span></p> |
| 976 <p id='t172' class='stm run hide_run'> <span class='key'>if</span>
<span class='key'>not</span> <span class='nam'>match</span><span class='op'>:</s
pan><span class='strut'> </span></p> |
| 977 <p id='t173' class='stm run hide_run'> <span class='key'>bre
ak</span><span class='strut'> </span></p> |
| 978 <p id='t174' class='pln'><span class='strut'> </span></p> |
| 979 <p id='t175' class='stm run hide_run'> <span class='key'>return</span> <sp
an class='nam'>os</span><span class='op'>.</span><span class='nam'>path</span><s
pan class='op'>.</span><span class='nam'>join</span><span class='op'>(</span><sp
an class='nam'>file_dir</span><span class='op'>,</span> <span class='nam'>file_n
ame</span><span class='op'>)</span><span class='op'>.</span><span class='nam'>re
place</span><span class='op'>(</span><span class='nam'>os</span><span class='op'
>.</span><span class='nam'>sep</span><span class='op'>,</span> <span class='str'
>'/'</span><span class='op'>)</span><span class='strut'> </span></p
> |
| 980 <p id='t176' class='pln'><span class='strut'> </span></p> |
| 981 <p id='t177' class='pln'><span class='strut'> </span></p> |
| 982 <p id='t178' class='stm run hide_run'><span class='key'>def</span> <span class='
nam'>_GetRelatedExtensionsList</span><span class='op'>(</span><span class='nam'>
extension</span><span class='op'>)</span><span class='op'>:</span><span class='s
trut'> </span></p> |
| 983 <p id='t179' class='stm run hide_run'> <span class='key'>for</span> <span
class='nam'>related_filetype_list</span> <span class='key'>in</span> <span class
='nam'>_RELATED_FILETYPES</span><span class='op'>:</span><span class='strut'>&nb
sp;</span></p> |
| 984 <p id='t180' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>extension</span> <span class='key'>in</span> <span class='nam'
>related_filetype_list</span><span class='op'>:</span><span class='strut'>
</span></p> |
| 985 <p id='t181' class='stm run hide_run'> <span class='key'>ret
urn</span> <span class='nam'>related_filetype_list</span><span class='strut'>&nb
sp;</span></p> |
| 986 <p id='t182' class='stm run hide_run'> <span class='key'>return</span> <sp
an class='op'>[</span><span class='op'>]</span><span class='strut'> </span>
</p> |
| 987 <p id='t183' class='pln'><span class='strut'> </span></p> |
| 988 <p id='t184' class='pln'><span class='strut'> </span></p> |
| 989 <p id='t185' class='stm run hide_run'><span class='key'>def</span> <span class='
nam'>_IsRelated</span><span class='op'>(</span><span class='nam'>changed_src_fil
e_path</span><span class='op'>,</span> <span class='nam'>file_path</span><span c
lass='op'>)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 990 <p id='t186' class='pln'> <span class='str'>"""Checks if tw
o files are related.</span><span class='strut'> </span></p> |
| 991 <p id='t187' class='pln'><span class='strut'> </span></p> |
| 992 <p id='t188' class='pln'><span class='str'> Example of related files:</spa
n><span class='strut'> </span></p> |
| 993 <p id='t189' class='pln'><span class='str'> 1. file.h <-> fil
e_impl.cc</span><span class='strut'> </span></p> |
| 994 <p id='t190' class='pln'><span class='str'> 2. file_impl.cc <-&g
t; file_unittest.cc</span><span class='strut'> </span></p> |
| 995 <p id='t191' class='pln'><span class='str'> 3. file_win.cc <->
; file_mac.cc</span><span class='strut'> </span></p> |
| 996 <p id='t192' class='pln'><span class='str'> 4. x.h <-> x.cc</
span><span class='strut'> </span></p> |
| 997 <p id='t193' class='pln'><span class='strut'> </span></p> |
| 998 <p id='t194' class='pln'><span class='str'> Example of not related files:<
/span><span class='strut'> </span></p> |
| 999 <p id='t195' class='pln'><span class='str'> 1. a_tests.py <->
a_browsertests.py</span><span class='strut'> </span></p> |
| 1000 <p id='t196' class='pln'><span class='str'> 2. a.isolate <->
a.cc</span><span class='strut'> </span></p> |
| 1001 <p id='t197' class='pln'><span class='str'> 3. a.py <-> a.cpp
</span><span class='strut'> </span></p> |
| 1002 <p id='t198' class='pln'><span class='str'> """</span><span
class='strut'> </span></p> |
| 1003 <p id='t199' class='stm run hide_run'> <span class='nam'>changed_src_file_
extension</span> <span class='op'>=</span> <span class='nam'>os</span><span clas
s='op'>.</span><span class='nam'>path</span><span class='op'>.</span><span class
='nam'>splitext</span><span class='op'>(</span><span class='nam'>changed_src_fil
e_path</span><span class='op'>)</span><span class='op'>[</span><span class='num'
>1</span><span class='op'>]</span><span class='op'>[</span><span class='num'>1</
span><span class='op'>:</span><span class='op'>]</span><span class='strut'> 
;</span></p> |
| 1004 <p id='t200' class='stm run hide_run'> <span class='nam'>file_path_extensi
on</span> <span class='op'>=</span> <span class='nam'>os</span><span class='op'>
.</span><span class='nam'>path</span><span class='op'>.</span><span class='nam'>
splitext</span><span class='op'>(</span><span class='nam'>file_path</span><span
class='op'>)</span><span class='op'>[</span><span class='num'>1</span><span clas
s='op'>]</span><span class='op'>[</span><span class='num'>1</span><span class='o
p'>:</span><span class='op'>]</span><span class='strut'> </span></p> |
| 1005 <p id='t201' class='pln'><span class='strut'> </span></p> |
| 1006 <p id='t202' class='stm run hide_run'> <span class='key'>if</span> <span c
lass='nam'>file_path_extension</span> <span class='key'>not</span> <span class='
key'>in</span> <span class='nam'>_GetRelatedExtensionsList</span><span class='op
'>(</span><span class='strut'> </span></p> |
| 1007 <p id='t203' class='pln'> <span class='nam'>changed_src_file
_extension</span><span class='op'>)</span><span class='op'>:</span><span class='
strut'> </span></p> |
| 1008 <p id='t204' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>False</span><span class='strut'> </span></p> |
| 1009 <p id='t205' class='pln'><span class='strut'> </span></p> |
| 1010 <p id='t206' class='stm run hide_run'> <span class='key'>if</span> <span c
lass='nam'>file_path</span><span class='op'>.</span><span class='nam'>endswith</
span><span class='op'>(</span><span class='str'>'.o'</span><span class='
op'>)</span> <span class='key'>or</span> <span class='nam'>file_path</span><span
class='op'>.</span><span class='nam'>endswith</span><span class='op'>(</span><s
pan class='str'>'.obj'</span><span class='op'>)</span><span class='op'>:
</span><span class='strut'> </span></p> |
| 1011 <p id='t207' class='stm run hide_run'> <span class='nam'>file_path<
/span> <span class='op'>=</span> <span class='nam'>_NormalizeObjectFilePath</spa
n><span class='op'>(</span><span class='nam'>file_path</span><span class='op'>)<
/span><span class='strut'> </span></p> |
| 1012 <p id='t208' class='pln'><span class='strut'> </span></p> |
| 1013 <p id='t209' class='stm run hide_run'> <span class='key'>if</span> <span c
lass='nam'>_AreBothFilesTestRelated</span><span class='op'>(</span><span class='
nam'>changed_src_file_path</span><span class='op'>,</span> <span class='nam'>fil
e_path</span><span class='op'>)</span><span class='op'>:</span><span class='stru
t'> </span></p> |
| 1014 <p id='t210' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>False</span><span class='strut'> </span></p> |
| 1015 <p id='t211' class='pln'><span class='strut'> </span></p> |
| 1016 <p id='t212' class='stm run hide_run'> <span class='key'>if</span> <span c
lass='nam'>_IsSameFile</span><span class='op'>(</span><span class='nam'>_StripEx
tensionAndCommonSuffix</span><span class='op'>(</span><span class='nam'>changed_
src_file_path</span><span class='op'>)</span><span class='op'>,</span><span clas
s='strut'> </span></p> |
| 1017 <p id='t213' class='pln'>
<span class='nam'>_StripExtensionAndCommonSuffix</span><span class='op'>(
</span><span class='nam'>file_path</span><span class='op'>)</span><span class='o
p'>)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 1018 <p id='t214' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>True</span><span class='strut'> </span></p> |
| 1019 <p id='t215' class='pln'><span class='strut'> </span></p> |
| 1020 <p id='t216' class='stm run hide_run'> <span class='key'>return</span> <sp
an class='nam'>False</span><span class='strut'> </span></p> |
| 1021 <p id='t217' class='pln'><span class='strut'> </span></p> |
| 1022 <p id='t218' class='pln'><span class='strut'> </span></p> |
| 1023 <p id='t219' class='stm run hide_run'><span class='key'>class</span> <span class
='nam'>_Justification</span><span class='op'>(</span><span class='nam'>object</s
pan><span class='op'>)</span><span class='op'>:</span><span class='strut'>
</span></p> |
| 1024 <p id='t220' class='pln'> <span class='str'>"""Justificatio
n for why a CL might be suspected for a build failure.</span><span class='strut'
> </span></p> |
| 1025 <p id='t221' class='pln'><span class='strut'> </span></p> |
| 1026 <p id='t222' class='pln'><span class='str'> A justification includes:</spa
n><span class='strut'> </span></p> |
| 1027 <p id='t223' class='pln'><span class='str'> 1. score:</span><span class='s
trut'> </span></p> |
| 1028 <p id='t224' class='pln'><span class='str'> 1) If a hint show
s that a CL is highly-suspected, the hint is given 5</span><span class='strut'>&
nbsp;</span></p> |
| 1029 <p id='t225' class='pln'><span class='str'> score poi
nts. Eg. a CL is highly suspected if it deleted a .cc file</span><span class='st
rut'> </span></p> |
| 1030 <p id='t226' class='pln'><span class='str'> appearing
in the compile failure.</span><span class='strut'> </span></p> |
| 1031 <p id='t227' class='pln'><span class='str'> 2) If a hint show
s that a CL is likely-suspected, the hint is given 1</span><span class='strut'>&
nbsp;</span></p> |
| 1032 <p id='t228' class='pln'><span class='str'> score poi
nt. Eg. a CL is just likely suspected if it only changed a</span><span class='st
rut'> </span></p> |
| 1033 <p id='t229' class='pln'><span class='str'> related f
ile (x_impl.cc vs. x.h) appearing in a failure.</span><span class='strut'>
</span></p> |
| 1034 <p id='t230' class='pln'><span class='str'> 2. hints: each hint is a strin
g describing a reason for suspecting a CL and</span><span class='strut'> </
span></p> |
| 1035 <p id='t231' class='pln'><span class='str'> could be shown to
the user (eg., "added x_impl.cc (and it was in log)").</span><span cl
ass='strut'> </span></p> |
| 1036 <p id='t232' class='pln'><span class='str'> """</span><span
class='strut'> </span></p> |
| 1037 <p id='t233' class='pln'><span class='strut'> </span></p> |
| 1038 <p id='t234' class='stm run hide_run'> <span class='key'>def</span> <span
class='nam'>__init__</span><span class='op'>(</span><span class='nam'>self</span
><span class='op'>)</span><span class='op'>:</span><span class='strut'> </s
pan></p> |
| 1039 <p id='t235' class='stm run hide_run'> <span class='nam'>self</span
><span class='op'>.</span><span class='nam'>_score</span> <span class='op'>=</sp
an> <span class='num'>0</span><span class='strut'> </span></p> |
| 1040 <p id='t236' class='stm run hide_run'> <span class='nam'>self</span
><span class='op'>.</span><span class='nam'>_hints</span> <span class='op'>=</sp
an> <span class='nam'>collections</span><span class='op'>.</span><span class='na
m'>defaultdict</span><span class='op'>(</span><span class='nam'>int</span><span
class='op'>)</span><span class='strut'> </span></p> |
| 1041 <p id='t237' class='pln'><span class='strut'> </span></p> |
| 1042 <p id='t238' class='stm run hide_run'> <span class='op'>@</span><span clas
s='nam'>property</span><span class='strut'> </span></p> |
| 1043 <p id='t239' class='pln'> <span class='key'>def</span> <span class='nam'>s
core</span><span class='op'>(</span><span class='nam'>self</span><span class='op
'>)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 1044 <p id='t240' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>self</span><span class='op'>.</span><span class='nam'>_sco
re</span><span class='strut'> </span></p> |
| 1045 <p id='t241' class='pln'><span class='strut'> </span></p> |
| 1046 <p id='t242' class='stm run hide_run'> <span class='key'>def</span> <span
class='nam'>AddFileChange</span><span class='op'>(</span><span class='nam'>self<
/span><span class='op'>,</span> <span class='nam'>change_action</span><span clas
s='op'>,</span> <span class='nam'>changed_src_file_path</span><span class='op'>,
</span><span class='strut'> </span></p> |
| 1047 <p id='t243' class='pln'>
<span class='nam'>file_path_in_log</span><span class='op'>,</span
> <span class='nam'>score</span><span class='op'>,</span> <span class='nam'>num_
file_name_occurrences</span><span class='op'>,</span><span class='strut'> <
/span></p> |
| 1048 <p id='t244' class='pln'>
<span class='nam'>changed_line_numbers</span><span class='op'>=</
span><span class='nam'>None</span><span class='op'>)</span><span class='op'>:</s
pan><span class='strut'> </span></p> |
| 1049 <p id='t245' class='pln'> <span class='str'>"""Adds
a suspected file change.</span><span class='strut'> </span></p> |
| 1050 <p id='t246' class='pln'><span class='strut'> </span></p> |
| 1051 <p id='t247' class='pln'><span class='str'> Args:</span><span class
='strut'> </span></p> |
| 1052 <p id='t248' class='pln'><span class='str'> change_action (s
tr): How file was changed: added, deleted, or modified.</span><span class='strut
'> </span></p> |
| 1053 <p id='t249' class='pln'><span class='str'> changed_src_file
_path (str): Changed file path in a CL.</span><span class='strut'> </span><
/p> |
| 1054 <p id='t250' class='pln'><span class='str'> file_path_in_log
(str): File path appearing in the failure log.</span><span class='strut'>
</span></p> |
| 1055 <p id='t251' class='pln'><span class='str'> score (int): Sco
re number for the file change.</span><span class='strut'> </span></p> |
| 1056 <p id='t252' class='pln'><span class='str'> num_file_name_oc
currences (int): Number of occurrences of this file base</span><span class='stru
t'> </span></p> |
| 1057 <p id='t253' class='pln'><span class='str'> na
me (not including directory part) in the commit.</span><span class='strut'> 
;</span></p> |
| 1058 <p id='t254' class='pln'><span class='str'> changed_line_num
bers (list): List of lines which are verified in both</span><span class='strut'>
</span></p> |
| 1059 <p id='t255' class='pln'><span class='str'> fa
ilure log and git blame.</span><span class='strut'> </span></p> |
| 1060 <p id='t256' class='pln'><span class='str'> """</spa
n><span class='strut'> </span></p> |
| 1061 <p id='t257' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>num_file_name_occurrences</span> <span class='op'>==</span> <s
pan class='num'>1</span><span class='op'>:</span><span class='strut'> </spa
n></p> |
| 1062 <p id='t258' class='stm run hide_run'> <span class='nam'>cha
nged_src_file_path</span> <span class='op'>=</span> <span class='nam'>os</span><
span class='op'>.</span><span class='nam'>path</span><span class='op'>.</span><s
pan class='nam'>basename</span><span class='op'>(</span><span class='nam'>change
d_src_file_path</span><span class='op'>)</span><span class='strut'> </span>
</p> |
| 1063 <p id='t259' class='stm run hide_run'> <span class='nam'>fil
e_path_in_log</span> <span class='op'>=</span> <span class='nam'>os</span><span
class='op'>.</span><span class='nam'>path</span><span class='op'>.</span><span c
lass='nam'>basename</span><span class='op'>(</span><span class='nam'>file_path_i
n_log</span><span class='op'>)</span><span class='strut'> </span></p> |
| 1064 <p id='t260' class='pln'><span class='strut'> </span></p> |
| 1065 <p id='t261' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>changed_src_file_path</span> <span class='op'>!=</span> <span
class='nam'>file_path_in_log</span><span class='op'>:</span><span class='strut'>
</span></p> |
| 1066 <p id='t262' class='stm run hide_run'> <span class='nam'>hin
t</span> <span class='op'>=</span> <span class='str'>'%s %s (%s was in log)&
#39;</span> <span class='op'>%</span> <span class='op'>(</span><span class='stru
t'> </span></p> |
| 1067 <p id='t263' class='pln'> <span class='nam'>ch
ange_action</span><span class='op'>,</span> <span class='nam'>changed_src_file_p
ath</span><span class='op'>,</span> <span class='nam'>file_path_in_log</span><sp
an class='op'>)</span><span class='strut'> </span></p> |
| 1068 <p id='t264' class='pln'> <span class='key'>else</span><span class=
'op'>:</span><span class='strut'> </span></p> |
| 1069 <p id='t265' class='stm run hide_run'> <span class='key'>if<
/span> <span class='nam'>changed_line_numbers</span><span class='op'>:</span><sp
an class='strut'> </span></p> |
| 1070 <p id='t266' class='stm run hide_run'> <span class='n
am'>hint</span> <span class='op'>=</span> <span class='str'>'%s %s[%s] (and
it was in log)'</span> <span class='op'>%</span> <span class='op'>(</span><s
pan class='strut'> </span></p> |
| 1071 <p id='t267' class='pln'> <span class='
nam'>change_action</span><span class='op'>,</span> <span class='nam'>changed_src
_file_path</span><span class='op'>,</span><span class='strut'> </span></p> |
| 1072 <p id='t268' class='pln'> <span class='
str'>', '</span><span class='op'>.</span><span class='nam'>join</span><s
pan class='op'>(</span><span class='nam'>map</span><span class='op'>(</span><spa
n class='nam'>str</span><span class='op'>,</span> <span class='nam'>changed_line
_numbers</span><span class='op'>)</span><span class='op'>)</span><span class='op
'>)</span><span class='strut'> </span></p> |
| 1073 <p id='t269' class='pln'> <span class='key'>else</span><span
class='op'>:</span><span class='strut'> </span></p> |
| 1074 <p id='t270' class='stm run hide_run'> <span class='n
am'>hint</span> <span class='op'>=</span> <span class='str'>'%s %s (and it w
as in log)'</span> <span class='op'>%</span> <span class='op'>(</span><span
class='strut'> </span></p> |
| 1075 <p id='t271' class='pln'> <span class='
nam'>change_action</span><span class='op'>,</span> <span class='nam'>changed_src
_file_path</span><span class='op'>)</span><span class='strut'> </span></p> |
| 1076 <p id='t272' class='pln'><span class='strut'> </span></p> |
| 1077 <p id='t273' class='stm run hide_run'> <span class='nam'>self</span
><span class='op'>.</span><span class='nam'>_hints</span><span class='op'>[</spa
n><span class='nam'>hint</span><span class='op'>]</span> <span class='op'>+=</sp
an> <span class='nam'>score</span><span class='strut'> </span></p> |
| 1078 <p id='t274' class='stm run hide_run'> <span class='nam'>self</span
><span class='op'>.</span><span class='nam'>_score</span> <span class='op'>+=</s
pan> <span class='nam'>score</span><span class='strut'> </span></p> |
| 1079 <p id='t275' class='pln'><span class='strut'> </span></p> |
| 1080 <p id='t276' class='stm run hide_run'> <span class='key'>def</span> <span
class='nam'>AddDEPSRoll</span><span class='op'>(</span><span class='nam'>self</s
pan><span class='op'>,</span> <span class='nam'>change_action</span><span class=
'op'>,</span> <span class='nam'>dep_path</span><span class='op'>,</span> <span c
lass='nam'>dep_repo_url</span><span class='op'>,</span> <span class='nam'>dep_ne
w_revision</span><span class='op'>,</span><span class='strut'> </span></p> |
| 1081 <p id='t277' class='pln'>
<span class='nam'>dep_old_revision</span><span class='op'>,</span> <span
class='nam'>file_path_in_log</span><span class='op'>,</span> <span class='nam'>
score</span><span class='op'>,</span><span class='strut'> </span></p> |
| 1082 <p id='t278' class='pln'>
<span class='nam'>changed_line_numbers</span><span class='op'>,</span> <
span class='nam'>roll_file_change_type</span><span class='op'>)</span><span clas
s='op'>:</span><span class='strut'> </span></p> |
| 1083 <p id='t279' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>dep_old_revision</span> <span class='key'>is</span> <span clas
s='key'>not</span> <span class='nam'>None</span> <span class='key'>and</span> <s
pan class='nam'>dep_new_revision</span> <span class='key'>is</span> <span class=
'key'>not</span> <span class='nam'>None</span><span class='op'>:</span><span cla
ss='strut'> </span></p> |
| 1084 <p id='t280' class='stm run hide_run'> <span class='nam'>url
_to_changes_in_roll</span> <span class='op'>=</span> <span class='str'>'%s/+
log/%s..%s?pretty=fuller'</span> <span class='op'>%</span> <span class='op'>
(</span><span class='strut'> </span></p> |
| 1085 <p id='t281' class='pln'> <span class='nam'>de
p_repo_url</span><span class='op'>,</span> <span class='nam'>dep_old_revision</s
pan><span class='op'>[</span><span class='op'>:</span><span class='num'>12</span
><span class='op'>]</span><span class='op'>,</span> <span class='nam'>dep_new_re
vision</span><span class='op'>[</span><span class='op'>:</span><span class='num'
>12</span><span class='op'>]</span><span class='op'>)</span><span class='strut'>
</span></p> |
| 1086 <p id='t282' class='stm run hide_run'> <span class='key'>elif</span
> <span class='nam'>dep_new_revision</span> <span class='key'>is</span> <span cl
ass='key'>not</span> <span class='nam'>None</span><span class='op'>:</span><span
class='strut'> </span></p> |
| 1087 <p id='t283' class='stm run hide_run'> <span class='nam'>url
_to_changes_in_roll</span> <span class='op'>=</span> <span class='str'>'%s/+
log/%s'</span> <span class='op'>%</span> <span class='op'>(</span><span clas
s='nam'>dep_repo_url</span><span class='op'>,</span> <span class='nam'>dep_new_r
evision</span><span class='op'>)</span><span class='strut'> </span></p> |
| 1088 <p id='t284' class='pln'> <span class='key'>else</span><span class=
'op'>:</span> <span class='com'># New revision is None. (Old revision shou
ld not be None.)</span><span class='strut'> </span></p> |
| 1089 <p id='t285' class='stm run hide_run'> <span class='nam'>url
_to_changes_in_roll</span> <span class='op'>=</span> <span class='str'>'%s/+
log/%s'</span> <span class='op'>%</span> <span class='op'>(</span><span clas
s='nam'>dep_repo_url</span><span class='op'>,</span> <span class='nam'>dep_old_r
evision</span><span class='op'>)</span><span class='strut'> </span></p> |
| 1090 <p id='t286' class='pln'><span class='strut'> </span></p> |
| 1091 <p id='t287' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>roll_file_change_type</span> <span class='op'>==</span> <span
class='nam'>ChangeType</span><span class='op'>.</span><span class='nam'>ADD</spa
n><span class='op'>:</span><span class='strut'> </span></p> |
| 1092 <p id='t288' class='stm run hide_run'> <span class='nam'>hin
t</span> <span class='op'>=</span> <span class='op'>(</span><span class='str'>&#
39;%s dependency %s with changes in %s '</span><span class='strut'> </s
pan></p> |
| 1093 <p id='t289' class='pln'> <span
class='str'>'(and %s(added) was in log)'</span> <span class='op'>%</span
> <span class='op'>(</span><span class='strut'> </span></p> |
| 1094 <p id='t290' class='pln'>
<span class='nam'>change_action</span><span class='op'>,</span> <span cl
ass='nam'>dep_path</span><span class='op'>,</span> <span class='nam'>url_to_chan
ges_in_roll</span><span class='op'>,</span><span class='strut'> </span></p> |
| 1095 <p id='t291' class='pln'>
<span class='nam'>file_path_in_log</span><span class='op'>)</span><span
class='op'>)</span><span class='strut'> </span></p> |
| 1096 <p id='t292' class='stm run hide_run'> <span class='key'>elif</span
> <span class='nam'>roll_file_change_type</span> <span class='op'>==</span> <spa
n class='nam'>ChangeType</span><span class='op'>.</span><span class='nam'>DELETE
</span><span class='op'>:</span><span class='strut'> </span></p> |
| 1097 <p id='t293' class='stm run hide_run'> <span class='nam'>hin
t</span> <span class='op'>=</span> <span class='op'>(</span><span class='str'>&#
39;%s dependency %s with changes in %s '</span><span class='strut'> </s
pan></p> |
| 1098 <p id='t294' class='pln'> <span
class='str'>'(and %s(deleted) was in log)'</span> <span class='op'>%</sp
an> <span class='op'>(</span><span class='strut'> </span></p> |
| 1099 <p id='t295' class='pln'>
<span class='nam'>change_action</span><span class='op'>,</span> <span cl
ass='nam'>dep_path</span><span class='op'>,</span> <span class='nam'>url_to_chan
ges_in_roll</span><span class='op'>,</span><span class='strut'> </span></p> |
| 1100 <p id='t296' class='pln'>
<span class='nam'>file_path_in_log</span><span class='op'>)</span><span
class='op'>)</span><span class='strut'> </span></p> |
| 1101 <p id='t297' class='stm run hide_run'> <span class='key'>elif</span
> <span class='nam'>changed_line_numbers</span><span class='op'>:</span><span cl
ass='strut'> </span></p> |
| 1102 <p id='t298' class='stm run hide_run'> <span class='nam'>hin
t</span> <span class='op'>=</span> <span class='op'>(</span><span class='str'>&#
39;%s dependency %s with changes in %s (and %s[%s] was in log)'</span> <span
class='op'>%</span> <span class='op'>(</span><span class='strut'> </span><
/p> |
| 1103 <p id='t299' class='pln'> <span class='nam'>ch
ange_action</span><span class='op'>,</span> <span class='nam'>dep_path</span><sp
an class='op'>,</span> <span class='nam'>url_to_changes_in_roll</span><span clas
s='op'>,</span> <span class='nam'>file_path_in_log</span><span class='op'>,</spa
n><span class='strut'> </span></p> |
| 1104 <p id='t300' class='pln'> <span class='str'>&#
39;, '</span><span class='op'>.</span><span class='nam'>join</span><span cla
ss='op'>(</span><span class='nam'>map</span><span class='op'>(</span><span class
='nam'>str</span><span class='op'>,</span> <span class='nam'>changed_line_number
s</span><span class='op'>)</span><span class='op'>)</span><span class='op'>)</sp
an><span class='op'>)</span><span class='strut'> </span></p> |
| 1105 <p id='t301' class='pln'> <span class='key'>else</span><span class=
'op'>:</span><span class='strut'> </span></p> |
| 1106 <p id='t302' class='stm run hide_run'> <span class='nam'>hin
t</span> <span class='op'>=</span> <span class='op'>(</span><span class='str'>&#
39;%s dependency %s with changes in %s (and %s was in log)'</span> <span cla
ss='op'>%</span> <span class='op'>(</span><span class='strut'> </span></p> |
| 1107 <p id='t303' class='pln'> <span class='nam'>ch
ange_action</span><span class='op'>,</span> <span class='nam'>dep_path</span><sp
an class='op'>,</span> <span class='nam'>url_to_changes_in_roll</span><span clas
s='op'>,</span> <span class='nam'>file_path_in_log</span><span class='op'>)</spa
n><span class='op'>)</span><span class='strut'> </span></p> |
| 1108 <p id='t304' class='pln'><span class='strut'> </span></p> |
| 1109 <p id='t305' class='stm run hide_run'> <span class='nam'>self</span
><span class='op'>.</span><span class='nam'>_hints</span><span class='op'>[</spa
n><span class='nam'>hint</span><span class='op'>]</span> <span class='op'>=</spa
n> <span class='nam'>score</span><span class='strut'> </span></p> |
| 1110 <p id='t306' class='stm run hide_run'> <span class='nam'>self</span
><span class='op'>.</span><span class='nam'>_score</span> <span class='op'>+=</s
pan> <span class='nam'>score</span><span class='strut'> </span></p> |
| 1111 <p id='t307' class='pln'><span class='strut'> </span></p> |
| 1112 <p id='t308' class='stm run hide_run'> <span class='key'>def</span> <span
class='nam'>ToDict</span><span class='op'>(</span><span class='nam'>self</span><
span class='op'>)</span><span class='op'>:</span><span class='strut'> </spa
n></p> |
| 1113 <p id='t309' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='op'>{</span><span class='strut'> </span></p> |
| 1114 <p id='t310' class='pln'> <span class='str'>'scor
e'</span><span class='op'>:</span> <span class='nam'>self</span><span class=
'op'>.</span><span class='nam'>_score</span><span class='op'>,</span><span class
='strut'> </span></p> |
| 1115 <p id='t311' class='pln'> <span class='str'>'hint
s'</span><span class='op'>:</span> <span class='nam'>self</span><span class=
'op'>.</span><span class='nam'>_hints</span><span class='op'>,</span><span class
='strut'> </span></p> |
| 1116 <p id='t312' class='pln'> <span class='op'>}</span><span class='str
ut'> </span></p> |
| 1117 <p id='t313' class='pln'><span class='strut'> </span></p> |
| 1118 <p id='t314' class='pln'><span class='strut'> </span></p> |
| 1119 <p id='t315' class='stm run hide_run'><span class='key'>def</span> <span class='
nam'>_CheckFile</span><span class='op'>(</span><span class='nam'>touched_file</s
pan><span class='op'>,</span><span class='strut'> </span></p> |
| 1120 <p id='t316' class='pln'>
<span class='nam'>file_path_in_log</span><span class='op'>,</span><span class='s
trut'> </span></p> |
| 1121 <p id='t317' class='pln'>
<span class='nam'>justification</span><span class='op'>,</span><span class='stru
t'> </span></p> |
| 1122 <p id='t318' class='pln'>
<span class='nam'>file_name_occurrences</span><span class='op'>,</span><span cla
ss='strut'> </span></p> |
| 1123 <p id='t319' class='pln'>
<span class='nam'>line_numbers</span><span class='op'>,</span><span class='strut
'> </span></p> |
| 1124 <p id='t320' class='pln'>
<span class='nam'>repo_info</span><span class='op'>,</span><span class='strut'>&
nbsp;</span></p> |
| 1125 <p id='t321' class='pln'>
<span class='nam'>suspected_revision</span><span class='op'>)</span><span class=
'op'>:</span><span class='strut'> </span></p> |
| 1126 <p id='t322' class='pln'> <span class='str'>"""Checks if th
e given files are related and updates the justification.</span><span class='stru
t'> </span></p> |
| 1127 <p id='t323' class='pln'><span class='strut'> </span></p> |
| 1128 <p id='t324' class='pln'><span class='str'> Args:</span><span class='strut
'> </span></p> |
| 1129 <p id='t325' class='pln'><span class='str'> touched_file (dict): Th
e touched file found in the change log.</span><span class='strut'> </span><
/p> |
| 1130 <p id='t326' class='pln'><span class='str'> file_path_in_log (str):
File path appearing in the failure log.</span><span class='strut'> </span>
</p> |
| 1131 <p id='t327' class='pln'><span class='str'> justification (_Justifi
cation): An instance of _Justification.</span><span class='strut'> </span><
/p> |
| 1132 <p id='t328' class='pln'><span class='str'> file_name_occurrences (
dict): A dict mapping file names to</span><span class='strut'> </span></p> |
| 1133 <p id='t329' class='pln'><span class='str'> number of
occurrences.</span><span class='strut'> </span></p> |
| 1134 <p id='t330' class='pln'><span class='str'> line_numbers(list): A l
ist of line numbers of 'file_path_in_log' which</span><span class='strut
'> </span></p> |
| 1135 <p id='t331' class='pln'><span class='str'> appears i
n failure log.</span><span class='strut'> </span></p> |
| 1136 <p id='t332' class='pln'><span class='str'> repo_info (dict): The r
epo_url and revision for the build cycle.</span><span class='strut'> </span
></p> |
| 1137 <p id='t333' class='pln'><span class='str'> suspected_revision (str
): Git hash revision of the suspected CL.</span><span class='strut'> </span
></p> |
| 1138 <p id='t334' class='pln'><span class='str'> """</span><span
class='strut'> </span></p> |
| 1139 <p id='t335' class='stm run hide_run'> <span class='nam'>change_type</span
> <span class='op'>=</span> <span class='nam'>touched_file</span><span class='op
'>[</span><span class='str'>'change_type'</span><span class='op'>]</span
><span class='strut'> </span></p> |
| 1140 <p id='t336' class='pln'><span class='strut'> </span></p> |
| 1141 <p id='t337' class='stm run hide_run'> <span class='key'>if</span> <span c
lass='nam'>change_type</span> <span class='op'>==</span> <span class='nam'>Chang
eType</span><span class='op'>.</span><span class='nam'>MODIFY</span><span class=
'op'>:</span><span class='strut'> </span></p> |
| 1142 <p id='t338' class='stm run hide_run'> <span class='nam'>changed_sr
c_file_path</span> <span class='op'>=</span> <span class='nam'>touched_file</spa
n><span class='op'>[</span><span class='str'>'new_path'</span><span clas
s='op'>]</span><span class='strut'> </span></p> |
| 1143 <p id='t339' class='stm run hide_run'> <span class='nam'>file_name<
/span> <span class='op'>=</span> <span class='nam'>os</span><span class='op'>.</
span><span class='nam'>path</span><span class='op'>.</span><span class='nam'>bas
ename</span><span class='op'>(</span><span class='nam'>changed_src_file_path</sp
an><span class='op'>)</span><span class='strut'> </span></p> |
| 1144 <p id='t340' class='pln'><span class='strut'> </span></p> |
| 1145 <p id='t341' class='stm run hide_run'> <span class='nam'>score</spa
n> <span class='op'>=</span> <span class='num'>0</span><span class='strut'> 
;</span></p> |
| 1146 <p id='t342' class='stm run hide_run'> <span class='nam'>changed_li
ne_numbers</span> <span class='op'>=</span> <span class='nam'>None</span><span c
lass='strut'> </span></p> |
| 1147 <p id='t343' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>_IsSameFile</span><span class='op'>(</span><span class='nam'>c
hanged_src_file_path</span><span class='op'>,</span> <span class='nam'>file_path
_in_log</span><span class='op'>)</span><span class='op'>:</span><span class='str
ut'> </span></p> |
| 1148 <p id='t344' class='stm run hide_run'> <span class='nam'>cha
nged_line_numbers</span> <span class='op'>=</span> <span class='nam'>_GetChanged
LinesForChromiumRepo</span><span class='op'>(</span><span class='strut'> </
span></p> |
| 1149 <p id='t345' class='pln'> <span class='nam'>re
po_info</span><span class='op'>,</span> <span class='nam'>touched_file</span><sp
an class='op'>,</span> <span class='nam'>line_numbers</span><span class='op'>,</
span> <span class='nam'>suspected_revision</span><span class='op'>)</span><span
class='strut'> </span></p> |
| 1150 <p id='t346' class='stm run hide_run'> <span class='key'>if<
/span> <span class='nam'>changed_line_numbers</span><span class='op'>:</span><sp
an class='strut'> </span></p> |
| 1151 <p id='t347' class='stm run hide_run'> <span class='n
am'>score</span> <span class='op'>=</span> <span class='num'>4</span><span class
='strut'> </span></p> |
| 1152 <p id='t348' class='pln'> <span class='key'>else</span><span
class='op'>:</span><span class='strut'> </span></p> |
| 1153 <p id='t349' class='stm run hide_run'> <span class='n
am'>score</span> <span class='op'>=</span> <span class='num'>2</span><span class
='strut'> </span></p> |
| 1154 <p id='t350' class='stm run hide_run'> <span class='key'>elif</span
> <span class='nam'>_IsRelated</span><span class='op'>(</span><span class='nam'>
changed_src_file_path</span><span class='op'>,</span> <span class='nam'>file_pat
h_in_log</span><span class='op'>)</span><span class='op'>:</span><span class='st
rut'> </span></p> |
| 1155 <p id='t351' class='stm run hide_run'> <span class='nam'>sco
re</span> <span class='op'>=</span> <span class='num'>1</span><span class='strut
'> </span></p> |
| 1156 <p id='t352' class='pln'><span class='strut'> </span></p> |
| 1157 <p id='t353' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>score</span><span class='op'>:</span><span class='strut'> 
;</span></p> |
| 1158 <p id='t354' class='stm run hide_run'> <span class='nam'>jus
tification</span><span class='op'>.</span><span class='nam'>AddFileChange</span>
<span class='op'>(</span><span class='str'>'modified'</span><span class=
'op'>,</span><span class='strut'> </span></p> |
| 1159 <p id='t355' class='pln'>
<span class='nam
'>changed_src_file_path</span><span class='op'>,</span><span class='strut'> 
;</span></p> |
| 1160 <p id='t356' class='pln'>
<span class='nam
'>file_path_in_log</span><span class='op'>,</span><span class='strut'> </sp
an></p> |
| 1161 <p id='t357' class='pln'>
<span class='nam
'>score</span><span class='op'>,</span><span class='strut'> </span></p> |
| 1162 <p id='t358' class='pln'>
<span class='nam
'>file_name_occurrences</span><span class='op'>.</span><span class='nam'>get</sp
an><span class='op'>(</span><span class='nam'>file_name</span><span class='op'>)
</span><span class='op'>,</span><span class='strut'> </span></p> |
| 1163 <p id='t359' class='pln'>
<span class='nam
'>changed_line_numbers</span><span class='op'>)</span><span class='strut'>
</span></p> |
| 1164 <p id='t360' class='pln'><span class='strut'> </span></p> |
| 1165 <p id='t361' class='stm run hide_run'> <span class='key'>if</span> <span c
lass='nam'>change_type</span> <span class='key'>in</span> <span class='op'>(</sp
an><span class='nam'>ChangeType</span><span class='op'>.</span><span class='nam'
>ADD</span><span class='op'>,</span> <span class='nam'>ChangeType</span><span cl
ass='op'>.</span><span class='nam'>COPY</span><span class='op'>,</span> <span cl
ass='nam'>ChangeType</span><span class='op'>.</span><span class='nam'>RENAME</sp
an><span class='op'>)</span><span class='op'>:</span><span class='strut'> <
/span></p> |
| 1166 <p id='t362' class='stm run hide_run'> <span class='nam'>changed_sr
c_file_path</span> <span class='op'>=</span> <span class='nam'>touched_file</spa
n><span class='op'>[</span><span class='str'>'new_path'</span><span clas
s='op'>]</span><span class='strut'> </span></p> |
| 1167 <p id='t363' class='stm run hide_run'> <span class='nam'>file_name<
/span> <span class='op'>=</span> <span class='nam'>os</span><span class='op'>.</
span><span class='nam'>path</span><span class='op'>.</span><span class='nam'>bas
ename</span><span class='op'>(</span><span class='nam'>changed_src_file_path</sp
an><span class='op'>)</span><span class='strut'> </span></p> |
| 1168 <p id='t364' class='pln'><span class='strut'> </span></p> |
| 1169 <p id='t365' class='stm run hide_run'> <span class='nam'>score</spa
n> <span class='op'>=</span> <span class='num'>0</span><span class='strut'> 
;</span></p> |
| 1170 <p id='t366' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>_IsSameFile</span><span class='op'>(</span><span class='nam'>c
hanged_src_file_path</span><span class='op'>,</span> <span class='nam'>file_path
_in_log</span><span class='op'>)</span><span class='op'>:</span><span class='str
ut'> </span></p> |
| 1171 <p id='t367' class='stm run hide_run'> <span class='nam'>sco
re</span> <span class='op'>=</span> <span class='num'>5</span><span class='strut
'> </span></p> |
| 1172 <p id='t368' class='stm run hide_run'> <span class='key'>elif</span
> <span class='nam'>_IsRelated</span><span class='op'>(</span><span class='nam'>
changed_src_file_path</span><span class='op'>,</span> <span class='nam'>file_pat
h_in_log</span><span class='op'>)</span><span class='op'>:</span><span class='st
rut'> </span></p> |
| 1173 <p id='t369' class='stm run hide_run'> <span class='nam'>sco
re</span> <span class='op'>=</span> <span class='num'>1</span><span class='strut
'> </span></p> |
| 1174 <p id='t370' class='pln'><span class='strut'> </span></p> |
| 1175 <p id='t371' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>score</span><span class='op'>:</span><span class='strut'> 
;</span></p> |
| 1176 <p id='t372' class='stm run hide_run'> <span class='nam'>jus
tification</span><span class='op'>.</span><span class='nam'>AddFileChange</span>
<span class='op'>(</span><span class='str'>'added'</span><span class='op
'>,</span><span class='strut'> </span></p> |
| 1177 <p id='t373' class='pln'>
<span class='nam
'>changed_src_file_path</span><span class='op'>,</span><span class='strut'> 
;</span></p> |
| 1178 <p id='t374' class='pln'>
<span class='nam
'>file_path_in_log</span><span class='op'>,</span><span class='strut'> </sp
an></p> |
| 1179 <p id='t375' class='pln'>
<span class='nam
'>score</span><span class='op'>,</span><span class='strut'> </span></p> |
| 1180 <p id='t376' class='pln'>
<span class='nam
'>file_name_occurrences</span><span class='op'>.</span><span class='nam'>get</sp
an><span class='op'>(</span><span class='nam'>file_name</span><span class='op'>)
</span><span class='op'>)</span><span class='strut'> </span></p> |
| 1181 <p id='t377' class='pln'><span class='strut'> </span></p> |
| 1182 <p id='t378' class='stm run hide_run'> <span class='key'>if</span> <span c
lass='nam'>change_type</span> <span class='key'>in</span> <span class='op'>(</sp
an><span class='nam'>ChangeType</span><span class='op'>.</span><span class='nam'
>DELETE</span><span class='op'>,</span> <span class='nam'>ChangeType</span><span
class='op'>.</span><span class='nam'>RENAME</span><span class='op'>)</span><spa
n class='op'>:</span><span class='strut'> </span></p> |
| 1183 <p id='t379' class='stm run hide_run'> <span class='nam'>changed_sr
c_file_path</span> <span class='op'>=</span> <span class='nam'>touched_file</spa
n><span class='op'>[</span><span class='str'>'old_path'</span><span clas
s='op'>]</span><span class='strut'> </span></p> |
| 1184 <p id='t380' class='stm run hide_run'> <span class='nam'>file_name<
/span> <span class='op'>=</span> <span class='nam'>os</span><span class='op'>.</
span><span class='nam'>path</span><span class='op'>.</span><span class='nam'>bas
ename</span><span class='op'>(</span><span class='nam'>changed_src_file_path</sp
an><span class='op'>)</span><span class='strut'> </span></p> |
| 1185 <p id='t381' class='pln'><span class='strut'> </span></p> |
| 1186 <p id='t382' class='stm run hide_run'> <span class='nam'>score</spa
n> <span class='op'>=</span> <span class='num'>0</span><span class='strut'> 
;</span></p> |
| 1187 <p id='t383' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>_IsSameFile</span><span class='op'>(</span><span class='nam'>c
hanged_src_file_path</span><span class='op'>,</span> <span class='nam'>file_path
_in_log</span><span class='op'>)</span><span class='op'>:</span><span class='str
ut'> </span></p> |
| 1188 <p id='t384' class='stm run hide_run'> <span class='nam'>sco
re</span> <span class='op'>=</span> <span class='num'>5</span><span class='strut
'> </span></p> |
| 1189 <p id='t385' class='stm run hide_run'> <span class='key'>elif</span
> <span class='nam'>_IsRelated</span><span class='op'>(</span><span class='nam'>
changed_src_file_path</span><span class='op'>,</span> <span class='nam'>file_pat
h_in_log</span><span class='op'>)</span><span class='op'>:</span><span class='st
rut'> </span></p> |
| 1190 <p id='t386' class='stm run hide_run'> <span class='nam'>sco
re</span> <span class='op'>=</span> <span class='num'>1</span><span class='strut
'> </span></p> |
| 1191 <p id='t387' class='pln'><span class='strut'> </span></p> |
| 1192 <p id='t388' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>score</span><span class='op'>:</span><span class='strut'> 
;</span></p> |
| 1193 <p id='t389' class='stm run hide_run'> <span class='nam'>jus
tification</span><span class='op'>.</span><span class='nam'>AddFileChange</span>
<span class='op'>(</span><span class='str'>'deleted'</span><span class='
op'>,</span><span class='strut'> </span></p> |
| 1194 <p id='t390' class='pln'>
<span class='nam
'>changed_src_file_path</span><span class='op'>,</span><span class='strut'> 
;</span></p> |
| 1195 <p id='t391' class='pln'>
<span class='nam
'>file_path_in_log</span><span class='op'>,</span><span class='strut'> </sp
an></p> |
| 1196 <p id='t392' class='pln'>
<span class='nam
'>score</span><span class='op'>,</span><span class='strut'> </span></p> |
| 1197 <p id='t393' class='pln'>
<span class='nam
'>file_name_occurrences</span><span class='op'>.</span><span class='nam'>get</sp
an><span class='op'>(</span><span class='nam'>file_name</span><span class='op'>)
</span><span class='op'>)</span><span class='strut'> </span></p> |
| 1198 <p id='t394' class='pln'><span class='strut'> </span></p> |
| 1199 <p id='t395' class='pln'><span class='strut'> </span></p> |
| 1200 <p id='t396' class='stm run hide_run'><span class='key'>def</span> <span class='
nam'>_StripChromiumRootDirectory</span><span class='op'>(</span><span class='nam
'>file_path</span><span class='op'>)</span><span class='op'>:</span><span class=
'strut'> </span></p> |
| 1201 <p id='t397' class='pln'> <span class='com'># Strip src/ from file path to
make all files relative to the chromium root</span><span class='strut'> </
span></p> |
| 1202 <p id='t398' class='pln'> <span class='com'># directory.</span><span class
='strut'> </span></p> |
| 1203 <p id='t399' class='stm run hide_run'> <span class='key'>if</span> <span c
lass='nam'>file_path</span><span class='op'>.</span><span class='nam'>startswith
</span><span class='op'>(</span><span class='str'>'src/'</span><span cla
ss='op'>)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 1204 <p id='t400' class='stm run hide_run'> <span class='nam'>file_path<
/span> <span class='op'>=</span> <span class='nam'>file_path</span><span class='
op'>[</span><span class='num'>4</span><span class='op'>:</span><span class='op'>
]</span><span class='strut'> </span></p> |
| 1205 <p id='t401' class='stm run hide_run'> <span class='key'>return</span> <sp
an class='nam'>file_path</span><span class='strut'> </span></p> |
| 1206 <p id='t402' class='pln'><span class='strut'> </span></p> |
| 1207 <p id='t403' class='pln'><span class='strut'> </span></p> |
| 1208 <p id='t404' class='stm run hide_run'><span class='key'>def</span> <span class='
nam'>_GetChangeTypeAndCulpritCommit</span><span class='op'>(</span><span class='
nam'>file_path_in_log</span><span class='op'>,</span> <span class='nam'>roll_rep
o</span><span class='op'>,</span><span class='strut'> </span></p> |
| 1209 <p id='t405' class='pln'>
<span clas
s='nam'>commits_between_revisions</span><span class='op'>)</span><span class='op
'>:</span><span class='strut'> </span></p> |
| 1210 <p id='t406' class='pln'> <span class='str'>"""Determines t
he first commit that touches a file within a revision range.</span><span class='
strut'> </span></p> |
| 1211 <p id='t407' class='pln'><span class='strut'> </span></p> |
| 1212 <p id='t408' class='pln'><span class='str'> Args:</span><span class='strut
'> </span></p> |
| 1213 <p id='t409' class='pln'><span class='str'> file_path_in_log: The f
ile to search each commit's change logs for.</span><span class='strut'> 
;</span></p> |
| 1214 <p id='t410' class='pln'><span class='str'> roll_repo: A git reposi
tory object to make requests to git for changes logs.</span><span class='strut'>
</span></p> |
| 1215 <p id='t411' class='pln'><span class='str'> commits_between_revisio
ns: A list of revisions to request change logs.</span><span class='strut'>
</span></p> |
| 1216 <p id='t412' class='pln'><span class='strut'> </span></p> |
| 1217 <p id='t413' class='pln'><span class='str'> Returns:</span><span class='st
rut'> </span></p> |
| 1218 <p id='t414' class='pln'><span class='str'> The modification type m
ade to file_path_in_log if found.</span><span class='strut'> </span></p> |
| 1219 <p id='t415' class='pln'><span class='str'> The corresponding commi
t that touched file_path_in_log if found.</span><span class='strut'> </span
></p> |
| 1220 <p id='t416' class='pln'><span class='str'> """</span><span
class='strut'> </span></p> |
| 1221 <p id='t417' class='stm run hide_run'> <span class='key'>for</span> <span
class='nam'>commit</span> <span class='key'>in</span> <span class='nam'>commits_
between_revisions</span><span class='op'>:</span><span class='strut'> </spa
n></p> |
| 1222 <p id='t418' class='pln'> <span class='com'># Use the change log fo
r each commit to determine if and how</span><span class='strut'> </span></p
> |
| 1223 <p id='t419' class='pln'> <span class='com'># file_path_in_log log
was modified.</span><span class='strut'> </span></p> |
| 1224 <p id='t420' class='stm run hide_run'> <span class='nam'>change_log
</span> <span class='op'>=</span> <span class='nam'>roll_repo</span><span class=
'op'>.</span><span class='nam'>GetChangeLog</span><span class='op'>(</span><span
class='nam'>commit</span><span class='op'>)</span><span class='strut'> </s
pan></p> |
| 1225 <p id='t421' class='stm run hide_run'> <span class='key'>for</span>
<span class='nam'>file_change_info</span> <span class='key'>in</span> <span cla
ss='nam'>change_log</span><span class='op'>.</span><span class='nam'>touched_fil
es</span><span class='op'>:</span><span class='strut'> </span></p> |
| 1226 <p id='t422' class='stm run hide_run'> <span class='key'>if<
/span> <span class='nam'>file_change_info</span><span class='op'>.</span><span c
lass='nam'>change_type</span> <span class='key'>in</span> <span class='op'>(</sp
an><span class='nam'>ChangeType</span><span class='op'>.</span><span class='nam'
>DELETE</span><span class='op'>,</span> <span class='nam'>ChangeType</span><span
class='op'>.</span><span class='nam'>RENAME</span><span class='op'>)</span><spa
n class='op'>:</span><span class='strut'> </span></p> |
| 1227 <p id='t423' class='stm run hide_run'> <span class='n
am'>changed_src_file_path</span> <span class='op'>=</span> <span class='nam'>fil
e_change_info</span><span class='op'>.</span><span class='nam'>old_path</span><s
pan class='strut'> </span></p> |
| 1228 <p id='t424' class='pln'> <span class='key'>else</span><span
class='op'>:</span><span class='strut'> </span></p> |
| 1229 <p id='t425' class='stm run hide_run'> <span class='n
am'>changed_src_file_path</span> <span class='op'>=</span> <span class='nam'>fil
e_change_info</span><span class='op'>.</span><span class='nam'>new_path</span><s
pan class='strut'> </span></p> |
| 1230 <p id='t426' class='pln'><span class='strut'> </span></p> |
| 1231 <p id='t427' class='stm run hide_run'> <span class='key'>if<
/span> <span class='nam'>_IsSameFile</span><span class='op'>(</span><span class=
'nam'>changed_src_file_path</span><span class='op'>,</span> <span class='nam'>fi
le_path_in_log</span><span class='op'>)</span><span class='op'>:</span><span cla
ss='strut'> </span></p> |
| 1232 <p id='t428' class='pln'> <span class='com'># Found t
he file and the commit that modified it.</span><span class='strut'> </span>
</p> |
| 1233 <p id='t429' class='pln'> <span class='com'># TODO(li
jeffrey): It is possible multiple commits modified the file.</span><span class='
strut'> </span></p> |
| 1234 <p id='t430' class='stm run hide_run'> <span class='k
ey'>return</span> <span class='nam'>file_change_info</span><span class='op'>.</s
pan><span class='nam'>change_type</span><span class='op'>,</span> <span class='n
am'>commit</span><span class='strut'> </span></p> |
| 1235 <p id='t431' class='pln'><span class='strut'> </span></p> |
| 1236 <p id='t432' class='pln'> <span class='com'># TODO(lijeffrey
): It is possible _IsRelated(changed_src_file_path,</span><span class='strut'>&n
bsp;</span></p> |
| 1237 <p id='t433' class='pln'> <span class='com'># file_path_in_l
og) may also provide useful information, but how is not</span><span class='strut
'> </span></p> |
| 1238 <p id='t434' class='pln'> <span class='com'># yet determined
.</span><span class='strut'> </span></p> |
| 1239 <p id='t435' class='pln'><span class='strut'> </span></p> |
| 1240 <p id='t436' class='stm run hide_run'> <span class='key'>return</span> <sp
an class='nam'>None</span><span class='op'>,</span> <span class='nam'>None</span
><span class='strut'> </span></p> |
| 1241 <p id='t437' class='pln'><span class='strut'> </span></p> |
| 1242 <p id='t438' class='pln'><span class='strut'> </span></p> |
| 1243 <p id='t439' class='stm run hide_run'><span class='key'>def</span> <span class='
nam'>_GetChangedLinesForDependencyRepo</span><span class='op'>(</span><span clas
s='nam'>roll</span><span class='op'>,</span> <span class='nam'>file_path_in_log<
/span><span class='op'>,</span> <span class='nam'>line_numbers</span><span class
='op'>)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 1244 <p id='t440' class='pln'> <span class='str'>"""Gets changed
line numbers for file in failure log.</span><span class='strut'> </span></
p> |
| 1245 <p id='t441' class='pln'><span class='strut'> </span></p> |
| 1246 <p id='t442' class='pln'><span class='str'> Tests if the same lines
mentioned in failure log are changed within</span><span class='strut'> </s
pan></p> |
| 1247 <p id='t443' class='pln'><span class='str'> the DEPS roll, if so, r
eturn those line numbers.</span><span class='strut'> </span></p> |
| 1248 <p id='t444' class='pln'><span class='str'> """</span><span
class='strut'> </span></p> |
| 1249 <p id='t445' class='stm run hide_run'> <span class='nam'>roll_repo</span>
<span class='op'>=</span> <span class='nam'>GitRepository</span><span class='op'
>(</span><span class='nam'>roll</span><span class='op'>[</span><span class='str'
>'repo_url'</span><span class='op'>]</span><span class='op'>,</span> <sp
an class='nam'>HttpClient</span><span class='op'>(</span><span class='op'>)</spa
n><span class='op'>)</span><span class='strut'> </span></p> |
| 1250 <p id='t446' class='stm run hide_run'> <span class='nam'>old_revision</spa
n> <span class='op'>=</span> <span class='nam'>roll</span><span class='op'>[</sp
an><span class='str'>'old_revision'</span><span class='op'>]</span><span
class='strut'> </span></p> |
| 1251 <p id='t447' class='stm run hide_run'> <span class='nam'>new_revision</spa
n> <span class='op'>=</span> <span class='nam'>roll</span><span class='op'>[</sp
an><span class='str'>'new_revision'</span><span class='op'>]</span><span
class='strut'> </span></p> |
| 1252 <p id='t448' class='stm run hide_run'> <span class='nam'>old_change_log</s
pan> <span class='op'>=</span> <span class='nam'>roll_repo</span><span class='op
'>.</span><span class='nam'>GetChangeLog</span><span class='op'>(</span><span cl
ass='nam'>old_revision</span><span class='op'>)</span><span class='strut'>
</span></p> |
| 1253 <p id='t449' class='stm run hide_run'> <span class='nam'>old_rev_author_ti
me</span> <span class='op'>=</span> <span class='nam'>old_change_log</span><span
class='op'>.</span><span class='nam'>author_time</span><span class='strut'>&nbs
p;</span></p> |
| 1254 <p id='t450' class='stm run hide_run'> <span class='nam'>new_change_log</s
pan> <span class='op'>=</span> <span class='nam'>roll_repo</span><span class='op
'>.</span><span class='nam'>GetChangeLog</span><span class='op'>(</span><span cl
ass='nam'>new_revision</span><span class='op'>)</span><span class='strut'>
</span></p> |
| 1255 <p id='t451' class='stm run hide_run'> <span class='nam'>new_rev_author_ti
me</span> <span class='op'>=</span> <span class='nam'>new_change_log</span><span
class='op'>.</span><span class='nam'>author_time</span><span class='strut'>&nbs
p;</span></p> |
| 1256 <p id='t452' class='pln'><span class='strut'> </span></p> |
| 1257 <p id='t453' class='stm run hide_run'> <span class='nam'>file_change_type<
/span> <span class='op'>=</span> <span class='nam'>None</span><span class='strut
'> </span></p> |
| 1258 <p id='t454' class='stm run hide_run'> <span class='nam'>changed_line_numb
ers</span> <span class='op'>=</span> <span class='op'>[</span><span class='op'>]
</span><span class='strut'> </span></p> |
| 1259 <p id='t455' class='pln'><span class='strut'> </span></p> |
| 1260 <p id='t456' class='stm run hide_run'> <span class='key'>if</span> <span c
lass='nam'>old_rev_author_time</span> <span class='op'>>=</span> <span class=
'nam'>new_rev_author_time</span><span class='op'>:</span><span class='strut'>&nb
sp;</span></p> |
| 1261 <p id='t457' class='pln'> <span class='com'># If the DEPS roll is d
owngrade, bail out.</span><span class='strut'> </span></p> |
| 1262 <p id='t458' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>file_change_type</span><span class='op'>,</span> <span cla
ss='nam'>changed_line_numbers</span><span class='strut'> </span></p> |
| 1263 <p id='t459' class='pln'><span class='strut'> </span></p> |
| 1264 <p id='t460' class='stm run hide_run'> <span class='nam'>commits_in_roll</
span> <span class='op'>=</span> <span class='nam'>roll_repo</span><span class='o
p'>.</span><span class='nam'>GetCommitsBetweenRevisions</span><span class='op'>(
</span><span class='strut'> </span></p> |
| 1265 <p id='t461' class='pln'> <span class='nam'>old_revision</sp
an><span class='op'>,</span> <span class='nam'>new_revision</span><span class='o
p'>)</span><span class='strut'> </span></p> |
| 1266 <p id='t462' class='pln'><span class='strut'> </span></p> |
| 1267 <p id='t463' class='stm run hide_run'> <span class='nam'>file_change_type<
/span><span class='op'>,</span> <span class='nam'>culprit_commit</span> <span cl
ass='op'>=</span> <span class='nam'>_GetChangeTypeAndCulpritCommit</span><span c
lass='op'>(</span><span class='strut'> </span></p> |
| 1268 <p id='t464' class='pln'> <span class='nam'>file_path_in_log
</span><span class='op'>,</span> <span class='nam'>roll_repo</span><span class='
op'>,</span> <span class='nam'>commits_in_roll</span><span class='op'>)</span><s
pan class='strut'> </span></p> |
| 1269 <p id='t465' class='pln'><span class='strut'> </span></p> |
| 1270 <p id='t466' class='stm run hide_run'> <span class='key'>if</span> <span c
lass='nam'>culprit_commit</span> <span class='key'>is</span> <span class='nam'>N
one</span><span class='op'>:</span><span class='strut'> </span></p> |
| 1271 <p id='t467' class='pln'> <span class='com'># Bail out if no commit
s touched the file in the log.</span><span class='strut'> </span></p> |
| 1272 <p id='t468' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>file_change_type</span><span class='op'>,</span> <span cla
ss='nam'>changed_line_numbers</span><span class='strut'> </span></p> |
| 1273 <p id='t469' class='pln'><span class='strut'> </span></p> |
| 1274 <p id='t470' class='stm run hide_run'> <span class='key'>if</span> <span c
lass='nam'>file_change_type</span> <span class='op'>==</span> <span class='nam'>
ChangeType</span><span class='op'>.</span><span class='nam'>MODIFY</span><span c
lass='op'>:</span><span class='strut'> </span></p> |
| 1275 <p id='t471' class='pln'> <span class='com'># If the file was modif
ied, use the blame information to determine which</span><span class='strut'>&nbs
p;</span></p> |
| 1276 <p id='t472' class='pln'> <span class='com'># lines were changed.</
span><span class='strut'> </span></p> |
| 1277 <p id='t473' class='stm run hide_run'> <span class='nam'>blame</spa
n> <span class='op'>=</span> <span class='nam'>roll_repo</span><span class='op'>
.</span><span class='nam'>GetBlame</span><span class='op'>(</span><span class='n
am'>file_path_in_log</span><span class='op'>,</span> <span class='nam'>culprit_c
ommit</span><span class='op'>)</span><span class='strut'> </span></p> |
| 1278 <p id='t474' class='pln'><span class='strut'> </span></p> |
| 1279 <p id='t475' class='stm run hide_run'> <span class='key'>if</span>
<span class='key'>not</span> <span class='nam'>blame</span><span class='op'>:</s
pan><span class='strut'> </span></p> |
| 1280 <p id='t476' class='stm run hide_run'> <span class='key'>ret
urn</span> <span class='nam'>file_change_type</span><span class='op'>,</span> <s
pan class='nam'>changed_line_numbers</span><span class='strut'> </span></p> |
| 1281 <p id='t477' class='pln'><span class='strut'> </span></p> |
| 1282 <p id='t478' class='stm run hide_run'> <span class='key'>for</span>
<span class='nam'>region</span> <span class='key'>in</span> <span class='nam'>b
lame</span><span class='op'>:</span><span class='strut'> </span></p> |
| 1283 <p id='t479' class='stm run hide_run'> <span class='key'>if<
/span> <span class='nam'>line_numbers</span><span class='op'>:</span><span class
='strut'> </span></p> |
| 1284 <p id='t480' class='stm run hide_run'> <span class='k
ey'>for</span> <span class='nam'>line_number</span> <span class='key'>in</span>
<span class='nam'>line_numbers</span><span class='op'>:</span><span class='strut
'> </span></p> |
| 1285 <p id='t481' class='stm run hide_run'> <span c
lass='key'>if</span> <span class='op'>(</span><span class='nam'>line_number</spa
n> <span class='op'>>=</span> <span class='nam'>region</span><span class='op'
>.</span><span class='nam'>start</span> <span class='key'>and</span><span class=
'strut'> </span></p> |
| 1286 <p id='t482' class='pln'> <span
class='nam'>line_number</span> <span class='op'><=</span> <span class='nam'>r
egion</span><span class='op'>.</span><span class='nam'>start</span> <span class=
'op'>+</span> <span class='nam'>region</span><span class='op'>.</span><span clas
s='nam'>count</span> <span class='op'>-</span> <span class='num'>1</span> <span
class='key'>and</span><span class='strut'> </span></p> |
| 1287 <p id='t483' class='pln'> <span
class='nam'>region</span><span class='op'>.</span><span class='nam'>revision</sp
an> <span class='key'>in</span> <span class='nam'>commits_in_roll</span><span cl
ass='op'>)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 1288 <p id='t484' class='pln'> <span class='
com'># One line which appears in the failure log is changed within</span><span c
lass='strut'> </span></p> |
| 1289 <p id='t485' class='pln'> <span class='
com'># the DEPS roll.</span><span class='strut'> </span></p> |
| 1290 <p id='t486' class='stm run hide_run'>
<span class='nam'>changed_line_numbers</span><span class='op'>.</span><span clas
s='nam'>append</span><span class='op'>(</span><span class='nam'>line_number</spa
n><span class='op'>)</span><span class='strut'> </span></p> |
| 1291 <p id='t487' class='pln'><span class='strut'> </span></p> |
| 1292 <p id='t488' class='stm run hide_run'> <span class='key'>return</span> <sp
an class='nam'>file_change_type</span><span class='op'>,</span> <span class='nam
'>changed_line_numbers</span><span class='strut'> </span></p> |
| 1293 <p id='t489' class='pln'><span class='strut'> </span></p> |
| 1294 <p id='t490' class='pln'><span class='strut'> </span></p> |
| 1295 <p id='t491' class='stm run hide_run'><span class='key'>def</span> <span class='
nam'>_CheckFileInDependencyRolls</span><span class='op'>(</span><span class='nam
'>file_path_in_log</span><span class='op'>,</span> <span class='nam'>rolls</span
><span class='op'>,</span> <span class='nam'>justification</span><span class='op
'>,</span><span class='strut'> </span></p> |
| 1296 <p id='t492' class='pln'>
<span class='nam'>line_
numbers</span><span class='op'>=</span><span class='nam'>None</span><span class=
'op'>)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 1297 <p id='t493' class='pln'> <span class='str'>"""Checks if th
e file is in a dependency roll and updates the justification.</span><span class=
'strut'> </span></p> |
| 1298 <p id='t494' class='pln'><span class='strut'> </span></p> |
| 1299 <p id='t495' class='pln'><span class='str'> Args:</span><span class='strut
'> </span></p> |
| 1300 <p id='t496' class='pln'><span class='str'> file_path_in_log (str):
File path appearing in the failure log.</span><span class='strut'> </span>
</p> |
| 1301 <p id='t497' class='pln'><span class='str'> rolls (list): A list of
dependency rolls made by a single commit/CL, each</span><span class='strut'>&nb
sp;</span></p> |
| 1302 <p id='t498' class='pln'><span class='str'> roll is a
dict in the following form:</span><span class='strut'> </span></p> |
| 1303 <p id='t499' class='pln'><span class='str'> {</span><
span class='strut'> </span></p> |
| 1304 <p id='t500' class='pln'><span class='str'> &#
39;path': 'path/to/dependency',</span><span class='strut'> </sp
an></p> |
| 1305 <p id='t501' class='pln'><span class='str'> &#
39;repo_url': 'https://url/to/dep.git',</span><span class='strut'>&n
bsp;</span></p> |
| 1306 <p id='t502' class='pln'><span class='str'> &#
39;old_revision': 'git_hash1',</span><span class='strut'> </spa
n></p> |
| 1307 <p id='t503' class='pln'><span class='str'> &#
39;new_revision': 'git_hash2'</span><span class='strut'> </span
></p> |
| 1308 <p id='t504' class='pln'><span class='str'> }</span><
span class='strut'> </span></p> |
| 1309 <p id='t505' class='pln'><span class='str'> justification (_Justifi
cation): An instance of _Justification.</span><span class='strut'> </span><
/p> |
| 1310 <p id='t506' class='pln'><span class='str'> line_numbers (list): Li
st of line_numbers mentioned in the failure log.</span><span class='strut'> 
;</span></p> |
| 1311 <p id='t507' class='pln'><span class='str'> """</span><span
class='strut'> </span></p> |
| 1312 <p id='t508' class='stm run hide_run'> <span class='key'>for</span> <span
class='nam'>roll</span> <span class='key'>in</span> <span class='nam'>rolls</spa
n><span class='op'>:</span><span class='strut'> </span></p> |
| 1313 <p id='t509' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>roll</span><span class='op'>[</span><span class='str'>'pat
h'</span><span class='op'>]</span> <span class='op'>==</span> <span class='s
tr'>'src/v8/'</span><span class='op'>:</span><span class='strut'> <
/span></p> |
| 1314 <p id='t510' class='pln'> <span class='com'># Cannot compare
author time for v8 roll, author time for CLs during the</span><span class='stru
t'> </span></p> |
| 1315 <p id='t511' class='pln'> <span class='com'># roll may be ea
rlier than the author time of old revision.</span><span class='strut'> </sp
an></p> |
| 1316 <p id='t512' class='pln'> <span class='com'># TODO: Figure o
ut the rolling mechanism of v8 to add logic for checking</span><span class='stru
t'> </span></p> |
| 1317 <p id='t513' class='pln'> <span class='com'># this repo.</sp
an><span class='strut'> </span></p> |
| 1318 <p id='t514' class='stm run hide_run'> <span class='key'>con
tinue</span><span class='strut'> </span></p> |
| 1319 <p id='t515' class='pln'><span class='strut'> </span></p> |
| 1320 <p id='t516' class='stm run hide_run'> <span class='nam'>change_act
ion</span> <span class='op'>=</span> <span class='nam'>None</span><span class='s
trut'> </span></p> |
| 1321 <p id='t517' class='stm run hide_run'> <span class='nam'>dep_path</
span> <span class='op'>=</span> <span class='nam'>_StripChromiumRootDirectory</s
pan><span class='op'>(</span><span class='nam'>roll</span><span class='op'>[</sp
an><span class='str'>'path'</span><span class='op'>]</span><span class='
op'>)</span><span class='strut'> </span></p> |
| 1322 <p id='t518' class='stm run hide_run'> <span class='key'>if</span>
<span class='key'>not</span> <span class='nam'>file_path_in_log</span><span clas
s='op'>.</span><span class='nam'>startswith</span><span class='op'>(</span><span
class='nam'>dep_path</span><span class='op'>)</span><span class='op'>:</span><s
pan class='strut'> </span></p> |
| 1323 <p id='t519' class='stm run hide_run'> <span class='key'>con
tinue</span><span class='strut'> </span></p> |
| 1324 <p id='t520' class='pln'><span class='strut'> </span></p> |
| 1325 <p id='t521' class='stm run hide_run'> <span class='nam'>changed_li
nes</span> <span class='op'>=</span> <span class='op'>[</span><span class='op'>]
</span><span class='strut'> </span></p> |
| 1326 <p id='t522' class='stm run hide_run'> <span class='nam'>roll_file_
change_type</span> <span class='op'>=</span> <span class='nam'>None</span><span
class='strut'> </span></p> |
| 1327 <p id='t523' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>roll</span><span class='op'>[</span><span class='str'>'old
_revision'</span><span class='op'>]</span> <span class='key'>and</span> <spa
n class='nam'>roll</span><span class='op'>[</span><span class='str'>'new_rev
ision'</span><span class='op'>]</span><span class='op'>:</span><span class='
strut'> </span></p> |
| 1328 <p id='t524' class='stm run hide_run'> <span class='nam'>rol
l_file_change_type</span><span class='op'>,</span> <span class='nam'>changed_lin
es</span> <span class='op'>=</span> <span class='nam'>_GetChangedLinesForDepende
ncyRepo</span><span class='op'>(</span><span class='strut'> </span></p> |
| 1329 <p id='t525' class='pln'> <span class='nam'>ro
ll</span><span class='op'>,</span> <span class='nam'>file_path_in_log</span><spa
n class='op'>[</span><span class='nam'>len</span><span class='op'>(</span><span
class='nam'>dep_path</span><span class='op'>)</span><span class='op'>:</span><sp
an class='op'>]</span><span class='op'>,</span> <span class='nam'>line_numbers</
span><span class='op'>)</span><span class='strut'> </span></p> |
| 1330 <p id='t526' class='pln'><span class='strut'> </span></p> |
| 1331 <p id='t527' class='stm run hide_run'> <span class='key'>if<
/span> <span class='key'>not</span> <span class='nam'>roll_file_change_type</spa
n><span class='op'>:</span><span class='strut'> </span></p> |
| 1332 <p id='t528' class='stm run hide_run'> <span class='k
ey'>continue</span><span class='strut'> </span></p> |
| 1333 <p id='t529' class='pln'><span class='strut'> </span></p> |
| 1334 <p id='t530' class='stm run hide_run'> <span class='nam'>cha
nge_action</span> <span class='op'>=</span> <span class='str'>'rolled'</
span><span class='strut'> </span></p> |
| 1335 <p id='t531' class='stm run hide_run'> <span class='key'>if<
/span> <span class='op'>(</span><span class='nam'>roll_file_change_type</span> <
span class='op'>==</span> <span class='nam'>ChangeType</span><span class='op'>.<
/span><span class='nam'>ADD</span> <span class='key'>or</span><span class='strut
'> </span></p> |
| 1336 <p id='t532' class='pln'> <span class='nam'>ro
ll_file_change_type</span> <span class='op'>==</span> <span class='nam'>ChangeTy
pe</span><span class='op'>.</span><span class='nam'>DELETE</span><span class='op
'>)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 1337 <p id='t533' class='pln'> <span class='com'># File wa
s either added or deleted.</span><span class='strut'> </span></p> |
| 1338 <p id='t534' class='stm run hide_run'> <span class='n
am'>score</span> <span class='op'>=</span> <span class='num'>5</span><span class
='strut'> </span></p> |
| 1339 <p id='t535' class='stm run hide_run'> <span class='key'>eli
f</span> <span class='key'>not</span> <span class='nam'>changed_lines</span><spa
n class='op'>:</span><span class='strut'> </span></p> |
| 1340 <p id='t536' class='pln'> <span class='com'># File is
changed, but not the same line.</span><span class='strut'> </span></p> |
| 1341 <p id='t537' class='stm run hide_run'> <span class='n
am'>score</span> <span class='op'>=</span> <span class='num'>1</span><span class
='strut'> </span></p> |
| 1342 <p id='t538' class='pln'> <span class='key'>else</span><span
class='op'>:</span><span class='strut'> </span></p> |
| 1343 <p id='t539' class='pln'> <span class='com'># The lin
es which appear in the failure log are changed.</span><span class='strut'>
</span></p> |
| 1344 <p id='t540' class='stm run hide_run'> <span class='n
am'>score</span> <span class='op'>=</span> <span class='num'>4</span><span class
='strut'> </span></p> |
| 1345 <p id='t541' class='stm run hide_run'> <span class='key'>elif</span
> <span class='nam'>roll</span><span class='op'>[</span><span class='str'>'n
ew_revision'</span><span class='op'>]</span><span class='op'>:</span><span c
lass='strut'> </span></p> |
| 1346 <p id='t542' class='stm run hide_run'> <span class='nam'>cha
nge_action</span> <span class='op'>=</span> <span class='str'>'added'</s
pan><span class='strut'> </span></p> |
| 1347 <p id='t543' class='stm run hide_run'> <span class='nam'>sco
re</span> <span class='op'>=</span> <span class='num'>5</span><span class='strut
'> </span></p> |
| 1348 <p id='t544' class='pln'> <span class='key'>else</span><span class=
'op'>:</span> <span class='com'># New revision is None. (Old revision shou
ld not be None.)</span><span class='strut'> </span></p> |
| 1349 <p id='t545' class='stm run hide_run'> <span class='nam'>cha
nge_action</span> <span class='op'>=</span> <span class='str'>'deleted'<
/span><span class='strut'> </span></p> |
| 1350 <p id='t546' class='stm run hide_run'> <span class='nam'>sco
re</span> <span class='op'>=</span> <span class='num'>5</span><span class='strut
'> </span></p> |
| 1351 <p id='t547' class='pln'><span class='strut'> </span></p> |
| 1352 <p id='t548' class='stm run hide_run'> <span class='nam'>justificat
ion</span><span class='op'>.</span><span class='nam'>AddDEPSRoll</span><span cla
ss='op'>(</span><span class='strut'> </span></p> |
| 1353 <p id='t549' class='pln'> <span class='nam'>change_ac
tion</span><span class='op'>,</span> <span class='nam'>dep_path</span><span clas
s='op'>,</span> <span class='nam'>roll</span><span class='op'>[</span><span clas
s='str'>'repo_url'</span><span class='op'>]</span><span class='op'>,</sp
an> <span class='nam'>roll</span><span class='op'>[</span><span class='str'>'
;new_revision'</span><span class='op'>]</span><span class='op'>,</span><span
class='strut'> </span></p> |
| 1354 <p id='t550' class='pln'> <span class='nam'>roll</spa
n><span class='op'>[</span><span class='str'>'old_revision'</span><span
class='op'>]</span><span class='op'>,</span> <span class='nam'>file_path_in_log<
/span><span class='op'>[</span><span class='nam'>len</span><span class='op'>(</s
pan><span class='nam'>dep_path</span><span class='op'>)</span><span class='op'>:
</span><span class='op'>]</span><span class='op'>,</span> <span class='nam'>scor
e</span><span class='op'>,</span><span class='strut'> </span></p> |
| 1355 <p id='t551' class='pln'> <span class='nam'>changed_l
ines</span><span class='op'>,</span> <span class='nam'>roll_file_change_type</sp
an><span class='op'>)</span><span class='strut'> </span></p> |
| 1356 <p id='t552' class='pln'><span class='strut'> </span></p> |
| 1357 <p id='t553' class='pln'><span class='strut'> </span></p> |
| 1358 <p id='t554' class='stm run hide_run'><span class='key'>def</span> <span class='
nam'>_CheckFiles</span><span class='op'>(</span><span class='nam'>failure_signal
</span><span class='op'>,</span> <span class='nam'>change_log</span><span class=
'op'>,</span> <span class='nam'>deps_info</span><span class='op'>)</span><span c
lass='op'>:</span><span class='strut'> </span></p> |
| 1359 <p id='t555' class='pln'> <span class='str'>"""Checks files
in the given change log of a CL against the failure signal.</span><span class='
strut'> </span></p> |
| 1360 <p id='t556' class='pln'><span class='strut'> </span></p> |
| 1361 <p id='t557' class='pln'><span class='str'> Args:</span><span class='strut
'> </span></p> |
| 1362 <p id='t558' class='pln'><span class='str'> failure_signal (Failure
Signal): The failure signal of a failed step or test.</span><span class='strut'>
</span></p> |
| 1363 <p id='t559' class='pln'><span class='str'> change_log (dict): The
change log of a CL as returned by</span><span class='strut'> </span></p> |
| 1364 <p id='t560' class='pln'><span class='str'> common.ch
ange_log.ChangeLog.ToDict().</span><span class='strut'> </span></p> |
| 1365 <p id='t561' class='pln'><span class='str'> deps_info (dict): Outpu
t of pipeline ExtractDEPSInfoPipeline.</span><span class='strut'> </span></
p> |
| 1366 <p id='t562' class='pln'><span class='strut'> </span></p> |
| 1367 <p id='t563' class='pln'><span class='str'> Returns:</span><span class='st
rut'> </span></p> |
| 1368 <p id='t564' class='pln'><span class='str'> A dict as returned by _
Justification.ToDict() if the CL is suspected for the</span><span class='strut'>
</span></p> |
| 1369 <p id='t565' class='pln'><span class='str'> failure; otherwise None
.</span><span class='strut'> </span></p> |
| 1370 <p id='t566' class='pln'><span class='str'> """</span><span
class='strut'> </span></p> |
| 1371 <p id='t567' class='pln'> <span class='com'># Use a dict to map each file
name of the touched files to their occurrences.</span><span class='strut'>
</span></p> |
| 1372 <p id='t568' class='stm run hide_run'> <span class='nam'>file_name_occurre
nces</span> <span class='op'>=</span> <span class='nam'>collections</span><span
class='op'>.</span><span class='nam'>defaultdict</span><span class='op'>(</span>
<span class='nam'>int</span><span class='op'>)</span><span class='strut'> <
/span></p> |
| 1373 <p id='t569' class='stm run hide_run'> <span class='key'>for</span> <span
class='nam'>touched_file</span> <span class='key'>in</span> <span class='nam'>ch
ange_log</span><span class='op'>[</span><span class='str'>'touched_files'
;</span><span class='op'>]</span><span class='op'>:</span><span class='strut'>&n
bsp;</span></p> |
| 1374 <p id='t570' class='stm run hide_run'> <span class='nam'>change_typ
e</span> <span class='op'>=</span> <span class='nam'>touched_file</span><span cl
ass='op'>[</span><span class='str'>'change_type'</span><span class='op'>
]</span><span class='strut'> </span></p> |
| 1375 <p id='t571' class='stm run hide_run'> <span class='key'>if</span>
<span class='op'>(</span><span class='nam'>change_type</span> <span class='key'>
in</span> <span class='op'>(</span><span class='nam'>ChangeType</span><span clas
s='op'>.</span><span class='nam'>ADD</span><span class='op'>,</span> <span class
='nam'>ChangeType</span><span class='op'>.</span><span class='nam'>COPY</span><s
pan class='op'>,</span><span class='strut'> </span></p> |
| 1376 <p id='t572' class='pln'>
<span class='nam'>ChangeType</span><span class='op'
>.</span><span class='nam'>RENAME</span><span class='op'>,</span> <span class='n
am'>ChangeType</span><span class='op'>.</span><span class='nam'>MODIFY</span><sp
an class='op'>)</span><span class='op'>)</span><span class='op'>:</span><span cl
ass='strut'> </span></p> |
| 1377 <p id='t573' class='stm run hide_run'> <span class='nam'>fil
e_name</span> <span class='op'>=</span> <span class='nam'>os</span><span class='
op'>.</span><span class='nam'>path</span><span class='op'>.</span><span class='n
am'>basename</span><span class='op'>(</span><span class='nam'>touched_file</span
><span class='op'>[</span><span class='str'>'new_path'</span><span class
='op'>]</span><span class='op'>)</span><span class='strut'> </span></p> |
| 1378 <p id='t574' class='stm run hide_run'> <span class='nam'>fil
e_name_occurrences</span><span class='op'>[</span><span class='nam'>file_name</s
pan><span class='op'>]</span> <span class='op'>+=</span> <span class='num'>1</sp
an><span class='strut'> </span></p> |
| 1379 <p id='t575' class='pln'><span class='strut'> </span></p> |
| 1380 <p id='t576' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>change_type</span> <span class='key'>in</span> <span class='op
'>(</span><span class='nam'>ChangeType</span><span class='op'>.</span><span clas
s='nam'>DELETE</span><span class='op'>,</span> <span class='nam'>ChangeType</spa
n><span class='op'>.</span><span class='nam'>RENAME</span><span class='op'>)</sp
an><span class='op'>:</span><span class='strut'> </span></p> |
| 1381 <p id='t577' class='stm run hide_run'> <span class='nam'>fil
e_name</span> <span class='op'>=</span> <span class='nam'>os</span><span class='
op'>.</span><span class='nam'>path</span><span class='op'>.</span><span class='n
am'>basename</span><span class='op'>(</span><span class='nam'>touched_file</span
><span class='op'>[</span><span class='str'>'old_path'</span><span class
='op'>]</span><span class='op'>)</span><span class='strut'> </span></p> |
| 1382 <p id='t578' class='stm run hide_run'> <span class='nam'>fil
e_name_occurrences</span><span class='op'>[</span><span class='nam'>file_name</s
pan><span class='op'>]</span> <span class='op'>+=</span> <span class='num'>1</sp
an><span class='strut'> </span></p> |
| 1383 <p id='t579' class='pln'><span class='strut'> </span></p> |
| 1384 <p id='t580' class='stm run hide_run'> <span class='nam'>justification</sp
an> <span class='op'>=</span> <span class='nam'>_Justification</span><span class
='op'>(</span><span class='op'>)</span><span class='strut'> </span></p> |
| 1385 <p id='t581' class='pln'><span class='strut'> </span></p> |
| 1386 <p id='t582' class='stm run hide_run'> <span class='nam'>rolls</span> <spa
n class='op'>=</span> <span class='nam'>deps_info</span><span class='op'>.</span
><span class='nam'>get</span><span class='op'>(</span><span class='str'>'dep
s_rolls'</span><span class='op'>,</span> <span class='op'>{</span><span clas
s='op'>}</span><span class='op'>)</span><span class='op'>.</span><span class='na
m'>get</span><span class='op'>(</span><span class='nam'>change_log</span><span c
lass='op'>[</span><span class='str'>'revision'</span><span class='op'>]<
/span><span class='op'>,</span> <span class='op'>[</span><span class='op'>]</spa
n><span class='op'>)</span><span class='strut'> </span></p> |
| 1387 <p id='t583' class='stm run hide_run'> <span class='nam'>repo_info</span>
<span class='op'>=</span> <span class='nam'>deps_info</span><span class='op'>.</
span><span class='nam'>get</span><span class='op'>(</span><span class='str'>'
;deps'</span><span class='op'>,</span> <span class='op'>{</span><span class=
'op'>}</span><span class='op'>)</span><span class='op'>.</span><span class='nam'
>get</span><span class='op'>(</span><span class='str'>'src/'</span><span
class='op'>,</span> <span class='op'>{</span><span class='op'>}</span><span cla
ss='op'>)</span><span class='strut'> </span></p> |
| 1388 <p id='t584' class='pln'><span class='strut'> </span></p> |
| 1389 <p id='t585' class='stm run hide_run'> <span class='key'>for</span> <span
class='nam'>file_path_in_log</span><span class='op'>,</span> <span class='nam'>l
ine_numbers</span> <span class='key'>in</span> <span class='nam'>failure_signal<
/span><span class='op'>.</span><span class='nam'>files</span><span class='op'>.<
/span><span class='nam'>iteritems</span><span class='op'>(</span><span class='op
'>)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 1390 <p id='t586' class='stm run hide_run'> <span class='nam'>file_path_
in_log</span> <span class='op'>=</span> <span class='nam'>_StripChromiumRootDire
ctory</span><span class='op'>(</span><span class='nam'>file_path_in_log</span><s
pan class='op'>)</span><span class='strut'> </span></p> |
| 1391 <p id='t587' class='pln'><span class='strut'> </span></p> |
| 1392 <p id='t588' class='stm run hide_run'> <span class='key'>for</span>
<span class='nam'>touched_file</span> <span class='key'>in</span> <span class='
nam'>change_log</span><span class='op'>[</span><span class='str'>'touched_fi
les'</span><span class='op'>]</span><span class='op'>:</span><span class='st
rut'> </span></p> |
| 1393 <p id='t589' class='stm run hide_run'> <span class='nam'>_Ch
eckFile</span><span class='op'>(</span><span class='strut'> </span></p> |
| 1394 <p id='t590' class='pln'> <span class='nam'>to
uched_file</span><span class='op'>,</span> <span class='nam'>file_path_in_log</s
pan><span class='op'>,</span> <span class='nam'>justification</span><span class=
'op'>,</span><span class='strut'> </span></p> |
| 1395 <p id='t591' class='pln'> <span class='nam'>fi
le_name_occurrences</span><span class='op'>,</span> <span class='nam'>line_numbe
rs</span><span class='op'>,</span> <span class='nam'>repo_info</span><span class
='op'>,</span><span class='strut'> </span></p> |
| 1396 <p id='t592' class='pln'> <span class='nam'>ch
ange_log</span><span class='op'>[</span><span class='str'>'revision'</sp
an><span class='op'>]</span><span class='op'>)</span><span class='strut'> <
/span></p> |
| 1397 <p id='t593' class='pln'><span class='strut'> </span></p> |
| 1398 <p id='t594' class='stm run hide_run'> <span class='nam'>_CheckFile
InDependencyRolls</span><span class='op'>(</span><span class='nam'>file_path_in_
log</span><span class='op'>,</span> <span class='nam'>rolls</span><span class='o
p'>,</span> <span class='nam'>justification</span><span class='op'>,</span><span
class='strut'> </span></p> |
| 1399 <p id='t595' class='pln'>
<span class='nam'>line_
numbers</span><span class='op'>)</span><span class='strut'> </span></p> |
| 1400 <p id='t596' class='pln'><span class='strut'> </span></p> |
| 1401 <p id='t597' class='stm run hide_run'> <span class='key'>if</span> <span c
lass='key'>not</span> <span class='nam'>justification</span><span class='op'>.</
span><span class='nam'>score</span><span class='op'>:</span><span class='strut'>
</span></p> |
| 1402 <p id='t598' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>None</span><span class='strut'> </span></p> |
| 1403 <p id='t599' class='pln'> <span class='key'>else</span><span class='op'>:<
/span><span class='strut'> </span></p> |
| 1404 <p id='t600' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>justification</span><span class='op'>.</span><span class='
nam'>ToDict</span><span class='op'>(</span><span class='op'>)</span><span class=
'strut'> </span></p> |
| 1405 <p id='t601' class='pln'><span class='strut'> </span></p> |
| 1406 <p id='t602' class='pln'><span class='strut'> </span></p> |
| 1407 <p id='t603' class='stm run hide_run'><span class='key'>def</span> <span class='
nam'>AnalyzeBuildFailure</span><span class='op'>(</span><span class='strut'>&nbs
p;</span></p> |
| 1408 <p id='t604' class='pln'> <span class='nam'>failure_info</span><spa
n class='op'>,</span> <span class='nam'>change_logs</span><span class='op'>,</sp
an> <span class='nam'>deps_info</span><span class='op'>,</span> <span class='nam
'>failure_signals</span><span class='op'>)</span><span class='op'>:</span><span
class='strut'> </span></p> |
| 1409 <p id='t605' class='pln'> <span class='str'>"""Analyze the
given failure signals, and figure out culprit CLs.</span><span class='strut'>&nb
sp;</span></p> |
| 1410 <p id='t606' class='pln'><span class='strut'> </span></p> |
| 1411 <p id='t607' class='pln'><span class='str'> Args:</span><span class='strut
'> </span></p> |
| 1412 <p id='t608' class='pln'><span class='str'> failure_info (dict): Ou
tput of pipeline DetectFirstFailurePipeline.</span><span class='strut'> </s
pan></p> |
| 1413 <p id='t609' class='pln'><span class='str'> change_logs (dict): Out
put of pipeline PullChangelogPipeline.</span><span class='strut'> </span></
p> |
| 1414 <p id='t610' class='pln'><span class='str'> deps_info (dict): Outpu
t of pipeline ExtractDEPSInfoPipeline.</span><span class='strut'> </span></
p> |
| 1415 <p id='t611' class='pln'><span class='str'> failure_signals (dict):
Output of pipeline ExtractSignalPipeline.</span><span class='strut'> </spa
n></p> |
| 1416 <p id='t612' class='pln'><span class='strut'> </span></p> |
| 1417 <p id='t613' class='pln'><span class='str'> Returns:</span><span class='st
rut'> </span></p> |
| 1418 <p id='t614' class='pln'><span class='str'> A dict with the followi
ng form:</span><span class='strut'> </span></p> |
| 1419 <p id='t615' class='pln'><span class='str'> {</span><span class='st
rut'> </span></p> |
| 1420 <p id='t616' class='pln'><span class='str'> 'failures
9;: [</span><span class='strut'> </span></p> |
| 1421 <p id='t617' class='pln'><span class='str'> {</span><
span class='strut'> </span></p> |
| 1422 <p id='t618' class='pln'><span class='str'> &#
39;step_name': 'compile',</span><span class='strut'> </span></p
> |
| 1423 <p id='t619' class='pln'><span class='str'> &#
39;supported': True</span><span class='strut'> </span></p> |
| 1424 <p id='t620' class='pln'><span class='str'> &#
39;first_failure': 230,</span><span class='strut'> </span></p> |
| 1425 <p id='t621' class='pln'><span class='str'> &#
39;last_pass': 229,</span><span class='strut'> </span></p> |
| 1426 <p id='t622' class='pln'><span class='str'> &#
39;suspected_cls': [</span><span class='strut'> </span></p> |
| 1427 <p id='t623' class='pln'><span class='str'> &n
bsp; {</span><span class='strut'> </span></p> |
| 1428 <p id='t624' class='pln'><span class='str'> &n
bsp; 'build_number': 230,</span><span class='strut'> </span>
</p> |
| 1429 <p id='t625' class='pln'><span class='str'> &n
bsp; 'repo_name': 'chromium',</span><span class='strut'>&
nbsp;</span></p> |
| 1430 <p id='t626' class='pln'><span class='str'> &n
bsp; 'revision': 'a_git_hash',</span><span class='strut'>
</span></p> |
| 1431 <p id='t627' class='pln'><span class='str'> &n
bsp; 'commit_position': 56789,</span><span class='strut'> </
span></p> |
| 1432 <p id='t628' class='pln'><span class='str'> &n
bsp; 'score': 11,</span><span class='strut'> </span></p> |
| 1433 <p id='t629' class='pln'><span class='str'> &n
bsp; 'hints': {</span><span class='strut'> </span></p> |
| 1434 <p id='t630' class='pln'><span class='str'> &n
bsp; 'add a/b/x.cc': 5,</span><span class='strut'> </
span></p> |
| 1435 <p id='t631' class='pln'><span class='str'> &n
bsp; 'delete a/b/y.cc': 5,</span><span class='strut'> 
;</span></p> |
| 1436 <p id='t632' class='pln'><span class='str'> &n
bsp; 'modify e/f/z.cc': 1,</span><span class='strut'> 
;</span></p> |
| 1437 <p id='t633' class='pln'><span class='str'> &n
bsp; ...</span><span class='strut'> </span></p> |
| 1438 <p id='t634' class='pln'><span class='str'> &n
bsp; }</span><span class='strut'> </span></p> |
| 1439 <p id='t635' class='pln'><span class='str'> &n
bsp; },</span><span class='strut'> </span></p> |
| 1440 <p id='t636' class='pln'><span class='str'> &n
bsp; ...</span><span class='strut'> </span></p> |
| 1441 <p id='t637' class='pln'><span class='str'> ],
</span><span class='strut'> </span></p> |
| 1442 <p id='t638' class='pln'><span class='str'> },</span>
<span class='strut'> </span></p> |
| 1443 <p id='t639' class='pln'><span class='str'> ...</span
><span class='strut'> </span></p> |
| 1444 <p id='t640' class='pln'><span class='str'> ]</span><span cl
ass='strut'> </span></p> |
| 1445 <p id='t641' class='pln'><span class='str'> }</span><span class='st
rut'> </span></p> |
| 1446 <p id='t642' class='pln'><span class='str'> """</span><span
class='strut'> </span></p> |
| 1447 <p id='t643' class='stm run hide_run'> <span class='nam'>analysis_result</
span> <span class='op'>=</span> <span class='op'>{</span><span class='strut'>&nb
sp;</span></p> |
| 1448 <p id='t644' class='pln'> <span class='str'>'failures
9;</span><span class='op'>:</span> <span class='op'>[</span><span class='op'>]</
span><span class='strut'> </span></p> |
| 1449 <p id='t645' class='pln'> <span class='op'>}</span><span class='strut'>&nb
sp;</span></p> |
| 1450 <p id='t646' class='pln'><span class='strut'> </span></p> |
| 1451 <p id='t647' class='stm run hide_run'> <span class='key'>if</span> <span c
lass='key'>not</span> <span class='nam'>failure_info</span><span class='op'>[</s
pan><span class='str'>'failed'</span><span class='op'>]</span> <span cla
ss='key'>or</span> <span class='key'>not</span> <span class='nam'>failure_info</
span><span class='op'>[</span><span class='str'>'chromium_revision'</spa
n><span class='op'>]</span><span class='op'>:</span><span class='strut'> </
span></p> |
| 1452 <p id='t648' class='pln'> <span class='com'># Bail out if no failed
step or no chromium revision.</span><span class='strut'> </span></p> |
| 1453 <p id='t649' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>analysis_result</span><span class='strut'> </span></p
> |
| 1454 <p id='t650' class='pln'><span class='strut'> </span></p> |
| 1455 <p id='t651' class='stm run hide_run'> <span class='key'>def</span> <span
class='nam'>CreateCLInfoDict</span><span class='op'>(</span><span class='nam'>ju
stification_dict</span><span class='op'>,</span> <span class='nam'>build_number<
/span><span class='op'>,</span> <span class='nam'>change_log</span><span class='
op'>)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 1456 <p id='t652' class='pln'> <span class='com'># TODO(stgao): remove h
ard-coded 'chromium' when DEPS file parsing is</span><span class='strut'
> </span></p> |
| 1457 <p id='t653' class='pln'> <span class='com'># supported.</span><spa
n class='strut'> </span></p> |
| 1458 <p id='t654' class='stm run hide_run'> <span class='nam'>cl_info</s
pan> <span class='op'>=</span> <span class='op'>{</span><span class='strut'>&nbs
p;</span></p> |
| 1459 <p id='t655' class='pln'> <span class='str'>'buil
d_number'</span><span class='op'>:</span> <span class='nam'>build_number</sp
an><span class='op'>,</span><span class='strut'> </span></p> |
| 1460 <p id='t656' class='pln'> <span class='str'>'repo
_name'</span><span class='op'>:</span> <span class='str'>'chromium'<
/span><span class='op'>,</span><span class='strut'> </span></p> |
| 1461 <p id='t657' class='pln'> <span class='str'>'revi
sion'</span><span class='op'>:</span> <span class='nam'>change_log</span><sp
an class='op'>[</span><span class='str'>'revision'</span><span class='op
'>]</span><span class='op'>,</span><span class='strut'> </span></p> |
| 1462 <p id='t658' class='pln'> <span class='str'>'comm
it_position'</span><span class='op'>:</span> <span class='nam'>change_log</s
pan><span class='op'>.</span><span class='nam'>get</span><span class='op'>(</spa
n><span class='str'>'commit_position'</span><span class='op'>)</span><sp
an class='op'>,</span><span class='strut'> </span></p> |
| 1463 <p id='t659' class='pln'> <span class='str'>'url&
#39;</span><span class='op'>:</span><span class='strut'> </span></p> |
| 1464 <p id='t660' class='pln'> <span class='
nam'>change_log</span><span class='op'>.</span><span class='nam'>get</span><span
class='op'>(</span><span class='str'>'code_review_url'</span><span clas
s='op'>)</span> <span class='key'>or</span> <span class='nam'>change_log</span><
span class='op'>.</span><span class='nam'>get</span><span class='op'>(</span><sp
an class='str'>'commit_url'</span><span class='op'>)</span><span class='
op'>,</span><span class='strut'> </span></p> |
| 1465 <p id='t661' class='pln'> <span class='op'>}</span><span class='str
ut'> </span></p> |
| 1466 <p id='t662' class='pln'><span class='strut'> </span></p> |
| 1467 <p id='t663' class='stm run hide_run'> <span class='nam'>cl_info</s
pan><span class='op'>.</span><span class='nam'>update</span><span class='op'>(</
span><span class='nam'>justification_dict</span><span class='op'>)</span><span c
lass='strut'> </span></p> |
| 1468 <p id='t664' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>cl_info</span><span class='strut'> </span></p> |
| 1469 <p id='t665' class='pln'><span class='strut'> </span></p> |
| 1470 <p id='t666' class='stm run hide_run'> <span class='nam'>failed_steps</spa
n> <span class='op'>=</span> <span class='nam'>failure_info</span><span class='o
p'>[</span><span class='str'>'failed_steps'</span><span class='op'>]</sp
an><span class='strut'> </span></p> |
| 1471 <p id='t667' class='stm run hide_run'> <span class='nam'>builds</span> <sp
an class='op'>=</span> <span class='nam'>failure_info</span><span class='op'>[</
span><span class='str'>'builds'</span><span class='op'>]</span><span cla
ss='strut'> </span></p> |
| 1472 <p id='t668' class='stm run hide_run'> <span class='nam'>master_name</span
> <span class='op'>=</span> <span class='nam'>failure_info</span><span class='op
'>.</span><span class='nam'>get</span><span class='op'>(</span><span class='str'
>'master_name'</span><span class='op'>)</span><span class='strut'>
</span></p> |
| 1473 <p id='t669' class='pln'><span class='strut'> </span></p> |
| 1474 <p id='t670' class='stm run hide_run'> <span class='key'>for</span> <span
class='nam'>step_name</span><span class='op'>,</span> <span class='nam'>step_fai
lure_info</span> <span class='key'>in</span> <span class='nam'>failed_steps</spa
n><span class='op'>.</span><span class='nam'>iteritems</span><span class='op'>(<
/span><span class='op'>)</span><span class='op'>:</span><span class='strut'>&nbs
p;</span></p> |
| 1475 <p id='t671' class='stm run hide_run'> <span class='nam'>is_test_le
vel</span> <span class='op'>=</span> <span class='nam'>step_failure_info</span><
span class='op'>.</span><span class='nam'>get</span><span class='op'>(</span><sp
an class='str'>'tests'</span><span class='op'>)</span> <span class='key'
>is</span> <span class='key'>not</span> <span class='nam'>None</span><span class
='strut'> </span></p> |
| 1476 <p id='t672' class='pln'><span class='strut'> </span></p> |
| 1477 <p id='t673' class='stm run hide_run'> <span class='nam'>failed_bui
ld_number</span> <span class='op'>=</span> <span class='nam'>step_failure_info</
span><span class='op'>[</span><span class='str'>'current_failure'</span>
<span class='op'>]</span><span class='strut'> </span></p> |
| 1478 <p id='t674' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>step_failure_info</span><span class='op'>.</span><span class='
nam'>get</span><span class='op'>(</span><span class='str'>'last_pass'</s
pan><span class='op'>)</span> <span class='key'>is</span> <span class='key'>not<
/span> <span class='nam'>None</span><span class='op'>:</span><span class='strut'
> </span></p> |
| 1479 <p id='t675' class='stm run hide_run'> <span class='nam'>sta
rt_build_number</span> <span class='op'>=</span> <span class='nam'>step_failure_
info</span><span class='op'>.</span><span class='nam'>get</span><span class='op'
>(</span><span class='str'>'last_pass'</span><span class='op'>)</span> <
span class='op'>+</span> <span class='num'>1</span><span class='strut'> </s
pan></p> |
| 1480 <p id='t676' class='pln'> <span class='key'>else</span><span class=
'op'>:</span><span class='strut'> </span></p> |
| 1481 <p id='t677' class='stm run hide_run'> <span class='nam'>sta
rt_build_number</span> <span class='op'>=</span> <span class='nam'>step_failure_
info</span><span class='op'>[</span><span class='str'>'first_failure'</s
pan><span class='op'>]</span><span class='strut'> </span></p> |
| 1482 <p id='t678' class='stm run hide_run'> <span class='nam'>step_analy
sis_result</span> <span class='op'>=</span> <span class='op'>{</span><span class
='strut'> </span></p> |
| 1483 <p id='t679' class='pln'> <span class='str'>'step
_name'</span><span class='op'>:</span> <span class='nam'>step_name</span><sp
an class='op'>,</span><span class='strut'> </span></p> |
| 1484 <p id='t680' class='pln'> <span class='str'>'firs
t_failure'</span><span class='op'>:</span> <span class='nam'>step_failure_in
fo</span><span class='op'>[</span><span class='str'>'first_failure'</spa
n><span class='op'>]</span><span class='op'>,</span><span class='strut'> </
span></p> |
| 1485 <p id='t681' class='pln'> <span class='str'>'last
_pass'</span><span class='op'>:</span> <span class='nam'>step_failure_info</
span><span class='op'>.</span><span class='nam'>get</span><span class='op'>(</sp
an><span class='str'>'last_pass'</span><span class='op'>)</span><span cl
ass='op'>,</span><span class='strut'> </span></p> |
| 1486 <p id='t682' class='pln'> <span class='str'>'susp
ected_cls'</span><span class='op'>:</span> <span class='op'>[</span><span cl
ass='op'>]</span><span class='op'>,</span><span class='strut'> </span></p> |
| 1487 <p id='t683' class='pln'> <span class='str'>'supp
orted'</span><span class='op'>:</span> <span class='nam'>waterfall_config</s
pan><span class='op'>.</span><span class='nam'>StepIsSupportedForMaster</span><s
pan class='op'>(</span><span class='strut'> </span></p> |
| 1488 <p id='t684' class='pln'> <span class='
nam'>step_name</span><span class='op'>,</span> <span class='nam'>master_name</sp
an><span class='op'>)</span><span class='strut'> </span></p> |
| 1489 <p id='t685' class='pln'> <span class='op'>}</span><span class='str
ut'> </span></p> |
| 1490 <p id='t686' class='pln'><span class='strut'> </span></p> |
| 1491 <p id='t687' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>is_test_level</span><span class='op'>:</span><span class='stru
t'> </span></p> |
| 1492 <p id='t688' class='stm run hide_run'> <span class='nam'>ste
p_analysis_result</span><span class='op'>[</span><span class='str'>'tests
9;</span><span class='op'>]</span> <span class='op'>=</span> <span class='op'>[<
/span><span class='op'>]</span><span class='strut'> </span></p> |
| 1493 <p id='t689' class='stm run hide_run'> <span class='key'>for
</span> <span class='nam'>test_name</span><span class='op'>,</span> <span class=
'nam'>test_failure</span> <span class='key'>in</span> <span class='nam'>step_fai
lure_info</span><span class='op'>[</span><span class='str'>'tests'</span
><span class='op'>]</span><span class='op'>.</span><span class='nam'>iteritems</
span><span class='op'>(</span><span class='op'>)</span><span class='op'>:</span>
<span class='strut'> </span></p> |
| 1494 <p id='t690' class='stm run hide_run'> <span class='n
am'>test_analysis_result</span> <span class='op'>=</span> <span class='op'>{</sp
an><span class='strut'> </span></p> |
| 1495 <p id='t691' class='pln'> <span class='
str'>'test_name'</span><span class='op'>:</span> <span class='nam'>test_
name</span><span class='op'>,</span><span class='strut'> </span></p> |
| 1496 <p id='t692' class='pln'> <span class='
str'>'first_failure'</span><span class='op'>:</span> <span class='nam'>t
est_failure</span><span class='op'>[</span><span class='str'>'first_failure&
#39;</span><span class='op'>]</span><span class='op'>,</span><span class='strut'
> </span></p> |
| 1497 <p id='t693' class='pln'> <span class='
str'>'last_pass'</span><span class='op'>:</span> <span class='nam'>test_
failure</span><span class='op'>.</span><span class='nam'>get</span><span class='
op'>(</span><span class='str'>'last_pass'</span><span class='op'>)</span
><span class='op'>,</span><span class='strut'> </span></p> |
| 1498 <p id='t694' class='pln'> <span class='
str'>'suspected_cls'</span><span class='op'>:</span> <span class='op'>[<
/span><span class='op'>]</span><span class='op'>,</span><span class='strut'>&nbs
p;</span></p> |
| 1499 <p id='t695' class='pln'> <span class='op'>}</span><s
pan class='strut'> </span></p> |
| 1500 <p id='t696' class='stm run hide_run'> <span class='n
am'>step_analysis_result</span><span class='op'>[</span><span class='str'>'t
ests'</span><span class='op'>]</span><span class='op'>.</span><span class='n
am'>append</span><span class='op'>(</span><span class='nam'>test_analysis_result
</span><span class='op'>)</span><span class='strut'> </span></p> |
| 1501 <p id='t697' class='pln'><span class='strut'> </span></p> |
| 1502 <p id='t698' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>step_analysis_result</span><span class='op'>[</span><span clas
s='str'>'supported'</span><span class='op'>]</span><span class='op'>:</s
pan><span class='strut'> </span></p> |
| 1503 <p id='t699' class='stm run hide_run'> <span class='key'>for
</span> <span class='nam'>build_number</span> <span class='key'>in</span> <span
class='nam'>range</span><span class='op'>(</span><span class='nam'>start_build_n
umber</span><span class='op'>,</span> <span class='nam'>failed_build_number</spa
n> <span class='op'>+</span> <span class='num'>1</span><span class='op'>)</span>
<span class='op'>:</span><span class='strut'> </span></p> |
| 1504 <p id='t700' class='stm run hide_run'> <span class='k
ey'>for</span> <span class='nam'>revision</span> <span class='key'>in</span> <sp
an class='nam'>builds</span><span class='op'>[</span><span class='nam'>str</span
><span class='op'>(</span><span class='nam'>build_number</span><span class='op'>
)</span><span class='op'>]</span><span class='op'>[</span><span class='str'>'
;blame_list'</span><span class='op'>]</span><span class='op'>:</span><span c
lass='strut'> </span></p> |
| 1505 <p id='t701' class='stm run hide_run'> <span c
lass='key'>if</span> <span class='nam'>is_test_level</span><span class='op'>:</s
pan><span class='strut'> </span></p> |
| 1506 <p id='t702' class='pln'> <span class='
com'># Checks files at test level.</span><span class='strut'> </span></p> |
| 1507 <p id='t703' class='stm run hide_run'>
<span class='key'>for</span> <span class='nam'>test_analysis_result</span> <span
class='key'>in</span> <span class='nam'>step_analysis_result</span><span class=
'op'>[</span><span class='str'>'tests'</span><span class='op'>]</span><s
pan class='op'>:</span><span class='strut'> </span></p> |
| 1508 <p id='t704' class='stm run hide_run'>
<span class='nam'>test_name</span> <span class='op'>=</span> <span class=
'nam'>test_analysis_result</span><span class='op'>[</span><span class='str'>'
;test_name'</span><span class='op'>]</span><span class='strut'> </span>
</p> |
| 1509 <p id='t705' class='stm run hide_run'>
<span class='nam'>test_signal</span> <span class='op'>=</span> <span clas
s='nam'>FailureSignal</span><span class='op'>.</span><span class='nam'>FromDict<
/span><span class='op'>(</span><span class='strut'> </span></p> |
| 1510 <p id='t706' class='pln'>
<span class='nam'>failure_signals</span><span class='op'>[</span><span c
lass='nam'>step_name</span><span class='op'>]</span><span class='op'>[</span><sp
an class='str'>'tests'</span><span class='op'>]</span><span class='op'>.
</span><span class='nam'>get</span><span class='op'>(</span><span class='nam'>te
st_name</span><span class='op'>,</span> <span class='op'>{</span><span class='op
'>}</span><span class='op'>)</span><span class='op'>)</span><span class='strut'>
</span></p> |
| 1511 <p id='t707' class='pln'><span class='strut'> </span></p> |
| 1512 <p id='t708' class='stm run hide_run'>
<span class='nam'>justification_dict</span> <span class='op'>=</span> <sp
an class='nam'>_CheckFiles</span><span class='op'>(</span><span class='strut'>&n
bsp;</span></p> |
| 1513 <p id='t709' class='pln'>
<span class='nam'>test_signal</span><span class='op'>,</span> <span clas
s='nam'>change_logs</span><span class='op'>[</span><span class='nam'>revision</s
pan><span class='op'>]</span><span class='op'>,</span> <span class='nam'>deps_in
fo</span><span class='op'>)</span><span class='strut'> </span></p> |
| 1514 <p id='t710' class='pln'><span class='strut'> </span></p> |
| 1515 <p id='t711' class='stm run hide_run'>
<span class='key'>if</span> <span class='key'>not</span> <span class='nam
'>justification_dict</span><span class='op'>:</span><span class='strut'> </
span></p> |
| 1516 <p id='t712' class='stm run hide_run'>
<span class='key'>continue</span><span class='strut'> </span>
</p> |
| 1517 <p id='t713' class='pln'><span class='strut'> </span></p> |
| 1518 <p id='t714' class='stm run hide_run'>
<span class='nam'>new_suspected_cl_dict</span> <span class='op'>=</span>
<span class='nam'>CreateCLInfoDict</span><span class='op'>(</span><span class='s
trut'> </span></p> |
| 1519 <p id='t715' class='pln'>
<span class='nam'>justification_dict</span><span class='op'>,</span> <sp
an class='nam'>build_number</span><span class='op'>,</span> <span class='nam'>ch
ange_logs</span><span class='op'>[</span><span class='nam'>revision</span><span
class='op'>]</span><span class='op'>)</span><span class='strut'> </span></p
> |
| 1520 <p id='t716' class='stm run hide_run'>
<span class='nam'>test_analysis_result</span><span class='op'>[</span><sp
an class='str'>'suspected_cls'</span><span class='op'>]</span><span clas
s='op'>.</span><span class='nam'>append</span><span class='op'>(</span><span cla
ss='strut'> </span></p> |
| 1521 <p id='t717' class='pln'>
<span class='nam'>new_suspected_cl_dict</span><span class='op'>)</span><
span class='strut'> </span></p> |
| 1522 <p id='t718' class='pln'><span class='strut'> </span></p> |
| 1523 <p id='t719' class='pln'> <span class='com'>#
Checks Files on step level using step level signals</span><span class='strut'>&n
bsp;</span></p> |
| 1524 <p id='t720' class='pln'> <span class='com'>#
regardless of test level signals so we can make sure</span><span class='strut'>&
nbsp;</span></p> |
| 1525 <p id='t721' class='pln'> <span class='com'>#
no duplicate justifications added to the step result.</span><span class='strut'>
</span></p> |
| 1526 <p id='t722' class='stm run hide_run'> <span c
lass='nam'>failure_signal</span> <span class='op'>=</span> <span class='nam'>Fai
lureSignal</span><span class='op'>.</span><span class='nam'>FromDict</span><span
class='op'>(</span><span class='nam'>failure_signals</span><span class='op'>[</
span><span class='nam'>step_name</span><span class='op'>]</span><span class='op'
>)</span><span class='strut'> </span></p> |
| 1527 <p id='t723' class='stm run hide_run'> <span c
lass='nam'>justification_dict</span> <span class='op'>=</span> <span class='nam'
>_CheckFiles</span><span class='op'>(</span><span class='strut'> </span></p
> |
| 1528 <p id='t724' class='pln'> <span
class='nam'>failure_signal</span><span class='op'>,</span> <span class='nam'>cha
nge_logs</span><span class='op'>[</span><span class='nam'>revision</span><span c
lass='op'>]</span><span class='op'>,</span> <span class='nam'>deps_info</span><s
pan class='op'>)</span><span class='strut'> </span></p> |
| 1529 <p id='t725' class='pln'><span class='strut'> </span></p> |
| 1530 <p id='t726' class='stm run hide_run'> <span c
lass='key'>if</span> <span class='key'>not</span> <span class='nam'>justificatio
n_dict</span><span class='op'>:</span><span class='strut'> </span></p> |
| 1531 <p id='t727' class='stm run hide_run'>
<span class='key'>continue</span><span class='strut'> </span></p> |
| 1532 <p id='t728' class='pln'><span class='strut'> </span></p> |
| 1533 <p id='t729' class='stm run hide_run'> <span c
lass='nam'>step_analysis_result</span><span class='op'>[</span><span class='str'
>'suspected_cls'</span><span class='op'>]</span><span class='op'>.</span
><span class='nam'>append</span><span class='op'>(</span><span class='strut'>&nb
sp;</span></p> |
| 1534 <p id='t730' class='pln'> <span
class='nam'>CreateCLInfoDict</span><span class='op'>(</span><span class='nam'>ju
stification_dict</span><span class='op'>,</span> <span class='nam'>build_number<
/span><span class='op'>,</span><span class='strut'> </span></p> |
| 1535 <p id='t731' class='pln'>
<span class='nam'>change
_logs</span><span class='op'>[</span><span class='nam'>revision</span><span clas
s='op'>]</span><span class='op'>)</span><span class='op'>)</span><span class='st
rut'> </span></p> |
| 1536 <p id='t732' class='pln'><span class='strut'> </span></p> |
| 1537 <p id='t733' class='pln'> <span class='com'># TODO(stgao): sort CLs
by score.</span><span class='strut'> </span></p> |
| 1538 <p id='t734' class='stm run hide_run'> <span class='nam'>analysis_r
esult</span><span class='op'>[</span><span class='str'>'failures'</span>
<span class='op'>]</span><span class='op'>.</span><span class='nam'>append</span
><span class='op'>(</span><span class='nam'>step_analysis_result</span><span cla
ss='op'>)</span><span class='strut'> </span></p> |
| 1539 <p id='t735' class='pln'><span class='strut'> </span></p> |
| 1540 <p id='t736' class='stm run hide_run'> <span class='key'>return</span> <sp
an class='nam'>analysis_result</span><span class='strut'> </span></p> |
| 1541 |
| 1542 </td> |
| 1543 </tr> |
| 1544 </table> |
| 1545 </div> |
| 1546 |
| 1547 <div id='footer'> |
| 1548 <div class='content'> |
| 1549 <p> |
| 1550 <a class='nav' href='index.html'>« index</a> <a c
lass='nav' href='http://nedbatchelder.com/code/coverage'>coverage.py v3.7.1</a> |
| 1551 </p> |
| 1552 </div> |
| 1553 </div> |
| 1554 |
| 1555 </body> |
| 1556 </html> |
| OLD | NEW |