| 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/extractors: 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/extractors</b> : |
| 24 <span class='pc_cov'>100%</span> |
| 25 </h1> |
| 26 <img id='keyboard_icon' src='keybd_closed.png'> |
| 27 <h2 class='stats'> |
| 28 219 statements |
| 29 <span class='run hide_run shortkey_r button_toggle_run'>219 run</spa
n> |
| 30 <span class='mis shortkey_m button_toggle_mis'>0 missing</span> |
| 31 <span class='exc shortkey_x button_toggle_exc'>79 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='pln'><a href='#n13'>13</a></p> |
| 79 <p id='n14' class='pln'><a href='#n14'>14</a></p> |
| 80 <p id='n15' class='stm run hide_run'><a href='#n15'>15</a></p> |
| 81 <p id='n16' class='pln'><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='stm run hide_run'><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='stm run hide_run'><a href='#n23'>23</a></p> |
| 89 <p id='n24' class='stm run hide_run'><a href='#n24'>24</a></p> |
| 90 <p id='n25' class='stm run hide_run'><a href='#n25'>25</a></p> |
| 91 <p id='n26' class='stm run hide_run'><a href='#n26'>26</a></p> |
| 92 <p id='n27' class='stm run hide_run'><a href='#n27'>27</a></p> |
| 93 <p id='n28' class='pln'><a href='#n28'>28</a></p> |
| 94 <p id='n29' class='stm run hide_run'><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='pln'><a href='#n31'>31</a></p> |
| 97 <p id='n32' class='stm run hide_run'><a href='#n32'>32</a></p> |
| 98 <p id='n33' class='pln'><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='pln'><a href='#n35'>35</a></p> |
| 101 <p id='n36' class='stm run hide_run'><a href='#n36'>36</a></p> |
| 102 <p id='n37' class='stm run hide_run'><a href='#n37'>37</a></p> |
| 103 <p id='n38' class='pln'><a href='#n38'>38</a></p> |
| 104 <p id='n39' class='stm run hide_run'><a href='#n39'>39</a></p> |
| 105 <p id='n40' class='stm run hide_run'><a href='#n40'>40</a></p> |
| 106 <p id='n41' class='pln'><a href='#n41'>41</a></p> |
| 107 <p id='n42' class='stm run hide_run'><a href='#n42'>42</a></p> |
| 108 <p id='n43' class='pln'><a href='#n43'>43</a></p> |
| 109 <p id='n44' class='stm run hide_run'><a href='#n44'>44</a></p> |
| 110 <p id='n45' class='pln'><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='pln'><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='stm run hide_run'><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='stm run hide_run'><a href='#n53'>53</a></p> |
| 119 <p id='n54' class='pln'><a href='#n54'>54</a></p> |
| 120 <p id='n55' class='stm run hide_run'><a href='#n55'>55</a></p> |
| 121 <p id='n56' class='stm run hide_run'><a href='#n56'>56</a></p> |
| 122 <p id='n57' class='stm run hide_run'><a href='#n57'>57</a></p> |
| 123 <p id='n58' class='pln'><a href='#n58'>58</a></p> |
| 124 <p id='n59' class='stm run hide_run'><a href='#n59'>59</a></p> |
| 125 <p id='n60' class='pln'><a href='#n60'>60</a></p> |
| 126 <p id='n61' class='stm run hide_run'><a href='#n61'>61</a></p> |
| 127 <p id='n62' class='exc'><a href='#n62'>62</a></p> |
| 128 <p id='n63' class='exc'><a href='#n63'>63</a></p> |
| 129 <p id='n64' class='exc'><a href='#n64'>64</a></p> |
| 130 <p id='n65' class='exc'><a href='#n65'>65</a></p> |
| 131 <p id='n66' class='exc'><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='pln'><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='pln'><a href='#n70'>70</a></p> |
| 136 <p id='n71' class='pln'><a href='#n71'>71</a></p> |
| 137 <p id='n72' class='pln'><a href='#n72'>72</a></p> |
| 138 <p id='n73' class='stm run hide_run'><a href='#n73'>73</a></p> |
| 139 <p id='n74' class='pln'><a href='#n74'>74</a></p> |
| 140 <p id='n75' class='stm run hide_run'><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='stm run hide_run'><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='stm run hide_run'><a href='#n80'>80</a></p> |
| 146 <p id='n81' class='exc'><a href='#n81'>81</a></p> |
| 147 <p id='n82' class='exc'><a href='#n82'>82</a></p> |
| 148 <p id='n83' class='exc'><a href='#n83'>83</a></p> |
| 149 <p id='n84' class='pln'><a href='#n84'>84</a></p> |
| 150 <p id='n85' class='exc'><a href='#n85'>85</a></p> |
| 151 <p id='n86' class='exc'><a href='#n86'>86</a></p> |
| 152 <p id='n87' class='exc'><a href='#n87'>87</a></p> |
| 153 <p id='n88' class='stm run hide_run'><a href='#n88'>88</a></p> |
| 154 <p id='n89' class='stm run hide_run'><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='pln'><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='exc'><a href='#n94'>94</a></p> |
| 160 <p id='n95' class='exc'><a href='#n95'>95</a></p> |
| 161 <p id='n96' class='pln'><a href='#n96'>96</a></p> |
| 162 <p id='n97' class='pln'><a href='#n97'>97</a></p> |
| 163 <p id='n98' class='exc'><a href='#n98'>98</a></p> |
| 164 <p id='n99' class='exc'><a href='#n99'>99</a></p> |
| 165 <p id='n100' class='pln'><a href='#n100'>100</a></p> |
| 166 <p id='n101' class='stm run hide_run'><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='pln'><a href='#n103'>103</a></p> |
| 169 <p id='n104' class='stm run hide_run'><a href='#n104'>104</a></p> |
| 170 <p id='n105' class='pln'><a href='#n105'>105</a></p> |
| 171 <p id='n106' class='stm run hide_run'><a href='#n106'>106</a></p> |
| 172 <p id='n107' class='pln'><a href='#n107'>107</a></p> |
| 173 <p id='n108' class='pln'><a href='#n108'>108</a></p> |
| 174 <p id='n109' class='stm run hide_run'><a href='#n109'>109</a></p> |
| 175 <p id='n110' class='pln'><a href='#n110'>110</a></p> |
| 176 <p id='n111' class='stm run hide_run'><a href='#n111'>111</a></p> |
| 177 <p id='n112' class='stm run hide_run'><a href='#n112'>112</a></p> |
| 178 <p id='n113' class='stm run hide_run'><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='pln'><a href='#n118'>118</a></p> |
| 184 <p id='n119' class='pln'><a href='#n119'>119</a></p> |
| 185 <p id='n120' class='stm run hide_run'><a href='#n120'>120</a></p> |
| 186 <p id='n121' class='pln'><a href='#n121'>121</a></p> |
| 187 <p id='n122' class='stm run hide_run'><a href='#n122'>122</a></p> |
| 188 <p id='n123' class='pln'><a href='#n123'>123</a></p> |
| 189 <p id='n124' class='stm run hide_run'><a href='#n124'>124</a></p> |
| 190 <p id='n125' class='pln'><a href='#n125'>125</a></p> |
| 191 <p id='n126' class='stm run hide_run'><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='stm run hide_run'><a href='#n128'>128</a></p> |
| 194 <p id='n129' class='stm run hide_run'><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='stm run hide_run'><a href='#n132'>132</a></p> |
| 198 <p id='n133' class='pln'><a href='#n133'>133</a></p> |
| 199 <p id='n134' class='stm run hide_run'><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='pln'><a href='#n140'>140</a></p> |
| 206 <p id='n141' class='pln'><a href='#n141'>141</a></p> |
| 207 <p id='n142' class='pln'><a href='#n142'>142</a></p> |
| 208 <p id='n143' class='stm run hide_run'><a href='#n143'>143</a></p> |
| 209 <p id='n144' class='pln'><a href='#n144'>144</a></p> |
| 210 <p id='n145' class='pln'><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='stm run hide_run'><a href='#n152'>152</a></p> |
| 218 <p id='n153' class='pln'><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='pln'><a href='#n156'>156</a></p> |
| 222 <p id='n157' class='stm run hide_run'><a href='#n157'>157</a></p> |
| 223 <p id='n158' class='stm run hide_run'><a href='#n158'>158</a></p> |
| 224 <p id='n159' class='stm run hide_run'><a href='#n159'>159</a></p> |
| 225 <p id='n160' class='stm run hide_run'><a href='#n160'>160</a></p> |
| 226 <p id='n161' class='pln'><a href='#n161'>161</a></p> |
| 227 <p id='n162' class='pln'><a href='#n162'>162</a></p> |
| 228 <p id='n163' class='pln'><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='pln'><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='pln'><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='pln'><a href='#n170'>170</a></p> |
| 236 <p id='n171' class='pln'><a href='#n171'>171</a></p> |
| 237 <p id='n172' class='pln'><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='stm run hide_run'><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='pln'><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='stm run hide_run'><a href='#n184'>184</a></p> |
| 250 <p id='n185' class='pln'><a href='#n185'>185</a></p> |
| 251 <p id='n186' class='stm run hide_run'><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='stm run hide_run'><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='stm run hide_run'><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='pln'><a href='#n200'>200</a></p> |
| 266 <p id='n201' class='stm run hide_run'><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='stm run hide_run'><a href='#n203'>203</a></p> |
| 269 <p id='n204' class='pln'><a href='#n204'>204</a></p> |
| 270 <p id='n205' class='pln'><a href='#n205'>205</a></p> |
| 271 <p id='n206' class='pln'><a href='#n206'>206</a></p> |
| 272 <p id='n207' class='pln'><a href='#n207'>207</a></p> |
| 273 <p id='n208' class='stm run hide_run'><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='pln'><a href='#n210'>210</a></p> |
| 276 <p id='n211' class='stm run hide_run'><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='stm run hide_run'><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='stm run hide_run'><a href='#n218'>218</a></p> |
| 284 <p id='n219' class='pln'><a href='#n219'>219</a></p> |
| 285 <p id='n220' class='stm run hide_run'><a href='#n220'>220</a></p> |
| 286 <p id='n221' class='stm run hide_run'><a href='#n221'>221</a></p> |
| 287 <p id='n222' class='stm run hide_run'><a href='#n222'>222</a></p> |
| 288 <p id='n223' class='pln'><a href='#n223'>223</a></p> |
| 289 <p id='n224' class='stm run hide_run'><a href='#n224'>224</a></p> |
| 290 <p id='n225' class='stm run hide_run'><a href='#n225'>225</a></p> |
| 291 <p id='n226' class='pln'><a href='#n226'>226</a></p> |
| 292 <p id='n227' class='stm run hide_run'><a href='#n227'>227</a></p> |
| 293 <p id='n228' class='stm run hide_run'><a href='#n228'>228</a></p> |
| 294 <p id='n229' class='stm run hide_run'><a href='#n229'>229</a></p> |
| 295 <p id='n230' class='stm run hide_run'><a href='#n230'>230</a></p> |
| 296 <p id='n231' class='stm run hide_run'><a href='#n231'>231</a></p> |
| 297 <p id='n232' class='stm run hide_run'><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='pln'><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='stm run hide_run'><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='stm run hide_run'><a href='#n241'>241</a></p> |
| 307 <p id='n242' class='pln'><a href='#n242'>242</a></p> |
| 308 <p id='n243' class='stm run hide_run'><a href='#n243'>243</a></p> |
| 309 <p id='n244' class='stm run hide_run'><a href='#n244'>244</a></p> |
| 310 <p id='n245' class='stm run hide_run'><a href='#n245'>245</a></p> |
| 311 <p id='n246' class='exc'><a href='#n246'>246</a></p> |
| 312 <p id='n247' class='stm run hide_run'><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='stm run hide_run'><a href='#n251'>251</a></p> |
| 317 <p id='n252' class='stm run hide_run'><a href='#n252'>252</a></p> |
| 318 <p id='n253' class='stm run hide_run'><a href='#n253'>253</a></p> |
| 319 <p id='n254' class='stm run hide_run'><a href='#n254'>254</a></p> |
| 320 <p id='n255' class='exc'><a href='#n255'>255</a></p> |
| 321 <p id='n256' class='pln'><a href='#n256'>256</a></p> |
| 322 <p id='n257' class='exc'><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='pln'><a href='#n259'>259</a></p> |
| 325 <p id='n260' class='stm run hide_run'><a href='#n260'>260</a></p> |
| 326 <p id='n261' class='pln'><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='pln'><a href='#n266'>266</a></p> |
| 332 <p id='n267' class='pln'><a href='#n267'>267</a></p> |
| 333 <p id='n268' class='stm run hide_run'><a href='#n268'>268</a></p> |
| 334 <p id='n269' class='stm run hide_run'><a href='#n269'>269</a></p> |
| 335 <p id='n270' class='pln'><a href='#n270'>270</a></p> |
| 336 <p id='n271' class='stm run hide_run'><a href='#n271'>271</a></p> |
| 337 <p id='n272' class='exc'><a href='#n272'>272</a></p> |
| 338 <p id='n273' class='pln'><a href='#n273'>273</a></p> |
| 339 <p id='n274' class='pln'><a href='#n274'>274</a></p> |
| 340 <p id='n275' class='exc'><a href='#n275'>275</a></p> |
| 341 <p id='n276' class='pln'><a href='#n276'>276</a></p> |
| 342 <p id='n277' class='pln'><a href='#n277'>277</a></p> |
| 343 <p id='n278' class='stm run hide_run'><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='pln'><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='pln'><a href='#n285'>285</a></p> |
| 351 <p id='n286' class='stm run hide_run'><a href='#n286'>286</a></p> |
| 352 <p id='n287' class='pln'><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='stm run hide_run'><a href='#n289'>289</a></p> |
| 355 <p id='n290' class='stm run hide_run'><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='stm run hide_run'><a href='#n294'>294</a></p> |
| 360 <p id='n295' class='pln'><a href='#n295'>295</a></p> |
| 361 <p id='n296' class='stm run hide_run'><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='stm run hide_run'><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='stm run hide_run'><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='stm run hide_run'><a href='#n307'>307</a></p> |
| 373 <p id='n308' class='pln'><a href='#n308'>308</a></p> |
| 374 <p id='n309' class='pln'><a href='#n309'>309</a></p> |
| 375 <p id='n310' class='stm run hide_run'><a href='#n310'>310</a></p> |
| 376 <p id='n311' class='stm run hide_run'><a href='#n311'>311</a></p> |
| 377 <p id='n312' class='pln'><a href='#n312'>312</a></p> |
| 378 <p id='n313' class='stm run hide_run'><a href='#n313'>313</a></p> |
| 379 <p id='n314' class='pln'><a href='#n314'>314</a></p> |
| 380 <p id='n315' class='pln'><a href='#n315'>315</a></p> |
| 381 <p id='n316' class='stm run hide_run'><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='stm run hide_run'><a href='#n323'>323</a></p> |
| 389 <p id='n324' class='pln'><a href='#n324'>324</a></p> |
| 390 <p id='n325' class='stm run hide_run'><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='stm run hide_run'><a href='#n328'>328</a></p> |
| 394 <p id='n329' class='pln'><a href='#n329'>329</a></p> |
| 395 <p id='n330' class='stm run hide_run'><a href='#n330'>330</a></p> |
| 396 <p id='n331' class='stm run hide_run'><a href='#n331'>331</a></p> |
| 397 <p id='n332' class='stm run hide_run'><a href='#n332'>332</a></p> |
| 398 <p id='n333' class='stm run hide_run'><a href='#n333'>333</a></p> |
| 399 <p id='n334' class='stm run hide_run'><a href='#n334'>334</a></p> |
| 400 <p id='n335' class='pln'><a href='#n335'>335</a></p> |
| 401 <p id='n336' class='stm run hide_run'><a href='#n336'>336</a></p> |
| 402 <p id='n337' class='exc'><a href='#n337'>337</a></p> |
| 403 <p id='n338' class='exc'><a href='#n338'>338</a></p> |
| 404 <p id='n339' class='exc'><a href='#n339'>339</a></p> |
| 405 <p id='n340' class='exc'><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='pln'><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='stm run hide_run'><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='pln'><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='stm run hide_run'><a href='#n355'>355</a></p> |
| 421 <p id='n356' class='pln'><a href='#n356'>356</a></p> |
| 422 <p id='n357' class='stm run hide_run'><a href='#n357'>357</a></p> |
| 423 <p id='n358' class='exc'><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='pln'><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='pln'><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='pln'><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='stm run hide_run'><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='pln'><a href='#n372'>372</a></p> |
| 438 <p id='n373' class='exc'><a href='#n373'>373</a></p> |
| 439 <p id='n374' class='exc'><a href='#n374'>374</a></p> |
| 440 <p id='n375' class='exc'><a href='#n375'>375</a></p> |
| 441 <p id='n376' class='exc'><a href='#n376'>376</a></p> |
| 442 <p id='n377' class='pln'><a href='#n377'>377</a></p> |
| 443 <p id='n378' class='exc'><a href='#n378'>378</a></p> |
| 444 <p id='n379' class='exc'><a href='#n379'>379</a></p> |
| 445 <p id='n380' class='pln'><a href='#n380'>380</a></p> |
| 446 <p id='n381' class='exc'><a href='#n381'>381</a></p> |
| 447 <p id='n382' class='exc'><a href='#n382'>382</a></p> |
| 448 <p id='n383' class='exc'><a href='#n383'>383</a></p> |
| 449 <p id='n384' class='pln'><a href='#n384'>384</a></p> |
| 450 <p id='n385' class='exc'><a href='#n385'>385</a></p> |
| 451 <p id='n386' class='exc'><a href='#n386'>386</a></p> |
| 452 <p id='n387' class='pln'><a href='#n387'>387</a></p> |
| 453 <p id='n388' class='exc'><a href='#n388'>388</a></p> |
| 454 <p id='n389' class='exc'><a href='#n389'>389</a></p> |
| 455 <p id='n390' class='pln'><a href='#n390'>390</a></p> |
| 456 <p id='n391' class='exc'><a href='#n391'>391</a></p> |
| 457 <p id='n392' class='exc'><a href='#n392'>392</a></p> |
| 458 <p id='n393' class='exc'><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='exc'><a href='#n396'>396</a></p> |
| 462 <p id='n397' class='pln'><a href='#n397'>397</a></p> |
| 463 <p id='n398' class='exc'><a href='#n398'>398</a></p> |
| 464 <p id='n399' class='pln'><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='pln'><a href='#n401'>401</a></p> |
| 467 <p id='n402' class='pln'><a href='#n402'>402</a></p> |
| 468 <p id='n403' class='stm run hide_run'><a href='#n403'>403</a></p> |
| 469 <p id='n404' class='pln'><a href='#n404'>404</a></p> |
| 470 <p id='n405' class='stm run hide_run'><a href='#n405'>405</a></p> |
| 471 <p id='n406' class='stm run hide_run'><a href='#n406'>406</a></p> |
| 472 <p id='n407' class='pln'><a href='#n407'>407</a></p> |
| 473 <p id='n408' class='stm run hide_run'><a href='#n408'>408</a></p> |
| 474 <p id='n409' class='stm run hide_run'><a href='#n409'>409</a></p> |
| 475 <p id='n410' class='stm run hide_run'><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='stm run hide_run'><a href='#n413'>413</a></p> |
| 479 <p id='n414' class='stm run hide_run'><a href='#n414'>414</a></p> |
| 480 <p id='n415' class='exc'><a href='#n415'>415</a></p> |
| 481 <p id='n416' class='exc'><a href='#n416'>416</a></p> |
| 482 <p id='n417' class='exc'><a href='#n417'>417</a></p> |
| 483 <p id='n418' class='exc'><a href='#n418'>418</a></p> |
| 484 <p id='n419' class='exc'><a href='#n419'>419</a></p> |
| 485 <p id='n420' class='exc'><a href='#n420'>420</a></p> |
| 486 <p id='n421' class='pln'><a href='#n421'>421</a></p> |
| 487 <p id='n422' class='exc'><a href='#n422'>422</a></p> |
| 488 <p id='n423' class='exc'><a href='#n423'>423</a></p> |
| 489 <p id='n424' class='exc'><a href='#n424'>424</a></p> |
| 490 <p id='n425' class='pln'><a href='#n425'>425</a></p> |
| 491 <p id='n426' class='exc'><a href='#n426'>426</a></p> |
| 492 <p id='n427' class='exc'><a href='#n427'>427</a></p> |
| 493 <p id='n428' class='exc'><a href='#n428'>428</a></p> |
| 494 <p id='n429' class='pln'><a href='#n429'>429</a></p> |
| 495 <p id='n430' class='pln'><a href='#n430'>430</a></p> |
| 496 <p id='n431' class='exc'><a href='#n431'>431</a></p> |
| 497 <p id='n432' class='pln'><a href='#n432'>432</a></p> |
| 498 <p id='n433' class='exc'><a href='#n433'>433</a></p> |
| 499 <p id='n434' class='pln'><a href='#n434'>434</a></p> |
| 500 <p id='n435' class='exc'><a href='#n435'>435</a></p> |
| 501 <p id='n436' class='exc'><a href='#n436'>436</a></p> |
| 502 <p id='n437' class='exc'><a href='#n437'>437</a></p> |
| 503 <p id='n438' class='exc'><a href='#n438'>438</a></p> |
| 504 <p id='n439' class='pln'><a href='#n439'>439</a></p> |
| 505 <p id='n440' class='stm run hide_run'><a href='#n440'>440</a></p> |
| 506 <p id='n441' class='stm run hide_run'><a href='#n441'>441</a></p> |
| 507 <p id='n442' class='stm run hide_run'><a href='#n442'>442</a></p> |
| 508 <p id='n443' class='pln'><a href='#n443'>443</a></p> |
| 509 <p id='n444' class='stm run hide_run'><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='pln'><a href='#n447'>447</a></p> |
| 513 <p id='n448' class='exc'><a href='#n448'>448</a></p> |
| 514 <p id='n449' class='exc'><a href='#n449'>449</a></p> |
| 515 <p id='n450' class='exc'><a href='#n450'>450</a></p> |
| 516 <p id='n451' class='exc'><a href='#n451'>451</a></p> |
| 517 <p id='n452' class='exc'><a href='#n452'>452</a></p> |
| 518 <p id='n453' class='pln'><a href='#n453'>453</a></p> |
| 519 <p id='n454' class='exc'><a href='#n454'>454</a></p> |
| 520 <p id='n455' class='exc'><a href='#n455'>455</a></p> |
| 521 <p id='n456' class='pln'><a href='#n456'>456</a></p> |
| 522 <p id='n457' class='pln'><a href='#n457'>457</a></p> |
| 523 <p id='n458' class='exc'><a href='#n458'>458</a></p> |
| 524 <p id='n459' class='exc'><a href='#n459'>459</a></p> |
| 525 <p id='n460' class='exc'><a href='#n460'>460</a></p> |
| 526 <p id='n461' class='stm run hide_run'><a href='#n461'>461</a></p> |
| 527 <p id='n462' class='pln'><a href='#n462'>462</a></p> |
| 528 <p id='n463' class='pln'><a href='#n463'>463</a></p> |
| 529 <p id='n464' class='stm run hide_run'><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='stm run hide_run'><a href='#n467'>467</a></p> |
| 533 <p id='n468' class='pln'><a href='#n468'>468</a></p> |
| 534 <p id='n469' class='stm run hide_run'><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='stm run hide_run'><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='stm run hide_run'><a href='#n474'>474</a></p> |
| 540 <p id='n475' class='pln'><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='exc'><a href='#n478'>478</a></p> |
| 544 <p id='n479' class='pln'><a href='#n479'>479</a></p> |
| 545 <p id='n480' class='exc'><a href='#n480'>480</a></p> |
| 546 <p id='n481' class='exc'><a href='#n481'>481</a></p> |
| 547 <p id='n482' class='exc'><a href='#n482'>482</a></p> |
| 548 <p id='n483' class='exc'><a href='#n483'>483</a></p> |
| 549 <p id='n484' class='pln'><a href='#n484'>484</a></p> |
| 550 <p id='n485' class='exc'><a href='#n485'>485</a></p> |
| 551 <p id='n486' class='exc'><a href='#n486'>486</a></p> |
| 552 <p id='n487' class='pln'><a href='#n487'>487</a></p> |
| 553 <p id='n488' class='exc'><a href='#n488'>488</a></p> |
| 554 <p id='n489' class='stm run hide_run'><a href='#n489'>489</a></p> |
| 555 <p id='n490' class='pln'><a href='#n490'>490</a></p> |
| 556 <p id='n491' class='pln'><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='stm run hide_run'><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='pln'><a href='#n508'>508</a></p> |
| 574 <p id='n509' class='pln'><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='pln'><a href='#n516'>516</a></p> |
| 582 <p id='n517' class='pln'><a href='#n517'>517</a></p> |
| 583 <p id='n518' class='pln'><a href='#n518'>518</a></p> |
| 584 <p id='n519' class='pln'><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='pln'><a href='#n523'>523</a></p> |
| 589 |
| 590 </td> |
| 591 <td class='text' valign='top'> |
| 592 <p id='t1' class='pln'><span class='com'># Copyright 2014 The Chromium Authors.
All rights reserved.</span><span class='strut'> </span></p> |
| 593 <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> |
| 594 <p id='t3' class='pln'><span class='com'># found in the LICENSE file.</span><spa
n class='strut'> </span></p> |
| 595 <p id='t4' class='pln'><span class='strut'> </span></p> |
| 596 <p id='t5' class='stm run hide_run'><span class='key'>import</span> <span class=
'nam'>logging</span><span class='strut'> </span></p> |
| 597 <p id='t6' class='stm run hide_run'><span class='key'>import</span> <span class=
'nam'>os</span><span class='strut'> </span></p> |
| 598 <p id='t7' class='stm run hide_run'><span class='key'>import</span> <span class=
'nam'>re</span><span class='strut'> </span></p> |
| 599 <p id='t8' class='pln'><span class='strut'> </span></p> |
| 600 <p id='t9' class='stm run hide_run'><span class='key'>from</span> <span class='n
am'>waterfall</span> <span class='key'>import</span> <span class='nam'>extractor
_util</span><span class='strut'> </span></p> |
| 601 <p id='t10' 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> |
| 602 <p id='t11' class='stm run hide_run'><span class='key'>from</span> <span class='
nam'>waterfall</span><span class='op'>.</span><span class='nam'>extractor</span>
<span class='key'>import</span> <span class='nam'>Extractor</span><span class='
strut'> </span></p> |
| 603 <p id='t12' 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> |
| 604 <p id='t13' class='pln'><span class='strut'> </span></p> |
| 605 <p id='t14' class='pln'><span class='strut'> </span></p> |
| 606 <p id='t15' class='stm run hide_run'><span class='key'>class</span> <span class=
'nam'>GeneralExtractor</span><span class='op'>(</span><span class='nam'>Extracto
r</span><span class='op'>)</span><span class='op'>:</span><span class='strut'>&n
bsp;</span></p> |
| 607 <p id='t16' class='pln'> <span class='str'>"""A general ext
ractor.</span><span class='strut'> </span></p> |
| 608 <p id='t17' class='pln'><span class='strut'> </span></p> |
| 609 <p id='t18' class='pln'><span class='str'> It extracts file name and line
numbers.</span><span class='strut'> </span></p> |
| 610 <p id='t19' class='pln'><span class='str'> """</span><span
class='strut'> </span></p> |
| 611 <p id='t20' class='stm run hide_run'> <span class='nam'>INDIRECT_LEAK_MARK
ER_PATTERN</span> <span class='op'>=</span> <span class='nam'>re</span><span cla
ss='op'>.</span><span class='nam'>compile</span><span class='op'>(</span><span c
lass='strut'> </span></p> |
| 612 <p id='t21' class='pln'> <span class='str'>r'.*Indirect
leak of \d+ byte\(s\) in \d+ object\(s\) allocated from:.*'</span><span clas
s='op'>)</span><span class='strut'> </span></p> |
| 613 <p id='t22' class='pln'><span class='strut'> </span></p> |
| 614 <p id='t23' class='stm run hide_run'> <span class='key'>def</span> <span c
lass='nam'>_ExtractCppFiles</span><span class='op'>(</span><span class='nam'>sel
f</span><span class='op'>,</span> <span class='nam'>cpp_stacktrace_frames</span>
<span class='op'>,</span> <span class='nam'>signal</span><span class='op'>)</spa
n><span class='op'>:</span><span class='strut'> </span></p> |
| 615 <p id='t24' class='stm run hide_run'> <span class='nam'>in_expected
_crash</span> <span class='op'>=</span> <span class='nam'>False</span><span clas
s='strut'> </span></p> |
| 616 <p id='t25' class='stm run hide_run'> <span class='key'>for</span>
<span class='nam'>frame</span> <span class='key'>in</span> <span class='nam'>cpp
_stacktrace_frames</span><span class='op'>:</span><span class='strut'> </sp
an></p> |
| 617 <p id='t26' class='stm run hide_run'> <span class='nam'>matc
h</span> <span class='op'>=</span> <span class='nam'>extractor_util</span><span
class='op'>.</span><span class='nam'>CPP_STACK_TRACE_FRAME_PATTERN</span><span c
lass='op'>.</span><span class='nam'>match</span><span class='op'>(</span><span c
lass='nam'>frame</span><span class='op'>)</span><span class='strut'> </span
></p> |
| 618 <p id='t27' class='stm run hide_run'> <span class='nam'>cpp_
stack_frame_index</span> <span class='op'>=</span> <span class='nam'>int</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> <sp
an class='num'>1</span><span class='strut'> </span></p> |
| 619 <p id='t28' class='pln'><span class='strut'> </span></p> |
| 620 <p id='t29' class='stm run hide_run'> <span class='key'>if</
span> <span class='str'>'::CrashIntentionally()'</span> <span class='key
'>in</span> <span class='nam'>frame</span><span class='op'>:</span><span class='
strut'> </span></p> |
| 621 <p id='t30' class='stm run hide_run'> <span class='na
m'>in_expected_crash</span> <span class='op'>=</span> <span class='nam'>True</sp
an><span class='strut'> </span></p> |
| 622 <p id='t31' class='pln'><span class='strut'> </span></p> |
| 623 <p id='t32' class='stm run hide_run'> <span class='key'>if</
span> <span class='op'>(</span><span class='key'>not</span> <span class='nam'>in
_expected_crash</span> <span class='key'>and</span> <span class='nam'>cpp_stack_
frame_index</span> <span class='op'><=</span><span class='strut'> </span
></p> |
| 624 <p id='t33' class='pln'> <span class='nam'>ext
ractor_util</span><span class='op'>.</span><span class='nam'>CPP_MAXIMUM_NUMBER_
STACK_FRAMES</span><span class='op'>)</span><span class='op'>:</span><span class
='strut'> </span></p> |
| 625 <p id='t34' class='stm run hide_run'> <span class='na
m'>self</span><span class='op'>.</span><span class='nam'>ExtractFiles</span><spa
n class='op'>(</span><span class='nam'>frame</span><span class='op'>,</span> <sp
an class='nam'>signal</span><span class='op'>)</span><span class='strut'> <
/span></p> |
| 626 <p id='t35' class='pln'><span class='strut'> </span></p> |
| 627 <p id='t36' class='stm run hide_run'> <span class='key'>def</span> <span c
lass='nam'>_ExtractPythonFiles</span><span class='op'>(</span><span class='nam'>
self</span><span class='op'>,</span> <span class='nam'>python_stacktrace_frames<
/span><span class='op'>,</span> <span class='nam'>signal</span><span class='op'>
)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 628 <p id='t37' class='stm run hide_run'> <span class='nam'>frames_with
_filenames</span> <span class='op'>=</span> <span class='op'>[</span><span class
='op'>]</span><span class='strut'> </span></p> |
| 629 <p id='t38' class='pln'><span class='strut'> </span></p> |
| 630 <p id='t39' class='stm run hide_run'> <span class='key'>for</span>
<span class='nam'>frame</span> <span class='key'>in</span> <span class='nam'>pyt
hon_stacktrace_frames</span><span class='op'>:</span><span class='strut'> <
/span></p> |
| 631 <p id='t40' class='stm run hide_run'> <span class='key'>if</
span> <span class='op'>(</span><span class='nam'>extractor_util</span><span clas
s='op'>.</span><span class='nam'>PYTHON_STACK_TRACE_FRAME_PATTERN_1</span><span
class='op'>.</span><span class='nam'>search</span><span class='op'>(</span><span
class='nam'>frame</span><span class='op'>)</span> <span class='key'>or</span><s
pan class='strut'> </span></p> |
| 632 <p id='t41' class='pln'> <span class='nam'>ext
ractor_util</span><span class='op'>.</span><span class='nam'>PYTHON_STACK_TRACE_
FRAME_PATTERN_2</span><span class='op'>.</span><span class='nam'>search</span><s
pan class='op'>(</span><span class='nam'>frame</span><span class='op'>)</span><s
pan class='op'>)</span><span class='op'>:</span><span class='strut'> </span
></p> |
| 633 <p id='t42' class='stm run hide_run'> <span class='na
m'>frames_with_filenames</span><span class='op'>.</span><span class='nam'>append
</span><span class='op'>(</span><span class='nam'>frame</span><span class='op'>)
</span><span class='strut'> </span></p> |
| 634 <p id='t43' class='pln'><span class='strut'> </span></p> |
| 635 <p id='t44' class='stm run hide_run'> <span class='key'>for</span>
<span class='nam'>frame</span> <span class='key'>in</span> <span class='nam'>fra
mes_with_filenames</span><span class='op'>[</span><span class='strut'> </sp
an></p> |
| 636 <p id='t45' class='pln'> <span class='op'>-</span><sp
an class='nam'>extractor_util</span><span class='op'>.</span><span class='nam'>P
YTHON_MAXIMUM_NUMBER_STACK_FRAMES</span><span class='op'>:</span><span class='op
'>]</span><span class='op'>:</span><span class='strut'> </span></p> |
| 637 <p id='t46' class='stm run hide_run'> <span class='nam'>self
</span><span class='op'>.</span><span class='nam'>ExtractFiles</span><span class
='op'>(</span><span class='nam'>frame</span><span class='op'>,</span> <span clas
s='nam'>signal</span><span class='op'>)</span><span class='strut'> </span><
/p> |
| 638 <p id='t47' class='pln'><span class='strut'> </span></p> |
| 639 <p id='t48' class='stm run hide_run'> <span class='key'>def</span> <span c
lass='nam'>Extract</span><span class='op'>(</span><span class='nam'>self</span><
span class='op'>,</span> <span class='nam'>failure_log</span><span class='op'>,<
/span> <span class='op'>*</span><span class='nam'>_</span><span class='op'>)</sp
an><span class='op'>:</span><span class='strut'> </span></p> |
| 640 <p id='t49' class='stm run hide_run'> <span class='nam'>signal</spa
n> <span class='op'>=</span> <span class='nam'>FailureSignal</span><span class='
op'>(</span><span class='op'>)</span><span class='strut'> </span></p> |
| 641 <p id='t50' class='stm run hide_run'> <span class='nam'>failure_log
_lines</span> <span class='op'>=</span> <span class='nam'>failure_log</span><spa
n class='op'>.</span><span class='nam'>splitlines</span><span class='op'>(</span
><span class='op'>)</span><span class='strut'> </span></p> |
| 642 <p id='t51' class='pln'><span class='strut'> </span></p> |
| 643 <p id='t52' class='stm run hide_run'> <span class='nam'>i</span> <s
pan class='op'>=</span> <span class='num'>0</span><span class='strut'> </sp
an></p> |
| 644 <p id='t53' class='stm run hide_run'> <span class='nam'>end_index</
span> <span class='op'>=</span> <span class='nam'>len</span><span class='op'>(</
span><span class='nam'>failure_log_lines</span><span class='op'>)</span><span cl
ass='strut'> </span></p> |
| 645 <p id='t54' class='pln'><span class='strut'> </span></p> |
| 646 <p id='t55' class='stm run hide_run'> <span class='key'>while</span
> <span class='nam'>i</span> <span class='op'><</span> <span class='nam'>end_
index</span><span class='op'>:</span><span class='strut'> </span></p> |
| 647 <p id='t56' class='stm run hide_run'> <span class='nam'>line
</span> <span class='op'>=</span> <span class='nam'>failure_log_lines</span><spa
n class='op'>[</span><span class='nam'>i</span><span class='op'>]</span><span cl
ass='strut'> </span></p> |
| 648 <p id='t57' class='stm run hide_run'> <span class='nam'>cpp_
stacktrace_match</span> <span class='op'>=</span> <span class='nam'>extractor_ut
il</span><span class='op'>.</span><span class='nam'>CPP_STACK_TRACE_FRAME_PATTER
N</span><span class='op'>.</span><span class='nam'>match</span><span class='op'>
(</span><span class='strut'> </span></p> |
| 649 <p id='t58' class='pln'> <span class='nam'>lin
e</span><span class='op'>)</span><span class='strut'> </span></p> |
| 650 <p id='t59' class='stm run hide_run'> <span class='key'>if</
span> <span class='nam'>cpp_stacktrace_match</span><span class='op'>:</span><spa
n class='strut'> </span></p> |
| 651 <p id='t60' class='pln'> <span class='com'># Handle c
pp failure stacktraces.</span><span class='strut'> </span></p> |
| 652 <p id='t61' class='stm run hide_run'> <span class='na
m'>start</span> <span class='op'>=</span> <span class='nam'>i</span><span class=
'strut'> </span></p> |
| 653 <p id='t62' class='exc'> <span class='key'>for</span>
<span class='nam'>line</span> <span class='key'>in</span> <span class='nam'>fai
lure_log_lines</span><span class='op'>[</span><span class='nam'>start</span><spa
n class='op'>:</span><span class='op'>]</span><span class='op'>:</span> <s
pan class='com'># pragma: no cover</span><span class='strut'> </span></p> |
| 654 <p id='t63' class='exc'> <span class='key'>if<
/span> <span class='nam'>extractor_util</span><span class='op'>.</span><span cla
ss='nam'>CPP_STACK_TRACE_FRAME_PATTERN</span><span class='op'>.</span><span clas
s='nam'>match</span><span class='op'>(</span><span class='nam'>line</span><span
class='op'>)</span><span class='op'>:</span><span class='strut'> </span></p
> |
| 655 <p id='t64' class='exc'> <span class='n
am'>i</span> <span class='op'>+=</span> <span class='num'>1</span><span class='s
trut'> </span></p> |
| 656 <p id='t65' class='exc'> <span class='key'>els
e</span><span class='op'>:</span><span class='strut'> </span></p> |
| 657 <p id='t66' class='exc'> <span class='k
ey'>break</span><span class='strut'> </span></p> |
| 658 <p id='t67' class='stm run hide_run'> <span class='na
m'>end</span> <span class='op'>=</span> <span class='nam'>i</span><span class='s
trut'> </span></p> |
| 659 <p id='t68' class='pln'><span class='strut'> </span></p> |
| 660 <p id='t69' class='stm run hide_run'> <span class='ke
y'>if</span> <span class='op'>(</span><span class='nam'>start</span> <span class
='op'>>=</span> <span class='num'>1</span> <span class='key'>and</span><span
class='strut'> </span></p> |
| 661 <p id='t70' class='pln'> <span class='n
am'>self</span><span class='op'>.</span><span class='nam'>INDIRECT_LEAK_MARKER_P
ATTERN</span><span class='op'>.</span><span class='nam'>match</span><span class=
'op'>(</span><span class='strut'> </span></p> |
| 662 <p id='t71' class='pln'>
<span class='nam'>failure_log_lines</span><span class='op'>[</span><span class='
nam'>start</span> <span class='op'>-</span> <span class='num'>1</span><span clas
s='op'>]</span><span class='op'>)</span><span class='op'>)</span><span class='op
'>:</span><span class='strut'> </span></p> |
| 663 <p id='t72' class='pln'> <span class='com'># I
gnore stack trace of an indirect leak.</span><span class='strut'> </span></
p> |
| 664 <p id='t73' class='stm run hide_run'> <span cl
ass='key'>continue</span><span class='strut'> </span></p> |
| 665 <p id='t74' class='pln'><span class='strut'> </span></p> |
| 666 <p id='t75' class='stm run hide_run'> <span class='na
m'>cpp_stacktrace_frames</span> <span class='op'>=</span> <span class='nam'>fail
ure_log_lines</span><span class='op'>[</span><span class='nam'>start</span><span
class='op'>:</span><span class='nam'>end</span><span class='op'>]</span><span c
lass='strut'> </span></p> |
| 667 <p id='t76' class='stm run hide_run'> <span class='na
m'>self</span><span class='op'>.</span><span class='nam'>_ExtractCppFiles</span>
<span class='op'>(</span><span class='nam'>cpp_stacktrace_frames</span><span cla
ss='op'>,</span> <span class='nam'>signal</span><span class='op'>)</span><span c
lass='strut'> </span></p> |
| 668 <p id='t77' class='stm run hide_run'> <span class='key'>elif
</span> <span class='nam'>extractor_util</span><span class='op'>.</span><span cl
ass='nam'>PYTHON_STACK_TRACE_START_PATTERN</span><span class='op'>.</span><span
class='nam'>search</span><span class='op'>(</span><span class='nam'>line</span><
span class='op'>)</span><span class='op'>:</span><span class='strut'> </spa
n></p> |
| 669 <p id='t78' class='pln'> <span class='com'># Handle p
ython failure stacktraces.</span><span class='strut'> </span></p> |
| 670 <p id='t79' class='stm run hide_run'> <span class='na
m'>i</span> <span class='op'>+=</span> <span class='num'>1</span><span class='st
rut'> </span></p> |
| 671 <p id='t80' class='stm run hide_run'> <span class='na
m'>start</span> <span class='op'>=</span> <span class='nam'>i</span><span class=
'strut'> </span></p> |
| 672 <p id='t81' class='exc'> <span class='key'>while</spa
n> <span class='nam'>i</span> <span class='op'><</span> <span class='nam'>end
_index</span><span class='op'>:</span> <span class='com'># pragma: no cove
r</span><span class='strut'> </span></p> |
| 673 <p id='t82' class='exc'> <span class='nam'>lin
e</span> <span class='op'>=</span> <span class='nam'>failure_log_lines</span><sp
an class='op'>[</span><span class='nam'>i</span><span class='op'>]</span><span c
lass='strut'> </span></p> |
| 674 <p id='t83' class='exc'> <span class='key'>if<
/span> <span class='op'>(</span><span class='nam'>extractor_util</span><span cla
ss='op'>.</span><span class='nam'>PYTHON_STACK_TRACE_FRAME_PATTERN_1</span><span
class='op'>.</span><span class='nam'>search</span><span class='op'>(</span><spa
n class='nam'>line</span><span class='op'>)</span> <span class='key'>or</span><s
pan class='strut'> </span></p> |
| 675 <p id='t84' class='pln'> <span c
lass='nam'>extractor_util</span><span class='op'>.</span><span class='nam'>PYTHO
N_STACK_TRACE_FRAME_PATTERN_2</span><span class='op'>.</span><span class='nam'>s
earch</span><span class='op'>(</span><span class='nam'>line</span><span class='o
p'>)</span><span class='op'>)</span><span class='op'>:</span><span class='strut'
> </span></p> |
| 676 <p id='t85' class='exc'> <span class='n
am'>i</span> <span class='op'>+=</span> <span class='num'>2</span><span class='s
trut'> </span></p> |
| 677 <p id='t86' class='exc'> <span class='key'>els
e</span><span class='op'>:</span><span class='strut'> </span></p> |
| 678 <p id='t87' class='exc'> <span class='k
ey'>break</span><span class='strut'> </span></p> |
| 679 <p id='t88' class='stm run hide_run'> <span class='na
m'>end</span> <span class='op'>=</span> <span class='nam'>i</span><span class='s
trut'> </span></p> |
| 680 <p id='t89' class='stm run hide_run'> <span class='na
m'>python_stacktrace_frames</span> <span class='op'>=</span> <span class='nam'>f
ailure_log_lines</span><span class='op'>[</span><span class='nam'>start</span><s
pan class='op'>:</span><span class='nam'>end</span><span class='op'>]</span><spa
n class='strut'> </span></p> |
| 681 <p id='t90' class='stm run hide_run'> <span class='na
m'>self</span><span class='op'>.</span><span class='nam'>_ExtractPythonFiles</sp
an><span class='op'>(</span><span class='nam'>python_stacktrace_frames</span><sp
an class='op'>,</span> <span class='nam'>signal</span><span class='op'>)</span><
span class='strut'> </span></p> |
| 682 <p id='t91' class='stm run hide_run'> <span class='key'>elif
</span> <span class='str'>'GMOCK WARNING'</span> <span class='key'>in</s
pan> <span class='nam'>line</span><span class='op'>:</span><span class='strut'>&
nbsp;</span></p> |
| 683 <p id='t92' class='pln'> <span class='com'># Ignore G
MOCK WARNING statements.</span><span class='strut'> </span></p> |
| 684 <p id='t93' class='stm run hide_run'> <span class='na
m'>start</span> <span class='op'>=</span> <span class='nam'>i</span><span class=
'strut'> </span></p> |
| 685 <p id='t94' class='exc'> <span class='key'>for</span>
<span class='nam'>l</span> <span class='key'>in</span> <span class='nam'>failur
e_log_lines</span><span class='op'>[</span><span class='nam'>start</span><span c
lass='op'>:</span><span class='op'>]</span><span class='op'>:</span> <span
class='com'># pragma: no cover</span><span class='strut'> </span></p> |
| 686 <p id='t95' class='exc'> <span class='key'>if<
/span> <span class='op'>(</span><span class='str'>'You can safely ignore the
above warning unless this call '</span><span class='strut'> </span></p
> |
| 687 <p id='t96' class='pln'> <span c
lass='str'>'should not happen.'</span><span class='op'>)</span> <span cl
ass='key'>in</span> <span class='nam'>l</span><span class='op'>:</span><span cla
ss='strut'> </span></p> |
| 688 <p id='t97' class='pln'> <span class='c
om'># The end line in GMOCK WARNING statements.</span><span class='strut'>
</span></p> |
| 689 <p id='t98' class='exc'> <span class='k
ey'>break</span><span class='strut'> </span></p> |
| 690 <p id='t99' class='exc'> <span class='nam'>i</
span> <span class='op'>+=</span> <span class='num'>1</span><span class='strut'>&
nbsp;</span></p> |
| 691 <p id='t100' class='pln'> <span class='key'>else</span><span
class='op'>:</span><span class='strut'> </span></p> |
| 692 <p id='t101' class='stm run hide_run'> <span class='k
ey'>if</span> <span class='nam'>line</span> <span class='key'>and</span> <span c
lass='key'>not</span> <span class='nam'>extractor_util</span><span class='op'>.<
/span><span class='nam'>ShouldIgnoreLine</span><span class='op'>(</span><span cl
ass='nam'>line</span><span class='op'>)</span><span class='op'>:</span><span cla
ss='strut'> </span></p> |
| 693 <p id='t102' class='stm run hide_run'> <span c
lass='nam'>self</span><span class='op'>.</span><span class='nam'>ExtractFiles</s
pan><span class='op'>(</span><span class='nam'>line</span><span class='op'>,</sp
an> <span class='nam'>signal</span><span class='op'>)</span><span class='strut'>
</span></p> |
| 694 <p id='t103' class='pln'><span class='strut'> </span></p> |
| 695 <p id='t104' class='stm run hide_run'> <span class='nam'>i</
span> <span class='op'>+=</span> <span class='num'>1</span><span class='strut'>&
nbsp;</span></p> |
| 696 <p id='t105' class='pln'><span class='strut'> </span></p> |
| 697 <p id='t106' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>signal</span><span class='strut'> </span></p> |
| 698 <p id='t107' class='pln'><span class='strut'> </span></p> |
| 699 <p id='t108' class='pln'><span class='strut'> </span></p> |
| 700 <p id='t109' class='stm run hide_run'><span class='key'>class</span> <span class
='nam'>CompileStepExtractor</span><span class='op'>(</span><span class='nam'>Ext
ractor</span><span class='op'>)</span><span class='op'>:</span><span class='stru
t'> </span></p> |
| 701 <p id='t110' class='pln'> <span class='str'>"""For compile
step, extracts files and identifies failed targets."""</span><spa
n class='strut'> </span></p> |
| 702 <p id='t111' class='stm run hide_run'> <span class='nam'>FAILURE_START_LIN
E_PREFIX</span> <span class='op'>=</span> <span class='str'>'FAILED: '</
span><span class='strut'> </span></p> |
| 703 <p id='t112' class='stm run hide_run'> <span class='nam'>FAILURE_WITH_ERRO
R_PATTERN</span> <span class='op'>=</span> <span class='nam'>re</span><span clas
s='op'>.</span><span class='nam'>compile</span><span class='op'>(</span><span cl
ass='str'>r'FAILED with \d+:'</span><span class='op'>)</span><span class
='strut'> </span></p> |
| 704 <p id='t113' class='stm run hide_run'> <span class='nam'>LINUX_BUILD_COMMA
ND_PATTERN</span> <span class='op'>=</span> <span class='nam'>re</span><span cla
ss='op'>.</span><span class='nam'>compile</span><span class='op'>(</span><span c
lass='str'>r'gomacc|clang\+\+'</span><span class='op'>)</span><span clas
s='strut'> </span></p> |
| 705 <p id='t114' class='pln'><span class='strut'> </span></p> |
| 706 <p id='t115' class='pln'> <span class='com'># TODO(lijeffrey): In some cas
es on mac, the target may have quotes wrapped</span><span class='strut'> </
span></p> |
| 707 <p id='t116' class='pln'> <span class='com'># around the target, i.e. &quo
t;Chromium Framework" and we will need to determine</span><span class='stru
t'> </span></p> |
| 708 <p id='t117' class='pln'> <span class='com'># whether or not the quotes sh
ould be included. If so, then this todo/comment</span><span class='strut'>
</span></p> |
| 709 <p id='t118' class='pln'> <span class='com'># can be removed, but if not t
hen we want to replace the target group with</span><span class='strut'> </s
pan></p> |
| 710 <p id='t119' class='pln'> <span class='com'># ("([^"]+)"|([
^\s-]+)) instead.</span><span class='strut'> </span></p> |
| 711 <p id='t120' class='stm run hide_run'> <span class='nam'>LINUX_FAILED_SOUR
CE_TARGET_PATTERN</span> <span class='op'>=</span> <span class='nam'>re</span><s
pan class='op'>.</span><span class='nam'>compile</span><span class='op'>(</span>
<span class='strut'> </span></p> |
| 712 <p id='t121' class='pln'> <span class='str'>r'(?:-c ([^\
s-]+))? -o (("[^"]+")|([^\s-]+))'</span><span class='op'>)</s
pan><span class='strut'> </span></p> |
| 713 <p id='t122' class='stm run hide_run'> <span class='nam'>WINDOWS_FAILED_SO
URCE_TARGET_PATTERN</span> <span class='op'>=</span> <span class='nam'>re</span>
<span class='op'>.</span><span class='nam'>compile</span><span class='op'>(</spa
n><span class='strut'> </span></p> |
| 714 <p id='t123' class='pln'> <span class='str'>r'/c ([^\s-]
+)\s+/Fo([^\s-]+)'</span><span class='op'>)</span><span class='strut'>
</span></p> |
| 715 <p id='t124' class='stm run hide_run'> <span class='nam'>WINDOWS_LINK_FAIL
URE_PATTERN</span> <span class='op'>=</span> <span class='nam'>re</span><span cl
ass='op'>.</span><span class='nam'>compile</span><span class='op'>(</span><span
class='str'>r'/OUT:([^\s-]+)'</span><span class='op'>)</span><span class
='strut'> </span></p> |
| 716 <p id='t125' class='pln'><span class='strut'> </span></p> |
| 717 <p id='t126' class='stm run hide_run'> <span class='nam'>NINJA_FAILURE_END
_LINE_PREFIX</span> <span class='op'>=</span> <span class='str'>'ninja: buil
d stopped'</span><span class='strut'> </span></p> |
| 718 <p id='t127' class='stm run hide_run'> <span class='nam'>NINJA_ERROR_LINE_
PREFIX</span> <span class='op'>=</span> <span class='str'>'ninja: error'
</span><span class='strut'> </span></p> |
| 719 <p id='t128' class='stm run hide_run'> <span class='nam'>ERROR_LINE_END_PA
TTERN</span> <span class='op'>=</span> <span class='nam'>re</span><span class='o
p'>.</span><span class='nam'>compile</span><span class='op'>(</span><span class=
'str'>r'^\d+ errors? generated.'</span><span class='op'>)</span><span cl
ass='strut'> </span></p> |
| 720 <p id='t129' class='stm run hide_run'> <span class='nam'>IOS_ERROR_LINE_ST
ART_PREFIX</span> <span class='op'>=</span> <span class='str'>'CompileC'
</span><span class='strut'> </span></p> |
| 721 <p id='t130' class='pln'><span class='strut'> </span></p> |
| 722 <p id='t131' class='stm run hide_run'> <span class='nam'>IOS_BUILDER_NAMES
_FOR_COMPILE</span> <span class='op'>=</span> <span class='op'>[</span><span cla
ss='str'>'iOS_Simulator_(dbg)'</span><span class='op'>,</span> <span cla
ss='str'>'iOS_Device'</span><span class='op'>]</span><span class='strut'
> </span></p> |
| 723 <p id='t132' class='stm run hide_run'> <span class='nam'>MAC_MASTER_NAME_F
OR_COMPILE</span> <span class='op'>=</span> <span class='str'>'chromium.mac&
#39;</span><span class='strut'> </span></p> |
| 724 <p id='t133' class='pln'><span class='strut'> </span></p> |
| 725 <p id='t134' class='stm run hide_run'> <span class='nam'>GOMA_COMPILER_PRE
FIX</span> <span class='op'>=</span> <span class='op'>(</span><span class='strut
'> </span></p> |
| 726 <p id='t135' class='pln'> <span class='str'>r'\S*/gomacc
'</span><span class='strut'> </span></p> |
| 727 <p id='t136' class='pln'> <span class='str'>'\S+(?
:clang\+\+|androideabi-gcc|androideabi-g\+\+)'</span><span class='strut'>&nb
sp;</span></p> |
| 728 <p id='t137' class='pln'> <span class='op'>)</span><span class='strut'>&nb
sp;</span></p> |
| 729 <p id='t138' class='stm run hide_run'> <span class='nam'>STRICT_COMPILE_FA
ILURE_PATTEN</span> <span class='op'>=</span> <span class='nam'>re</span><span c
lass='op'>.</span><span class='nam'>compile</span><span class='op'>(</span><span
class='strut'> </span></p> |
| 730 <p id='t139' class='pln'> <span class='str'>r'^FAILED: %
s -MMD -MF (obj/[^\s-]+\.o)\.d .* '</span><span class='strut'> </span><
/p> |
| 731 <p id='t140' class='pln'> <span class='str'>'-c ([
^\s-]+(?:cc|c|cpp|m|mm)) -o \\1$'</span> <span class='op'>%</span> <span cla
ss='op'>(</span><span class='strut'> </span></p> |
| 732 <p id='t141' class='pln'> <span class='n
am'>GOMA_COMPILER_PREFIX</span><span class='op'>)</span><span class='op'>)</span
><span class='strut'> </span></p> |
| 733 <p id='t142' class='pln'><span class='strut'> </span></p> |
| 734 <p id='t143' class='stm run hide_run'> <span class='nam'>STRICT_LINK_FAILU
RE_PATTEN</span> <span class='op'>=</span> <span class='nam'>re</span><span clas
s='op'>.</span><span class='nam'>compile</span><span class='op'>(</span><span cl
ass='strut'> </span></p> |
| 735 <p id='t144' class='pln'> <span class='str'>r'^FAILED: %
s -Wl,.* -o (\S+) -Wl,--start-group .*$'</span> <span class='op'>%</span> <s
pan class='op'>(</span><span class='strut'> </span></p> |
| 736 <p id='t145' class='pln'> <span class='nam'>GO
MA_COMPILER_PREFIX</span><span class='op'>)</span><span class='op'>)</span><span
class='strut'> </span></p> |
| 737 <p id='t146' class='pln'><span class='strut'> </span></p> |
| 738 <p id='t147' class='stm run hide_run'> <span class='key'>def</span> <span
class='nam'>ExtractFailedOutputNodes</span><span class='op'>(</span><span class=
'nam'>self</span><span class='op'>,</span> <span class='nam'>line</span><span cl
ass='op'>,</span> <span class='nam'>signal</span><span class='op'>)</span><span
class='op'>:</span><span class='strut'> </span></p> |
| 739 <p id='t148' class='stm run hide_run'> <span class='nam'>match</spa
n> <span class='op'>=</span> <span class='nam'>self</span><span class='op'>.</sp
an><span class='nam'>STRICT_COMPILE_FAILURE_PATTEN</span><span class='op'>.</spa
n><span class='nam'>match</span><span class='op'>(</span><span class='nam'>line<
/span><span class='op'>)</span><span class='strut'> </span></p> |
| 740 <p id='t149' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>match</span><span class='op'>:</span><span class='strut'> 
;</span></p> |
| 741 <p id='t150' class='stm run hide_run'> <span class='nam'>tar
get</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='strut'> </span></p> |
| 742 <p id='t151' class='stm run hide_run'> <span class='nam'>sou
rce</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'>2</span><span class='op'>)</span><span class='strut'> </span></p> |
| 743 <p id='t152' class='stm run hide_run'> <span class='nam'>sig
nal</span><span class='op'>.</span><span class='nam'>AddTarget</span><span class
='op'>(</span><span class='op'>{</span><span class='strut'> </span></p> |
| 744 <p id='t153' class='pln'> <span class='str'>&#
39;target'</span><span class='op'>:</span> <span class='nam'>target</span><s
pan class='op'>,</span><span class='strut'> </span></p> |
| 745 <p id='t154' class='pln'> <span class='str'>&#
39;source'</span><span class='op'>:</span> <span class='nam'>source</span><s
pan class='op'>,</span><span class='strut'> </span></p> |
| 746 <p id='t155' class='pln'> <span class='op'>}</span><span cla
ss='op'>)</span><span class='strut'> </span></p> |
| 747 <p id='t156' class='pln'> <span class='key'>else</span><span class=
'op'>:</span><span class='strut'> </span></p> |
| 748 <p id='t157' class='stm run hide_run'> <span class='nam'>mat
ch</span> <span class='op'>=</span> <span class='nam'>self</span><span class='op
'>.</span><span class='nam'>STRICT_LINK_FAILURE_PATTEN</span><span class='op'>.<
/span><span class='nam'>match</span><span class='op'>(</span><span class='nam'>l
ine</span><span class='op'>)</span><span class='strut'> </span></p> |
| 749 <p id='t158' class='stm run hide_run'> <span class='key'>if<
/span> <span class='nam'>match</span><span class='op'>:</span><span class='strut
'> </span></p> |
| 750 <p id='t159' class='stm run hide_run'> <span class='n
am'>target</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='strut'> </span></
p> |
| 751 <p id='t160' class='stm run hide_run'> <span class='n
am'>signal</span><span class='op'>.</span><span class='nam'>AddTarget</span><spa
n class='op'>(</span><span class='op'>{</span><span class='strut'> </span><
/p> |
| 752 <p id='t161' class='pln'> <span class='
str'>'target'</span><span class='op'>:</span> <span class='nam'>target</
span><span class='op'>,</span><span class='strut'> </span></p> |
| 753 <p id='t162' class='pln'> <span class='op'>}</span><s
pan class='op'>)</span><span class='strut'> </span></p> |
| 754 <p id='t163' class='pln'> <span class='key'>else</span><span
class='op'>:</span><span class='strut'> </span></p> |
| 755 <p id='t164' class='stm run hide_run'> <span class='n
am'>logging</span><span class='op'>.</span><span class='nam'>warn</span><span cl
ass='op'>(</span><span class='str'>'Unknown failure type: %s'</span><spa
n class='op'>,</span> <span class='nam'>line</span><span class='op'>)</span><spa
n class='strut'> </span></p> |
| 756 <p id='t165' class='pln'><span class='strut'> </span></p> |
| 757 <p id='t166' class='stm run hide_run'> <span class='key'>def</span> <span
class='nam'>GetFailedTarget</span><span class='op'>(</span><span class='nam'>sel
f</span><span class='op'>,</span> <span class='nam'>line</span><span class='op'>
,</span> <span class='nam'>signal</span><span class='op'>)</span><span class='op
'>:</span><span class='strut'> </span></p> |
| 758 <p id='t167' class='stm run hide_run'> <span class='nam'>match</spa
n> <span class='op'>=</span> <span class='nam'>self</span><span class='op'>.</sp
an><span class='nam'>LINUX_FAILED_SOURCE_TARGET_PATTERN</span><span class='op'>.
</span><span class='nam'>search</span><span class='op'>(</span><span class='nam'
>line</span><span class='op'>)</span><span class='strut'> </span></p> |
| 759 <p id='t168' class='pln'><span class='strut'> </span></p> |
| 760 <p id='t169' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>match</span><span class='op'>:</span><span class='strut'> 
;</span></p> |
| 761 <p id='t170' class='pln'> <span class='com'># For non-window
s builds, build lines should contain either gomacc or</span><span class='strut'>
</span></p> |
| 762 <p id='t171' class='pln'> <span class='com'># clang++, so on
ly search for source/target files after the call to</span><span class='strut'>&n
bsp;</span></p> |
| 763 <p id='t172' class='pln'> <span class='com'># gomacc/clang++
to avoid extracting false positives in the failure line.</span><span class='str
ut'> </span></p> |
| 764 <p id='t173' class='stm run hide_run'> <span class='nam'>bui
ld_line_match</span> <span class='op'>=</span> <span class='nam'>self</span><spa
n class='op'>.</span><span class='nam'>LINUX_BUILD_COMMAND_PATTERN</span><span c
lass='op'>.</span><span class='nam'>search</span><span class='op'>(</span><span
class='nam'>line</span><span class='op'>)</span><span class='strut'> </span
></p> |
| 765 <p id='t174' class='stm run hide_run'> <span class='key'>if<
/span> <span class='key'>not</span> <span class='nam'>build_line_match</span><sp
an class='op'>:</span><span class='strut'> </span></p> |
| 766 <p id='t175' class='stm run hide_run'> <span class='k
ey'>return</span><span class='strut'> </span></p> |
| 767 <p id='t176' class='pln'><span class='strut'> </span></p> |
| 768 <p id='t177' class='pln'> <span class='com'># Only begin ext
racting the targets starting from the index of gomacc or</span><span class='stru
t'> </span></p> |
| 769 <p id='t178' class='pln'> <span class='com'># clang++ showin
g up in the line.</span><span class='strut'> </span></p> |
| 770 <p id='t179' class='stm run hide_run'> <span class='nam'>sta
rt</span> <span class='op'>=</span> <span class='nam'>build_line_match</span><sp
an class='op'>.</span><span class='nam'>start</span><span class='op'>(</span><sp
an class='op'>)</span><span class='strut'> </span></p> |
| 771 <p id='t180' class='stm run hide_run'> <span class='nam'>mat
ch</span> <span class='op'>=</span> <span class='nam'>self</span><span class='op
'>.</span><span class='nam'>LINUX_FAILED_SOURCE_TARGET_PATTERN</span><span class
='op'>.</span><span class='nam'>search</span><span class='op'>(</span><span clas
s='nam'>line</span><span class='op'>[</span><span class='nam'>start</span><span
class='op'>:</span><span class='op'>]</span><span class='op'>)</span><span class
='strut'> </span></p> |
| 772 <p id='t181' class='stm run hide_run'> <span class='nam'>sou
rce_file</span> <span class='op'>=</span> <span class='nam'>match</span><span cl
ass='op'>.</span><span class='nam'>group</span><span class='op'>(</span><span cl
ass='num'>1</span><span class='op'>)</span><span class='strut'> </span></p> |
| 773 <p id='t182' class='stm run hide_run'> <span class='nam'>tar
get</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'>2</span><span class='op'>)</span><span class='strut'> </span></p> |
| 774 <p id='t183' class='pln'><span class='strut'> </span></p> |
| 775 <p id='t184' class='stm run hide_run'> <span class='key'>if<
/span> <span class='nam'>source_file</span><span class='op'>:</span><span class=
'strut'> </span></p> |
| 776 <p id='t185' class='pln'> <span class='com'># Failure
is a compile failure.</span><span class='strut'> </span></p> |
| 777 <p id='t186' class='stm run hide_run'> <span class='n
am'>signal</span><span class='op'>.</span><span class='nam'>AddTarget</span><spa
n class='op'>(</span><span class='op'>{</span><span class='strut'> </span><
/p> |
| 778 <p id='t187' class='pln'> <span class='
str'>'target'</span><span class='op'>:</span> <span class='nam'>target</
span><span class='op'>,</span><span class='strut'> </span></p> |
| 779 <p id='t188' class='pln'> <span class='
str'>'source'</span><span class='op'>:</span> <span class='nam'>source_f
ile</span><span class='strut'> </span></p> |
| 780 <p id='t189' class='pln'> <span class='op'>}</span><s
pan class='op'>)</span><span class='strut'> </span></p> |
| 781 <p id='t190' class='pln'> <span class='key'>else</span><span
class='op'>:</span><span class='strut'> </span></p> |
| 782 <p id='t191' class='pln'> <span class='com'># Failure
is a linker error.</span><span class='strut'> </span></p> |
| 783 <p id='t192' class='stm run hide_run'> <span class='n
am'>signal</span><span class='op'>.</span><span class='nam'>AddTarget</span><spa
n class='op'>(</span><span class='op'>{</span><span class='strut'> </span><
/p> |
| 784 <p id='t193' class='pln'> <span class='
str'>'target'</span><span class='op'>:</span> <span class='nam'>target</
span><span class='strut'> </span></p> |
| 785 <p id='t194' class='pln'> <span class='op'>}</span><s
pan class='op'>)</span><span class='strut'> </span></p> |
| 786 <p id='t195' class='pln'> <span class='key'>else</span><span class=
'op'>:</span><span class='strut'> </span></p> |
| 787 <p id='t196' class='pln'> <span class='com'># If no match wa
s found using Linux pattern matching, fallback to Windows.</span><span class='st
rut'> </span></p> |
| 788 <p id='t197' class='stm run hide_run'> <span class='nam'>mat
ch</span> <span class='op'>=</span> <span class='nam'>self</span><span class='op
'>.</span><span class='nam'>WINDOWS_FAILED_SOURCE_TARGET_PATTERN</span><span cla
ss='op'>.</span><span class='nam'>search</span><span class='op'>(</span><span cl
ass='nam'>line</span><span class='op'>)</span><span class='strut'> </span><
/p> |
| 789 <p id='t198' class='pln'><span class='strut'> </span></p> |
| 790 <p id='t199' class='stm run hide_run'> <span class='key'>if<
/span> <span class='nam'>match</span><span class='op'>:</span><span class='strut
'> </span></p> |
| 791 <p id='t200' class='pln'> <span class='com'># Failure
is a compile failure.</span><span class='strut'> </span></p> |
| 792 <p id='t201' class='stm run hide_run'> <span class='n
am'>source_file</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='strut'> </sp
an></p> |
| 793 <p id='t202' class='stm run hide_run'> <span class='n
am'>object_file</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'>2</span><span class='op'>)</span><span class='strut'> </sp
an></p> |
| 794 <p id='t203' class='stm run hide_run'> <span class='n
am'>signal</span><span class='op'>.</span><span class='nam'>AddTarget</span><spa
n class='op'>(</span><span class='op'>{</span><span class='strut'> </span><
/p> |
| 795 <p id='t204' class='pln'> <span class='
str'>'target'</span><span class='op'>:</span> <span class='nam'>object_f
ile</span><span class='op'>,</span><span class='strut'> </span></p> |
| 796 <p id='t205' class='pln'> <span class='
str'>'source'</span><span class='op'>:</span> <span class='nam'>source_f
ile</span><span class='strut'> </span></p> |
| 797 <p id='t206' class='pln'> <span class='op'>}</span><s
pan class='op'>)</span><span class='strut'> </span></p> |
| 798 <p id='t207' class='pln'> <span class='key'>else</span><span
class='op'>:</span><span class='strut'> </span></p> |
| 799 <p id='t208' class='stm run hide_run'> <span class='n
am'>match</span> <span class='op'>=</span> <span class='nam'>self</span><span cl
ass='op'>.</span><span class='nam'>WINDOWS_LINK_FAILURE_PATTERN</span><span clas
s='op'>.</span><span class='nam'>search</span><span class='op'>(</span><span cla
ss='nam'>line</span><span class='op'>)</span><span class='strut'> </span></
p> |
| 800 <p id='t209' class='stm run hide_run'> <span class='k
ey'>if</span> <span class='nam'>match</span><span class='op'>:</span><span class
='strut'> </span></p> |
| 801 <p id='t210' class='pln'> <span class='com'>#
Failure is a linker error.</span><span class='strut'> </span></p> |
| 802 <p id='t211' class='stm run hide_run'> <span c
lass='nam'>target</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='strut'> </
span></p> |
| 803 <p id='t212' class='stm run hide_run'> <span c
lass='nam'>signal</span><span class='op'>.</span><span class='nam'>AddTarget</sp
an><span class='op'>(</span><span class='op'>{</span><span class='str'>'targ
et'</span><span class='op'>:</span> <span class='nam'>target</span><span cla
ss='op'>}</span><span class='op'>)</span><span class='strut'> </span></p> |
| 804 <p id='t213' class='pln'><span class='strut'> </span></p> |
| 805 <p id='t214' class='stm run hide_run'> <span class='key'>def</span> <span
class='nam'>Extract</span><span class='op'>(</span><span class='nam'>self</span>
<span class='op'>,</span> <span class='nam'>failure_log</span><span class='op'>,
</span> <span class='nam'>test_name</span><span class='op'>,</span> <span class=
'nam'>step_name</span><span class='op'>,</span> <span class='nam'>bot_name</span
><span class='op'>,</span> <span class='nam'>master_name</span><span class='op'>
)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 806 <p id='t215' class='stm run hide_run'> <span class='nam'>signal</sp
an> <span class='op'>=</span> <span class='nam'>FailureSignal</span><span class=
'op'>(</span><span class='op'>)</span><span class='strut'> </span></p> |
| 807 <p id='t216' class='stm run hide_run'> <span class='nam'>failure_st
arted</span> <span class='op'>=</span> <span class='nam'>False</span><span class
='strut'> </span></p> |
| 808 <p id='t217' class='pln'><span class='strut'> </span></p> |
| 809 <p id='t218' class='stm run hide_run'> <span class='key'>if</span>
<span class='op'>(</span><span class='nam'>master_name</span> <span class='op'>=
=</span> <span class='nam'>self</span><span class='op'>.</span><span class='nam'
>MAC_MASTER_NAME_FOR_COMPILE</span> <span class='key'>and</span><span class='str
ut'> </span></p> |
| 810 <p id='t219' class='pln'> <span class='nam'>bot_name<
/span> <span class='key'>in</span> <span class='nam'>self</span><span class='op'
>.</span><span class='nam'>IOS_BUILDER_NAMES_FOR_COMPILE</span><span class='op'>
)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 811 <p id='t220' class='stm run hide_run'> <span class='nam'>err
or_lines</span> <span class='op'>=</span> <span class='op'>[</span><span class='
op'>]</span><span class='strut'> </span></p> |
| 812 <p id='t221' class='stm run hide_run'> <span class='key'>for
</span> <span class='nam'>line</span> <span class='key'>in</span> <span class='n
am'>reversed</span><span class='op'>(</span><span class='nam'>failure_log</span>
<span class='op'>.</span><span class='nam'>splitlines</span><span class='op'>(</
span><span class='op'>)</span><span class='op'>)</span><span class='op'>:</span>
<span class='strut'> </span></p> |
| 813 <p id='t222' class='stm run hide_run'> <span class='k
ey'>if</span> <span class='op'>(</span><span class='key'>not</span> <span class=
'nam'>failure_started</span> <span class='key'>and</span><span class='strut'>&nb
sp;</span></p> |
| 814 <p id='t223' class='pln'> <span class='
nam'>self</span><span class='op'>.</span><span class='nam'>ERROR_LINE_END_PATTER
N</span><span class='op'>.</span><span class='nam'>match</span><span class='op'>
(</span><span class='nam'>line</span><span class='op'>)</span><span class='op'>)
</span><span class='op'>:</span><span class='strut'> </span></p> |
| 815 <p id='t224' class='stm run hide_run'> <span c
lass='nam'>failure_started</span> <span class='op'>=</span> <span class='nam'>Tr
ue</span><span class='strut'> </span></p> |
| 816 <p id='t225' class='stm run hide_run'> <span c
lass='key'>continue</span><span class='strut'> </span></p> |
| 817 <p id='t226' class='pln'><span class='strut'> </span></p> |
| 818 <p id='t227' class='stm run hide_run'> <span class='k
ey'>if</span> <span class='nam'>failure_started</span><span class='op'>:</span><
span class='strut'> </span></p> |
| 819 <p id='t228' class='stm run hide_run'> <span c
lass='key'>if</span> <span class='nam'>line</span><span class='op'>.</span><span
class='nam'>startswith</span><span class='op'>(</span><span class='nam'>self</s
pan><span class='op'>.</span><span class='nam'>IOS_ERROR_LINE_START_PREFIX</span
><span class='op'>)</span><span class='op'>:</span><span class='strut'> </s
pan></p> |
| 820 <p id='t229' class='stm run hide_run'>
<span class='nam'>failure_started</span> <span class='op'>=</span> <span class='
nam'>False</span><span class='strut'> </span></p> |
| 821 <p id='t230' class='stm run hide_run'>
<span class='key'>for</span> <span class='nam'>l</span> <span class='key'>in</sp
an> <span class='nam'>error_lines</span><span class='op'>[</span><span class='op
'>:</span><span class='op'>-</span><span class='num'>4</span><span class='op'>]<
/span><span class='op'>:</span><span class='strut'> </span></p> |
| 822 <p id='t231' class='stm run hide_run'>
<span class='nam'>self</span><span class='op'>.</span><span class='nam'>E
xtractFiles</span><span class='op'>(</span><span class='nam'>l</span><span class
='op'>,</span> <span class='nam'>signal</span><span class='op'>)</span><span cla
ss='strut'> </span></p> |
| 823 <p id='t232' class='stm run hide_run'>
<span class='nam'>error_lines</span> <span class='op'>=</span> <span class='op'>
[</span><span class='op'>]</span><span class='strut'> </span></p> |
| 824 <p id='t233' class='pln'> <span class='key'>el
se</span><span class='op'>:</span><span class='strut'> </span></p> |
| 825 <p id='t234' class='stm run hide_run'>
<span class='nam'>error_lines</span><span class='op'>.</span><span class='nam'>a
ppend</span><span class='op'>(</span><span class='nam'>line</span><span class='o
p'>)</span><span class='strut'> </span></p> |
| 826 <p id='t235' class='pln'> <span class='key'>else</span><span class=
'op'>:</span><span class='strut'> </span></p> |
| 827 <p id='t236' class='stm run hide_run'> <span class='nam'>str
ict_regex</span> <span class='op'>=</span> <span class='nam'>waterfall_config</s
pan><span class='op'>.</span><span class='nam'>EnableStrictRegexForCompileLinkFa
ilures</span><span class='op'>(</span><span class='strut'> </span></p> |
| 828 <p id='t237' class='pln'> <span class='nam'>ma
ster_name</span><span class='op'>,</span> <span class='nam'>bot_name</span><span
class='op'>)</span><span class='strut'> </span></p> |
| 829 <p id='t238' class='stm run hide_run'> <span class='key'>for
</span> <span class='nam'>line</span> <span class='key'>in</span> <span class='n
am'>failure_log</span><span class='op'>.</span><span class='nam'>splitlines</spa
n><span class='op'>(</span><span class='op'>)</span><span class='op'>:</span><sp
an class='strut'> </span></p> |
| 830 <p id='t239' class='stm run hide_run'> <span class='k
ey'>if</span> <span class='nam'>line</span><span class='op'>.</span><span class=
'nam'>startswith</span><span class='op'>(</span><span class='nam'>self</span><sp
an class='op'>.</span><span class='nam'>FAILURE_START_LINE_PREFIX</span><span cl
ass='op'>)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 831 <p id='t240' class='stm run hide_run'> <span c
lass='key'>if</span> <span class='nam'>strict_regex</span><span class='op'>:</sp
an><span class='strut'> </span></p> |
| 832 <p id='t241' class='stm run hide_run'>
<span class='nam'>self</span><span class='op'>.</span><span class='nam'>ExtractF
ailedOutputNodes</span><span class='op'>(</span><span class='nam'>line</span><sp
an class='op'>,</span> <span class='nam'>signal</span><span class='op'>)</span><
span class='strut'> </span></p> |
| 833 <p id='t242' class='pln'> <span class='key'>el
se</span><span class='op'>:</span><span class='strut'> </span></p> |
| 834 <p id='t243' class='stm run hide_run'>
<span class='nam'>self</span><span class='op'>.</span><span class='nam'>GetFaile
dTarget</span><span class='op'>(</span><span class='nam'>line</span><span class=
'op'>,</span> <span class='nam'>signal</span><span class='op'>)</span><span clas
s='strut'> </span></p> |
| 835 <p id='t244' class='stm run hide_run'> <span c
lass='key'>if</span> <span class='key'>not</span> <span class='nam'>failure_star
ted</span><span class='op'>:</span><span class='strut'> </span></p> |
| 836 <p id='t245' class='stm run hide_run'>
<span class='nam'>failure_started</span> <span class='op'>=</span> <span class='
nam'>True</span><span class='strut'> </span></p> |
| 837 <p id='t246' class='exc'> <span class='key'>co
ntinue</span> <span class='com'># pragma: no cover</span><span class='stru
t'> </span></p> |
| 838 <p id='t247' class='stm run hide_run'> <span class='k
ey'>elif</span> <span class='nam'>self</span><span class='op'>.</span><span clas
s='nam'>FAILURE_WITH_ERROR_PATTERN</span><span class='op'>.</span><span class='n
am'>match</span><span class='op'>(</span><span class='nam'>line</span><span clas
s='op'>)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 839 <p id='t248' class='pln'> <span class='com'>#
It is possible the target and source file associated with a compile</span><span
class='strut'> </span></p> |
| 840 <p id='t249' class='pln'> <span class='com'>#
failure is logged outside a 'FAILED: ... 1 error generated' block,</span
><span class='strut'> </span></p> |
| 841 <p id='t250' class='pln'> <span class='com'>#
so extract regardless of failure_started.</span><span class='strut'> </span
></p> |
| 842 <p id='t251' class='stm run hide_run'> <span c
lass='key'>if</span> <span class='key'>not</span> <span class='nam'>strict_regex
</span><span class='op'>:</span><span class='strut'> </span></p> |
| 843 <p id='t252' class='stm run hide_run'>
<span class='nam'>self</span><span class='op'>.</span><span class='nam'>GetFaile
dTarget</span><span class='op'>(</span><span class='nam'>line</span><span class=
'op'>,</span> <span class='nam'>signal</span><span class='op'>)</span><span clas
s='strut'> </span></p> |
| 844 <p id='t253' class='stm run hide_run'> <span class='k
ey'>elif</span> <span class='nam'>failure_started</span> <span class='key'>and</
span> <span class='nam'>self</span><span class='op'>.</span><span class='nam'>ER
ROR_LINE_END_PATTERN</span><span class='op'>.</span><span class='nam'>match</spa
n><span class='op'>(</span><span class='nam'>line</span><span class='op'>)</span
><span class='op'>:</span><span class='strut'> </span></p> |
| 845 <p id='t254' class='stm run hide_run'> <span c
lass='nam'>failure_started</span> <span class='op'>=</span> <span class='nam'>Fa
lse</span><span class='strut'> </span></p> |
| 846 <p id='t255' class='exc'> <span class='key'>elif</spa
n> <span class='nam'>failure_started</span> <span class='key'>and</span> <span c
lass='nam'>line</span><span class='op'>.</span><span class='nam'>startswith</spa
n><span class='op'>(</span><span class='strut'> </span></p> |
| 847 <p id='t256' class='pln'> <span class='
nam'>self</span><span class='op'>.</span><span class='nam'>NINJA_FAILURE_END_LIN
E_PREFIX</span><span class='op'>)</span><span class='op'>:</span> <span cl
ass='com'># pragma: no cover</span><span class='strut'> </span></p> |
| 848 <p id='t257' class='exc'> <span class='key'>br
eak</span><span class='strut'> </span></p> |
| 849 <p id='t258' class='stm run hide_run'> <span class='k
ey'>if</span> <span class='nam'>failure_started</span> <span class='key'>or</spa
n> <span class='nam'>line</span><span class='op'>.</span><span class='nam'>start
swith</span><span class='op'>(</span><span class='nam'>self</span><span class='o
p'>.</span><span class='nam'>NINJA_ERROR_LINE_PREFIX</span><span class='op'>)</s
pan><span class='op'>:</span><span class='strut'> </span></p> |
| 850 <p id='t259' class='pln'> <span class='com'>#
either within the compile errors or is a ninja error.</span><span class='strut'>
</span></p> |
| 851 <p id='t260' class='stm run hide_run'> <span c
lass='nam'>self</span><span class='op'>.</span><span class='nam'>ExtractFiles</s
pan><span class='op'>(</span><span class='nam'>line</span><span class='op'>,</sp
an> <span class='nam'>signal</span><span class='op'>)</span><span class='strut'>
</span></p> |
| 852 <p id='t261' class='pln'><span class='strut'> </span></p> |
| 853 <p id='t262' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>signal</span><span class='strut'> </span></p> |
| 854 <p id='t263' class='pln'><span class='strut'> </span></p> |
| 855 <p id='t264' class='pln'><span class='strut'> </span></p> |
| 856 <p id='t265' class='stm run hide_run'><span class='key'>class</span> <span class
='nam'>CheckPermExtractor</span><span class='op'>(</span><span class='nam'>Extra
ctor</span><span class='op'>)</span><span class='op'>:</span><span class='strut'
> </span></p> |
| 857 <p id='t266' class='pln'> <span class='str'>"""For CheckPer
m, only extracts files."""</span><span class='strut'> </span
></p> |
| 858 <p id='t267' class='pln'><span class='strut'> </span></p> |
| 859 <p id='t268' class='stm run hide_run'> <span class='key'>def</span> <span
class='nam'>Extract</span><span class='op'>(</span><span class='nam'>self</span>
<span class='op'>,</span> <span class='nam'>failure_log</span><span class='op'>,
</span> <span class='op'>*</span><span class='nam'>_</span><span class='op'>)</s
pan><span class='op'>:</span><span class='strut'> </span></p> |
| 860 <p id='t269' class='stm run hide_run'> <span class='nam'>signal</sp
an> <span class='op'>=</span> <span class='nam'>FailureSignal</span><span class=
'op'>(</span><span class='op'>)</span><span class='strut'> </span></p> |
| 861 <p id='t270' class='pln'><span class='strut'> </span></p> |
| 862 <p id='t271' class='stm run hide_run'> <span class='key'>for</span>
<span class='nam'>line</span> <span class='key'>in</span> <span class='nam'>rev
ersed</span><span class='op'>(</span><span class='nam'>failure_log</span><span c
lass='op'>.</span><span class='nam'>splitlines</span><span class='op'>(</span><s
pan class='op'>)</span><span class='op'>)</span><span class='op'>:</span><span c
lass='strut'> </span></p> |
| 863 <p id='t272' class='exc'> <span class='key'>if</span> <span
class='nam'>line</span><span class='op'>.</span><span class='nam'>startswith</sp
an><span class='op'>(</span><span class='str'>'FAILED'</span><span class
='op'>)</span><span class='op'>:</span> <span class='com'># pragma: no cov
er</span><span class='strut'> </span></p> |
| 864 <p id='t273' class='pln'> <span class='com'># This is
where the failure message starts.</span><span class='strut'> </span></p> |
| 865 <p id='t274' class='pln'> <span class='com'># As we d
o reverse check, we should stop here.</span><span class='strut'> </span></p
> |
| 866 <p id='t275' class='exc'> <span class='key'>break</sp
an><span class='strut'> </span></p> |
| 867 <p id='t276' class='pln'><span class='strut'> </span></p> |
| 868 <p id='t277' class='pln'> <span class='com'># Extract files.
</span><span class='strut'> </span></p> |
| 869 <p id='t278' class='stm run hide_run'> <span class='key'>for
</span> <span class='nam'>match</span> <span class='key'>in</span> <span class='
nam'>extractor_util</span><span class='op'>.</span><span class='nam'>FILE_PATH_L
INE_PATTERN</span><span class='op'>.</span><span class='nam'>finditer</span><spa
n class='op'>(</span><span class='nam'>line</span><span class='op'>)</span><span
class='op'>:</span><span class='strut'> </span></p> |
| 870 <p id='t279' class='stm run hide_run'> <span class='n
am'>file_path</span><span class='op'>,</span> <span class='nam'>line_number</spa
n> <span class='op'>=</span> <span class='nam'>match</span><span class='op'>.</s
pan><span class='nam'>groups</span><span class='op'>(</span><span class='op'>)</
span><span class='strut'> </span></p> |
| 871 <p id='t280' class='stm run hide_run'> <span class='n
am'>signal</span><span class='op'>.</span><span class='nam'>AddFile</span><span
class='op'>(</span><span class='nam'>extractor_util</span><span class='op'>.</sp
an><span class='nam'>NormalizeFilePath</span><span class='op'>(</span><span clas
s='nam'>file_path</span><span class='op'>)</span><span class='op'>,</span><span
class='strut'> </span></p> |
| 872 <p id='t281' class='pln'>
<span class='nam'>line_number</span><span class='op'
>)</span><span class='strut'> </span></p> |
| 873 <p id='t282' class='pln'><span class='strut'> </span></p> |
| 874 <p id='t283' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>signal</span><span class='strut'> </span></p> |
| 875 <p id='t284' class='pln'><span class='strut'> </span></p> |
| 876 <p id='t285' class='pln'><span class='strut'> </span></p> |
| 877 <p id='t286' class='stm run hide_run'><span class='key'>class</span> <span class
='nam'>CheckSizesExtractor</span><span class='op'>(</span><span class='nam'>Extr
actor</span><span class='op'>)</span><span class='op'>:</span><span class='strut
'> </span></p> |
| 878 <p id='t287' class='pln'> <span class='str'>"""For Sizes, o
nly extract files."""</span><span class='strut'> </span></p> |
| 879 <p id='t288' class='stm run hide_run'> <span class='nam'>BEGINNING_MARKER<
/span> <span class='op'>=</span> <span class='str'>'# Static initializers in
'</span><span class='strut'> </span></p> |
| 880 <p id='t289' class='stm run hide_run'> <span class='nam'>HINT_MARKER</span
> <span class='op'>=</span> <span class='str'>'# HINT:'</span><span clas
s='strut'> </span></p> |
| 881 <p id='t290' class='stm run hide_run'> <span class='nam'>END_MARKER</span>
<span class='op'>=</span> <span class='nam'>re</span><span class='op'>.</span><
span class='nam'>compile</span><span class='op'>(</span><span class='str'>'#
Found \\d+ static initializers in \\d+ files?\\.'</span><span class='op'>)<
/span><span class='strut'> </span></p> |
| 882 <p id='t291' class='pln'><span class='strut'> </span></p> |
| 883 <p id='t292' class='stm run hide_run'> <span class='key'>def</span> <span
class='nam'>Extract</span><span class='op'>(</span><span class='nam'>self</span>
<span class='op'>,</span> <span class='nam'>failure_log</span><span class='op'>,
</span> <span class='op'>*</span><span class='nam'>_</span><span class='op'>)</s
pan><span class='op'>:</span><span class='strut'> </span></p> |
| 884 <p id='t293' class='stm run hide_run'> <span class='nam'>signal</sp
an> <span class='op'>=</span> <span class='nam'>FailureSignal</span><span class=
'op'>(</span><span class='op'>)</span><span class='strut'> </span></p> |
| 885 <p id='t294' class='stm run hide_run'> <span class='nam'>failure_st
arted</span> <span class='op'>=</span> <span class='nam'>False</span><span class
='strut'> </span></p> |
| 886 <p id='t295' class='pln'><span class='strut'> </span></p> |
| 887 <p id='t296' class='stm run hide_run'> <span class='key'>for</span>
<span class='nam'>line</span> <span class='key'>in</span> <span class='nam'>fai
lure_log</span><span class='op'>.</span><span class='nam'>splitlines</span><span
class='op'>(</span><span class='op'>)</span><span class='op'>:</span><span clas
s='strut'> </span></p> |
| 888 <p id='t297' class='stm run hide_run'> <span class='key'>if<
/span> <span class='nam'>line</span><span class='op'>.</span><span class='nam'>s
tartswith</span><span class='op'>(</span><span class='nam'>self</span><span clas
s='op'>.</span><span class='nam'>BEGINNING_MARKER</span><span class='op'>)</span
><span class='op'>:</span><span class='strut'> </span></p> |
| 889 <p id='t298' class='stm run hide_run'> <span class='n
am'>failure_started</span> <span class='op'>=</span> <span class='nam'>True</spa
n><span class='strut'> </span></p> |
| 890 <p id='t299' class='stm run hide_run'> <span class='k
ey'>continue</span><span class='strut'> </span></p> |
| 891 <p id='t300' class='pln'><span class='strut'> </span></p> |
| 892 <p id='t301' class='pln'> <span class='com'># Skip hints.</s
pan><span class='strut'> </span></p> |
| 893 <p id='t302' class='stm run hide_run'> <span class='key'>if<
/span> <span class='nam'>line</span><span class='op'>.</span><span class='nam'>s
tartswith</span><span class='op'>(</span><span class='nam'>self</span><span clas
s='op'>.</span><span class='nam'>HINT_MARKER</span><span class='op'>)</span><spa
n class='op'>:</span><span class='strut'> </span></p> |
| 894 <p id='t303' class='stm run hide_run'> <span class='k
ey'>continue</span><span class='strut'> </span></p> |
| 895 <p id='t304' class='pln'><span class='strut'> </span></p> |
| 896 <p id='t305' class='stm run hide_run'> <span class='key'>if<
/span> <span class='nam'>self</span><span class='op'>.</span><span class='nam'>E
ND_MARKER</span><span class='op'>.</span><span class='nam'>match</span><span cla
ss='op'>(</span><span class='nam'>line</span><span class='op'>)</span><span clas
s='op'>:</span><span class='strut'> </span></p> |
| 897 <p id='t306' class='stm run hide_run'> <span class='n
am'>failure_started</span> <span class='op'>=</span> <span class='nam'>False</sp
an><span class='strut'> </span></p> |
| 898 <p id='t307' class='stm run hide_run'> <span class='k
ey'>continue</span><span class='strut'> </span></p> |
| 899 <p id='t308' class='pln'><span class='strut'> </span></p> |
| 900 <p id='t309' class='pln'> <span class='com'># Begin extracti
ng file names.</span><span class='strut'> </span></p> |
| 901 <p id='t310' class='stm run hide_run'> <span class='key'>if<
/span> <span class='nam'>failure_started</span><span class='op'>:</span><span cl
ass='strut'> </span></p> |
| 902 <p id='t311' class='stm run hide_run'> <span class='n
am'>self</span><span class='op'>.</span><span class='nam'>ExtractFiles</span><sp
an class='op'>(</span><span class='nam'>line</span><span class='op'>,</span> <sp
an class='nam'>signal</span><span class='op'>)</span><span class='strut'> <
/span></p> |
| 903 <p id='t312' class='pln'><span class='strut'> </span></p> |
| 904 <p id='t313' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>signal</span><span class='strut'> </span></p> |
| 905 <p id='t314' class='pln'><span class='strut'> </span></p> |
| 906 <p id='t315' class='pln'><span class='strut'> </span></p> |
| 907 <p id='t316' class='stm run hide_run'><span class='key'>class</span> <span class
='nam'>AndroidJavaTestExtractor</span><span class='op'>(</span><span class='nam'
>Extractor</span><span class='op'>)</span><span class='op'>:</span><span class='
strut'> </span></p> |
| 908 <p id='t317' class='pln'> <span class='str'>"""An extractor
for java-based Android tests.</span><span class='strut'> </span></p> |
| 909 <p id='t318' class='pln'><span class='strut'> </span></p> |
| 910 <p id='t319' class='pln'><span class='str'> Note this extractor sho
uld not be used directly, but contains shared</span><span class='strut'> </
span></p> |
| 911 <p id='t320' class='pln'><span class='str'> constants and functions
to be used by its children classes.</span><span class='strut'> </span></p> |
| 912 <p id='t321' class='pln'><span class='str'> """</span><span
class='strut'> </span></p> |
| 913 <p id='t322' class='pln'> <span class='com'># White-list of java packages
to consider.</span><span class='strut'> </span></p> |
| 914 <p id='t323' class='stm run hide_run'> <span class='nam'>JAVA_PACKAGES_TO_
CONSIDER</span> <span class='op'>=</span> <span class='op'>[</span><span class='
str'>'org.chromium.'</span><span class='op'>]</span><span class='strut'>
</span></p> |
| 915 <p id='t324' class='pln'><span class='strut'> </span></p> |
| 916 <p id='t325' class='stm run hide_run'> <span class='nam'>JAVA_TEST_NAME_PA
TTERN</span> <span class='op'>=</span> <span class='nam'>re</span><span class='o
p'>.</span><span class='nam'>compile</span><span class='op'>(</span><span class=
'strut'> </span></p> |
| 917 <p id='t326' class='pln'> <span class='str'>r'((?P<pa
ckage_classname>(?:\w+(?:\$\w+)?\.)+)(?P<method><?\w+>?))'</s
pan><span class='op'>)</span><span class='strut'> </span></p> |
| 918 <p id='t327' class='pln'><span class='strut'> </span></p> |
| 919 <p id='t328' class='stm run hide_run'> <span class='nam'>JAVA_STACK_TRACE_
START_MARKERS</span> <span class='op'>=</span> <span class='op'>[</span><span cl
ass='str'>'Caused by:'</span><span class='op'>]</span><span class='strut
'> </span></p> |
| 920 <p id='t329' class='pln'><span class='strut'> </span></p> |
| 921 <p id='t330' class='stm run hide_run'> <span class='key'>def</span> <span
class='nam'>_IsStartOfStackTrace</span><span class='op'>(</span><span class='nam
'>self</span><span class='op'>,</span> <span class='nam'>line</span><span class=
'op'>)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 922 <p id='t331' class='stm run hide_run'> <span class='key'>for</span>
<span class='nam'>start_marker</span> <span class='key'>in</span> <span class='
nam'>self</span><span class='op'>.</span><span class='nam'>JAVA_STACK_TRACE_STAR
T_MARKERS</span><span class='op'>:</span><span class='strut'> </span></p> |
| 923 <p id='t332' class='stm run hide_run'> <span class='key'>if<
/span> <span class='nam'>line</span><span class='op'>.</span><span class='nam'>s
tartswith</span><span class='op'>(</span><span class='nam'>start_marker</span><s
pan class='op'>)</span><span class='op'>:</span><span class='strut'> </span
></p> |
| 924 <p id='t333' class='stm run hide_run'> <span class='k
ey'>return</span> <span class='nam'>True</span><span class='strut'> </span>
</p> |
| 925 <p id='t334' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>False</span><span class='strut'> </span></p> |
| 926 <p id='t335' class='pln'><span class='strut'> </span></p> |
| 927 <p id='t336' class='stm run hide_run'> <span class='key'>def</span> <span
class='nam'>_InWhitelist</span><span class='op'>(</span><span class='nam'>self</
span><span class='op'>,</span> <span class='nam'>package_filename</span><span cl
ass='op'>)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 928 <p id='t337' class='exc'> <span class='key'>if</span> <span class='
nam'>package_filename</span><span class='op'>:</span> <span class='com'>#
pragma: no cover</span><span class='strut'> </span></p> |
| 929 <p id='t338' class='exc'> <span class='key'>for</span> <span
class='nam'>package</span> <span class='key'>in</span> <span class='nam'>self</
span><span class='op'>.</span><span class='nam'>JAVA_PACKAGES_TO_CONSIDER</span>
<span class='op'>:</span><span class='strut'> </span></p> |
| 930 <p id='t339' class='exc'> <span class='key'>if</span>
<span class='nam'>package_filename</span><span class='op'>.</span><span class='
nam'>startswith</span><span class='op'>(</span><span class='nam'>package</span><
span class='op'>)</span><span class='op'>:</span><span class='strut'> </spa
n></p> |
| 931 <p id='t340' class='exc'> <span class='key'>re
turn</span> <span class='nam'>True</span><span class='strut'> </span></p> |
| 932 <p id='t341' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>False</span><span class='strut'> </span></p> |
| 933 <p id='t342' class='pln'><span class='strut'> </span></p> |
| 934 <p id='t343' class='stm run hide_run'> <span class='key'>def</span> <span
class='nam'>ExtractJavaFileMatch</span><span class='op'>(</span><span class='nam
'>self</span><span class='op'>,</span> <span class='nam'>match</span><span class
='op'>,</span> <span class='nam'>signal</span><span class='op'>)</span><span cla
ss='op'>:</span><span class='strut'> </span></p> |
| 935 <p id='t344' class='stm run hide_run'> <span class='nam'>match_dict
</span> <span class='op'>=</span> <span class='nam'>match</span><span class='op'
>.</span><span class='nam'>groupdict</span><span class='op'>(</span><span class=
'op'>)</span><span class='strut'> </span></p> |
| 936 <p id='t345' class='stm run hide_run'> <span class='nam'>package_cl
assname</span> <span class='op'>=</span> <span class='nam'>match_dict</span><spa
n class='op'>.</span><span class='nam'>get</span><span class='op'>(</span><span
class='str'>'package_classname'</span><span class='op'>)</span><span cla
ss='strut'> </span></p> |
| 937 <p id='t346' class='stm run hide_run'> <span class='nam'>filename</
span> <span class='op'>=</span> <span class='nam'>match_dict</span><span class='
op'>.</span><span class='nam'>get</span><span class='op'>(</span><span class='st
r'>'filename'</span><span class='op'>)</span><span class='strut'> <
/span></p> |
| 938 <p id='t347' class='stm run hide_run'> <span class='nam'>line_numbe
r</span> <span class='op'>=</span> <span class='nam'>match_dict</span><span clas
s='op'>.</span><span class='nam'>get</span><span class='op'>(</span><span class=
'str'>'line_number'</span><span class='op'>)</span><span class='strut'>&
nbsp;</span></p> |
| 939 <p id='t348' class='pln'><span class='strut'> </span></p> |
| 940 <p id='t349' class='stm run hide_run'> <span class='key'>if</span>
<span class='nam'>self</span><span class='op'>.</span><span class='nam'>_InWhite
list</span><span class='op'>(</span><span class='nam'>package_classname</span><s
pan class='op'>)</span><span class='op'>:</span><span class='strut'> </span
></p> |
| 941 <p id='t350' class='stm run hide_run'> <span class='key'>if<
/span> <span class='nam'>filename</span><span class='op'>:</span><span class='st
rut'> </span></p> |
| 942 <p id='t351' class='stm run hide_run'> <span class='n
am'>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><span c
lass='nam'>join</span><span class='op'>(</span><span class='strut'> </span>
</p> |
| 943 <p id='t352' class='pln'> <span class='
str'>'/'</span><span class='op'>.</span><span class='nam'>join</span><sp
an class='op'>(</span><span class='nam'>package_classname</span><span class='op'
>.</span><span class='nam'>split</span><span class='op'>(</span><span class='str
'>'.'</span><span class='op'>)</span><span class='op'>[</span><span clas
s='op'>:</span><span class='op'>-</span><span class='num'>2</span><span class='o
p'>]</span><span class='op'>)</span><span class='op'>,</span> <span class='nam'>
filename</span><span class='op'>)</span><span class='strut'> </span></p> |
| 944 <p id='t353' class='pln'> <span class='key'>else</span><span
class='op'>:</span><span class='strut'> </span></p> |
| 945 <p id='t354' class='stm run hide_run'> <span class='n
am'>file_path</span> <span class='op'>=</span> <span class='str'>'/'</sp
an><span class='op'>.</span><span class='nam'>join</span><span class='op'>(</spa
n><span class='nam'>package_classname</span><span class='op'>.</span><span class
='nam'>split</span><span class='op'>(</span><span class='str'>'.'</span>
<span class='op'>)</span><span class='op'>[</span><span class='op'>:</span><span
class='op'>-</span><span class='num'>1</span><span class='op'>]</span><span cla
ss='op'>)</span> <span class='op'>+</span> <span class='str'>'.java'</sp
an><span class='strut'> </span></p> |
| 946 <p id='t355' class='stm run hide_run'> <span class='nam'>sig
nal</span><span class='op'>.</span><span class='nam'>AddFile</span><span class='
op'>(</span><span class='nam'>extractor_util</span><span class='op'>.</span><spa
n class='nam'>NormalizeFilePath</span><span class='op'>(</span><span class='nam'
>file_path</span><span class='op'>)</span><span class='op'>,</span> <span class=
'nam'>line_number</span><span class='op'>)</span><span class='strut'> </spa
n></p> |
| 947 <p id='t356' class='pln'><span class='strut'> </span></p> |
| 948 <p id='t357' class='stm run hide_run'> <span class='key'>def</span> <span
class='nam'>Extract</span><span class='op'>(</span><span class='nam'>self</span>
<span class='op'>,</span> <span class='nam'>failure_log</span><span class='op'>,
</span> <span class='op'>*</span><span class='nam'>_</span><span class='op'>)</s
pan><span class='op'>:</span><span class='strut'> </span></p> |
| 949 <p id='t358' class='exc'> <span class='key'>raise</span> <span clas
s='nam'>NotImplementedError</span><span class='op'>(</span><span class='strut'>&
nbsp;</span></p> |
| 950 <p id='t359' class='pln'> <span class='str'>'Extr
act should be implemented in the child class.'</span><span class='op'>)</spa
n> <span class='com'># pragma: no cover</span><span class='strut'> </
span></p> |
| 951 <p id='t360' class='pln'><span class='strut'> </span></p> |
| 952 <p id='t361' class='pln'><span class='strut'> </span></p> |
| 953 <p id='t362' class='stm run hide_run'><span class='key'>class</span> <span class
='nam'>InstrumentationTestExtractor</span><span class='op'>(</span><span class='
nam'>AndroidJavaTestExtractor</span><span class='op'>)</span><span class='op'>:<
/span><span class='strut'> </span></p> |
| 954 <p id='t363' class='pln'> <span class='str'>"""For Instrume
ntation tests."""</span><span class='strut'> </span></p> |
| 955 <p id='t364' class='pln'> <span class='com'># Beginning marker for Java st
ack trace.</span><span class='strut'> </span></p> |
| 956 <p id='t365' class='stm run hide_run'> <span class='nam'>JAVA_STACK_TRACE_
BEGINNING_MARKER</span> <span class='op'>=</span> <span class='nam'>re</span><sp
an class='op'>.</span><span class='nam'>compile</span><span class='op'>(</span><
span class='str'>r'^.*\[FAIL] .*\#.*:'</span><span class='op'>)</span><s
pan class='strut'> </span></p> |
| 957 <p id='t366' class='pln'><span class='strut'> </span></p> |
| 958 <p id='t367' class='stm run hide_run'> <span class='key'>def</span> <span
class='nam'>Extract</span><span class='op'>(</span><span class='nam'>self</span>
<span class='op'>,</span> <span class='nam'>failure_log</span><span class='op'>,
</span> <span class='op'>*</span><span class='nam'>_</span><span class='op'>)</s
pan><span class='op'>:</span><span class='strut'> </span></p> |
| 959 <p id='t368' class='stm run hide_run'> <span class='nam'>signal</sp
an> <span class='op'>=</span> <span class='nam'>FailureSignal</span><span class=
'op'>(</span><span class='op'>)</span><span class='strut'> </span></p> |
| 960 <p id='t369' class='stm run hide_run'> <span class='nam'>failure_st
arted</span> <span class='op'>=</span> <span class='nam'>False</span><span class
='strut'> </span></p> |
| 961 <p id='t370' class='stm run hide_run'> <span class='nam'>in_failure
_stacktrace_within_range</span> <span class='op'>=</span> <span class='nam'>Fals
e</span><span class='strut'> </span></p> |
| 962 <p id='t371' class='stm run hide_run'> <span class='nam'>java_stack
_frame_index</span> <span class='op'>=</span> <span class='num'>0</span><span cl
ass='strut'> </span></p> |
| 963 <p id='t372' class='pln'><span class='strut'> </span></p> |
| 964 <p id='t373' class='exc'> <span class='key'>for</span> <span class=
'nam'>line</span> <span class='key'>in</span> <span class='nam'>failure_log</spa
n><span class='op'>.</span><span class='nam'>splitlines</span><span class='op'>(
</span><span class='op'>)</span><span class='op'>:</span> <span class='com
'># pragma: no cover</span><span class='strut'> </span></p> |
| 965 <p id='t374' class='exc'> <span class='key'>if</span> <span
class='key'>not</span> <span class='nam'>failure_started</span> <span class='key
'>and</span> <span class='nam'>line</span><span class='op'>.</span><span class='
nam'>endswith</span><span class='op'>(</span><span class='str'>'Detailed Log
s'</span><span class='op'>)</span><span class='op'>:</span><span class='stru
t'> </span></p> |
| 966 <p id='t375' class='exc'> <span class='nam'>failure_s
tarted</span> <span class='op'>=</span> <span class='nam'>True</span><span class
='strut'> </span></p> |
| 967 <p id='t376' class='exc'> <span class='key'>continue<
/span><span class='strut'> </span></p> |
| 968 <p id='t377' class='pln'><span class='strut'> </span></p> |
| 969 <p id='t378' class='exc'> <span class='key'>if</span> <span
class='nam'>failure_started</span><span class='op'>:</span><span class='strut'>&
nbsp;</span></p> |
| 970 <p id='t379' class='exc'> <span class='key'>if</span>
<span class='op'>(</span><span class='key'>not</span> <span class='nam'>in_fail
ure_stacktrace_within_range</span> <span class='key'>and</span><span class='stru
t'> </span></p> |
| 971 <p id='t380' class='pln'> <span class='
nam'>self</span><span class='op'>.</span><span class='nam'>JAVA_STACK_TRACE_BEGI
NNING_MARKER</span><span class='op'>.</span><span class='nam'>match</span><span
class='op'>(</span><span class='nam'>line</span><span class='op'>)</span><span c
lass='op'>)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 972 <p id='t381' class='exc'> <span class='nam'>in
_failure_stacktrace_within_range</span> <span class='op'>=</span> <span class='n
am'>True</span><span class='strut'> </span></p> |
| 973 <p id='t382' class='exc'> <span class='nam'>ja
va_stack_frame_index</span> <span class='op'>=</span> <span class='num'>0</span>
<span class='strut'> </span></p> |
| 974 <p id='t383' class='exc'> <span class='key'>co
ntinue</span><span class='strut'> </span></p> |
| 975 <p id='t384' class='pln'><span class='strut'> </span></p> |
| 976 <p id='t385' class='exc'> <span class='key'>if</span>
<span class='nam'>line</span><span class='op'>.</span><span class='nam'>endswit
h</span><span class='op'>(</span><span class='str'>'Summary'</span><span
class='op'>)</span><span class='op'>:</span><span class='strut'> </span></
p> |
| 977 <p id='t386' class='exc'> <span class='key'>br
eak</span><span class='strut'> </span></p> |
| 978 <p id='t387' class='pln'><span class='strut'> </span></p> |
| 979 <p id='t388' class='exc'> <span class='key'>if</span>
<span class='nam'>in_failure_stacktrace_within_range</span><span class='op'>:</
span><span class='strut'> </span></p> |
| 980 <p id='t389' class='exc'> <span class='nam'>ma
tch</span> <span class='op'>=</span> <span class='nam'>extractor_util</span><spa
n class='op'>.</span><span class='nam'>JAVA_STACK_TRACE_FRAME_PATTERN</span><spa
n class='op'>.</span><span class='nam'>search</span><span class='op'>(</span><sp
an class='nam'>line</span><span class='op'>)</span><span class='strut'> </s
pan></p> |
| 981 <p id='t390' class='pln'><span class='strut'> </span></p> |
| 982 <p id='t391' class='exc'> <span class='key'>if
</span> <span class='nam'>match</span><span class='op'>:</span><span class='stru
t'> </span></p> |
| 983 <p id='t392' class='exc'> <span class='
nam'>self</span><span class='op'>.</span><span class='nam'>ExtractJavaFileMatch<
/span><span class='op'>(</span><span class='nam'>match</span><span class='op'>,<
/span> <span class='nam'>signal</span><span class='op'>)</span><span class='stru
t'> </span></p> |
| 984 <p id='t393' class='exc'> <span class='
nam'>java_stack_frame_index</span> <span class='op'>+=</span> <span class='num'>
1</span><span class='strut'> </span></p> |
| 985 <p id='t394' class='pln'><span class='strut'> </span></p> |
| 986 <p id='t395' class='pln'> <span class='
com'># Only extract the top several frames of each stack.</span><span class='str
ut'> </span></p> |
| 987 <p id='t396' class='exc'> <span class='
key'>if</span> <span class='op'>(</span><span class='nam'>java_stack_frame_index
</span> <span class='op'>>=</span><span class='strut'> </span></p> |
| 988 <p id='t397' class='pln'>
<span class='nam'>extractor_util</span><span class='op'>.</span><span class='na
m'>JAVA_MAXIMUM_NUMBER_STACK_FRAMES</span><span class='op'>)</span><span class='
op'>:</span><span class='strut'> </span></p> |
| 989 <p id='t398' class='exc'> <span
class='nam'>in_failure_stacktrace_within_range</span> <span class='op'>=</span>
<span class='nam'>False</span><span class='strut'> </span></p> |
| 990 <p id='t399' class='pln'><span class='strut'> </span></p> |
| 991 <p id='t400' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>signal</span><span class='strut'> </span></p> |
| 992 <p id='t401' class='pln'><span class='strut'> </span></p> |
| 993 <p id='t402' class='pln'><span class='strut'> </span></p> |
| 994 <p id='t403' class='stm run hide_run'><span class='key'>class</span> <span class
='nam'>JunitTestExtractor</span><span class='op'>(</span><span class='nam'>Andro
idJavaTestExtractor</span><span class='op'>)</span><span class='op'>:</span><spa
n class='strut'> </span></p> |
| 995 <p id='t404' class='pln'> <span class='str'>"""For Junit te
sts."""</span><span class='strut'> </span></p> |
| 996 <p id='t405' class='stm run hide_run'> <span class='nam'>TEST_START_MARKER
</span> <span class='op'>=</span> <span class='str'>'[ RUN &nbs
p; ]'</span><span class='strut'> </span></p> |
| 997 <p id='t406' class='stm run hide_run'> <span class='nam'>TEST_FAILED_MARKE
R</span> <span class='op'>=</span> <span class='str'>'[ FAILED ]
'</span><span class='strut'> </span></p> |
| 998 <p id='t407' class='pln'><span class='strut'> </span></p> |
| 999 <p id='t408' class='stm run hide_run'> <span class='key'>def</span> <span
class='nam'>ProcessTestFailure</span><span class='op'>(</span><span class='nam'>
self</span><span class='op'>,</span> <span class='nam'>log_lines</span><span cla
ss='op'>,</span> <span class='nam'>signal</span><span class='op'>)</span><span c
lass='op'>:</span><span class='strut'> </span></p> |
| 1000 <p id='t409' class='stm run hide_run'> <span class='nam'>in_failure
_stacktrace_within_range</span> <span class='op'>=</span> <span class='nam'>Fals
e</span><span class='strut'> </span></p> |
| 1001 <p id='t410' class='stm run hide_run'> <span class='nam'>java_stack
_frame_index</span> <span class='op'>=</span> <span class='num'>0</span><span cl
ass='strut'> </span></p> |
| 1002 <p id='t411' class='pln'><span class='strut'> </span></p> |
| 1003 <p id='t412' class='pln'> <span class='com'># Find first failure st
acktrace.</span><span class='strut'> </span></p> |
| 1004 <p id='t413' class='stm run hide_run'> <span class='nam'>index</spa
n> <span class='op'>=</span> <span class='num'>0</span><span class='strut'> 
;</span></p> |
| 1005 <p id='t414' class='stm run hide_run'> <span class='nam'>end_index<
/span> <span class='op'>=</span> <span class='nam'>len</span><span class='op'>(<
/span><span class='nam'>log_lines</span><span class='op'>)</span><span class='st
rut'> </span></p> |
| 1006 <p id='t415' class='exc'> <span class='key'>while</span> <span clas
s='nam'>index</span> <span class='op'><</span> <span class='nam'>end_index</s
pan><span class='op'>:</span> <span class='com'># pragma: no cover</span><
span class='strut'> </span></p> |
| 1007 <p id='t416' class='exc'> <span class='nam'>line</span> <spa
n class='op'>=</span> <span class='nam'>log_lines</span><span class='op'>[</span
><span class='nam'>index</span><span class='op'>]</span><span class='strut'>&nbs
p;</span></p> |
| 1008 <p id='t417' class='exc'> <span class='key'>if</span> <span
class='nam'>extractor_util</span><span class='op'>.</span><span class='nam'>JAVA
_STACK_TRACE_FRAME_PATTERN</span><span class='op'>.</span><span class='nam'>sear
ch</span><span class='op'>(</span><span class='nam'>line</span><span class='op'>
)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 1009 <p id='t418' class='exc'> <span class='nam'>in_failur
e_stacktrace_within_range</span> <span class='op'>=</span> <span class='nam'>Tru
e</span><span class='strut'> </span></p> |
| 1010 <p id='t419' class='exc'> <span class='key'>break</sp
an><span class='strut'> </span></p> |
| 1011 <p id='t420' class='exc'> <span class='nam'>index</span> <sp
an class='op'>+=</span> <span class='num'>1</span><span class='strut'> </sp
an></p> |
| 1012 <p id='t421' class='pln'><span class='strut'> </span></p> |
| 1013 <p id='t422' class='exc'> <span class='key'>for</span> <span class=
'nam'>line</span> <span class='key'>in</span> <span class='nam'>log_lines</span>
<span class='op'>[</span><span class='nam'>index</span><span class='op'>:</span>
<span class='op'>]</span><span class='op'>:</span> <span class='com'># pra
gma: no cover</span><span class='strut'> </span></p> |
| 1014 <p id='t423' class='exc'> <span class='key'>if</span> <span
class='nam'>in_failure_stacktrace_within_range</span><span class='op'>:</span><s
pan class='strut'> </span></p> |
| 1015 <p id='t424' class='exc'> <span class='nam'>match</sp
an> <span class='op'>=</span> <span class='nam'>extractor_util</span><span class
='op'>.</span><span class='nam'>JAVA_STACK_TRACE_FRAME_PATTERN</span><span class
='op'>.</span><span class='nam'>search</span><span class='op'>(</span><span clas
s='nam'>line</span><span class='op'>)</span><span class='strut'> </span></p
> |
| 1016 <p id='t425' class='pln'><span class='strut'> </span></p> |
| 1017 <p id='t426' class='exc'> <span class='key'>if</span>
<span class='nam'>match</span><span class='op'>:</span><span class='strut'>&nbs
p;</span></p> |
| 1018 <p id='t427' class='exc'> <span class='nam'>se
lf</span><span class='op'>.</span><span class='nam'>ExtractJavaFileMatch</span><
span class='op'>(</span><span class='nam'>match</span><span class='op'>,</span>
<span class='nam'>signal</span><span class='op'>)</span><span class='strut'>&nbs
p;</span></p> |
| 1019 <p id='t428' class='exc'> <span class='nam'>ja
va_stack_frame_index</span> <span class='op'>+=</span> <span class='num'>1</span
><span class='strut'> </span></p> |
| 1020 <p id='t429' class='pln'><span class='strut'> </span></p> |
| 1021 <p id='t430' class='pln'> <span class='com'>#
Only extract the top several frames of each stack.</span><span class='strut'>&nb
sp;</span></p> |
| 1022 <p id='t431' class='exc'> <span class='key'>if
</span> <span class='op'>(</span><span class='nam'>java_stack_frame_index</span>
<span class='op'>>=</span><span class='strut'> </span></p> |
| 1023 <p id='t432' class='pln'> <span
class='nam'>extractor_util</span><span class='op'>.</span><span class='nam'>JAVA
_MAXIMUM_NUMBER_STACK_FRAMES</span><span class='op'>)</span><span class='op'>:</
span><span class='strut'> </span></p> |
| 1024 <p id='t433' class='exc'> <span class='
nam'>in_failure_stacktrace_within_range</span> <span class='op'>=</span> <span c
lass='nam'>False</span><span class='strut'> </span></p> |
| 1025 <p id='t434' class='pln'><span class='strut'> </span></p> |
| 1026 <p id='t435' class='exc'> <span class='key'>if</span> <span
class='nam'>self</span><span class='op'>.</span><span class='nam'>_IsStartOfStac
kTrace</span><span class='op'>(</span><span class='nam'>line</span><span class='
op'>)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 1027 <p id='t436' class='exc'> <span class='nam'>in_failur
e_stacktrace_within_range</span> <span class='op'>=</span> <span class='nam'>Tru
e</span><span class='strut'> </span></p> |
| 1028 <p id='t437' class='exc'> <span class='nam'>java_stac
k_frame_index</span> <span class='op'>=</span> <span class='num'>0</span><span c
lass='strut'> </span></p> |
| 1029 <p id='t438' class='exc'> <span class='key'>continue<
/span><span class='strut'> </span></p> |
| 1030 <p id='t439' class='pln'><span class='strut'> </span></p> |
| 1031 <p id='t440' class='stm run hide_run'> <span class='key'>def</span> <span
class='nam'>Extract</span><span class='op'>(</span><span class='nam'>self</span>
<span class='op'>,</span> <span class='nam'>failure_log</span><span class='op'>,
</span> <span class='op'>*</span><span class='nam'>_</span><span class='op'>)</s
pan><span class='op'>:</span><span class='strut'> </span></p> |
| 1032 <p id='t441' class='stm run hide_run'> <span class='nam'>signal</sp
an> <span class='op'>=</span> <span class='nam'>FailureSignal</span><span class=
'op'>(</span><span class='op'>)</span><span class='strut'> </span></p> |
| 1033 <p id='t442' class='stm run hide_run'> <span class='nam'>log_lines<
/span> <span class='op'>=</span> <span class='nam'>failure_log</span><span class
='op'>.</span><span class='nam'>splitlines</span><span class='op'>(</span><span
class='op'>)</span><span class='strut'> </span></p> |
| 1034 <p id='t443' class='pln'><span class='strut'> </span></p> |
| 1035 <p id='t444' class='stm run hide_run'> <span class='nam'>index</spa
n> <span class='op'>=</span> <span class='num'>0</span><span class='strut'> 
;</span></p> |
| 1036 <p id='t445' class='stm run hide_run'> <span class='nam'>start</spa
n> <span class='op'>=</span> <span class='nam'>index</span><span class='strut'>&
nbsp;</span></p> |
| 1037 <p id='t446' class='stm run hide_run'> <span class='nam'>end</span>
<span class='op'>=</span> <span class='nam'>len</span><span class='op'>(</span>
<span class='nam'>log_lines</span><span class='op'>)</span><span class='strut'>&
nbsp;</span></p> |
| 1038 <p id='t447' class='pln'><span class='strut'> </span></p> |
| 1039 <p id='t448' class='exc'> <span class='key'>while</span> <span clas
s='nam'>index</span> <span class='op'><</span> <span class='nam'>end</span><s
pan class='op'>:</span> <span class='com'># pragma: no cover</span><span c
lass='strut'> </span></p> |
| 1040 <p id='t449' class='exc'> <span class='nam'>line</span> <spa
n class='op'>=</span> <span class='nam'>log_lines</span><span class='op'>[</span
><span class='nam'>index</span><span class='op'>]</span><span class='strut'>&nbs
p;</span></p> |
| 1041 <p id='t450' class='exc'> <span class='key'>if</span> <span
class='nam'>line</span><span class='op'>.</span><span class='nam'>startswith</sp
an><span class='op'>(</span><span class='nam'>self</span><span class='op'>.</spa
n><span class='nam'>TEST_START_MARKER</span><span class='op'>)</span><span class
='op'>:</span><span class='strut'> </span></p> |
| 1042 <p id='t451' class='exc'> <span class='nam'>start</sp
an> <span class='op'>=</span> <span class='nam'>index</span> <span class='op'>+<
/span> <span class='num'>1</span><span class='strut'> </span></p> |
| 1043 <p id='t452' class='exc'> <span class='key'>elif</span> <spa
n class='nam'>line</span><span class='op'>.</span><span class='nam'>startswith</
span><span class='op'>(</span><span class='nam'>self</span><span class='op'>.</s
pan><span class='nam'>TEST_FAILED_MARKER</span><span class='op'>)</span><span cl
ass='op'>:</span><span class='strut'> </span></p> |
| 1044 <p id='t453' class='pln'> <span class='com'># Extract
the test that failed as a possible signal.</span><span class='strut'> </sp
an></p> |
| 1045 <p id='t454' class='exc'> <span class='nam'>match</sp
an> <span class='op'>=</span> <span class='nam'>self</span><span class='op'>.</s
pan><span class='nam'>JAVA_TEST_NAME_PATTERN</span><span class='op'>.</span><spa
n class='nam'>search</span><span class='op'>(</span><span class='nam'>line</span
><span class='op'>)</span><span class='strut'> </span></p> |
| 1046 <p id='t455' class='exc'> <span class='nam'>self</spa
n><span class='op'>.</span><span class='nam'>ExtractJavaFileMatch</span><span cl
ass='op'>(</span><span class='nam'>match</span><span class='op'>,</span> <span c
lass='nam'>signal</span><span class='op'>)</span><span class='strut'> </spa
n></p> |
| 1047 <p id='t456' class='pln'><span class='strut'> </span></p> |
| 1048 <p id='t457' class='pln'> <span class='com'># Extract
the rest of the stacks associated with this failure.</span><span class='strut'>
</span></p> |
| 1049 <p id='t458' class='exc'> <span class='nam'>test_fail
ure_lines</span> <span class='op'>=</span> <span class='nam'>log_lines</span><sp
an class='op'>[</span><span class='nam'>start</span><span class='op'>:</span><sp
an class='nam'>index</span><span class='op'>]</span><span class='strut'> </
span></p> |
| 1050 <p id='t459' class='exc'> <span class='nam'>self</spa
n><span class='op'>.</span><span class='nam'>ProcessTestFailure</span><span clas
s='op'>(</span><span class='nam'>test_failure_lines</span><span class='op'>,</sp
an> <span class='nam'>signal</span><span class='op'>)</span><span class='strut'>
</span></p> |
| 1051 <p id='t460' class='exc'> <span class='nam'>index</span> <sp
an class='op'>+=</span> <span class='num'>1</span><span class='strut'> </sp
an></p> |
| 1052 <p id='t461' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>signal</span><span class='strut'> </span></p> |
| 1053 <p id='t462' class='pln'><span class='strut'> </span></p> |
| 1054 <p id='t463' class='pln'><span class='strut'> </span></p> |
| 1055 <p id='t464' class='stm run hide_run'><span class='key'>class</span> <span class
='nam'>RunhooksExtractor</span><span class='op'>(</span><span class='nam'>Extrac
tor</span><span class='op'>)</span><span class='op'>:</span><span class='strut'>
</span></p> |
| 1056 <p id='t465' class='pln'> <span class='str'>"""For runhooks
and gclient runhooks."""</span><span class='strut'> </span>
</p> |
| 1057 <p id='t466' class='stm run hide_run'> <span class='nam'>IGNORE_LINE_MARKE
R</span> <span class='op'>=</span> <span class='nam'>re</span><span class='op'>.
</span><span class='nam'>compile</span><span class='op'>(</span><span class='str
'>'@@@.+@@@'</span><span class='op'>)</span><span class='strut'> </
span></p> |
| 1058 <p id='t467' class='stm run hide_run'> <span class='nam'>STOP_MARKER</span
> <span class='op'>=</span> <span class='nam'>re</span><span class='op'>.</span>
<span class='nam'>compile</span><span class='op'>(</span><span class='str'>'
________ running'</span><span class='op'>)</span><span class='strut'> <
/span></p> |
| 1059 <p id='t468' class='pln'><span class='strut'> </span></p> |
| 1060 <p id='t469' class='stm run hide_run'> <span class='key'>def</span> <span
class='nam'>_ShouldIgnoreLine</span><span class='op'>(</span><span class='nam'>s
elf</span><span class='op'>,</span> <span class='nam'>line</span><span class='op
'>)</span><span class='op'>:</span><span class='strut'> </span></p> |
| 1061 <p id='t470' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>bool</span><span class='op'>(</span><span class='nam'>self
</span><span class='op'>.</span><span class='nam'>IGNORE_LINE_MARKER</span><span
class='op'>.</span><span class='nam'>search</span><span class='op'>(</span><spa
n class='nam'>line</span><span class='op'>)</span><span class='op'>)</span><span
class='strut'> </span></p> |
| 1062 <p id='t471' class='pln'><span class='strut'> </span></p> |
| 1063 <p id='t472' class='stm run hide_run'> <span class='key'>def</span> <span
class='nam'>Extract</span><span class='op'>(</span><span class='nam'>self</span>
<span class='op'>,</span> <span class='nam'>failure_log</span><span class='op'>,
</span> <span class='op'>*</span><span class='nam'>_</span><span class='op'>)</s
pan><span class='op'>:</span><span class='strut'> </span></p> |
| 1064 <p id='t473' class='stm run hide_run'> <span class='nam'>signal</sp
an> <span class='op'>=</span> <span class='nam'>FailureSignal</span><span class=
'op'>(</span><span class='op'>)</span><span class='strut'> </span></p> |
| 1065 <p id='t474' class='stm run hide_run'> <span class='nam'>log_lines<
/span> <span class='op'>=</span> <span class='nam'>failure_log</span><span class
='op'>.</span><span class='nam'>splitlines</span><span class='op'>(</span><span
class='op'>)</span><span class='strut'> </span></p> |
| 1066 <p id='t475' class='pln'><span class='strut'> </span></p> |
| 1067 <p id='t476' class='stm run hide_run'> <span class='nam'>index</spa
n> <span class='op'>=</span> <span class='nam'>len</span><span class='op'>(</spa
n><span class='nam'>log_lines</span><span class='op'>)</span> <span class='op'>-
</span> <span class='num'>1</span><span class='strut'> </span></p> |
| 1068 <p id='t477' class='pln'><span class='strut'> </span></p> |
| 1069 <p id='t478' class='exc'> <span class='key'>while</span> <span clas
s='nam'>index</span> <span class='op'>>=</span> <span class='num'>0</span><sp
an class='op'>:</span> <span class='com'># pragma: no cover</span><span cl
ass='strut'> </span></p> |
| 1070 <p id='t479' class='pln'> <span class='com'># Start at the b
ottom of the log and read up.</span><span class='strut'> </span></p> |
| 1071 <p id='t480' class='exc'> <span class='nam'>line</span> <spa
n class='op'>=</span> <span class='nam'>log_lines</span><span class='op'>[</span
><span class='nam'>index</span><span class='op'>]</span><span class='strut'>&nbs
p;</span></p> |
| 1072 <p id='t481' class='exc'> <span class='key'>if</span> <span
class='nam'>line</span><span class='op'>:</span><span class='strut'> </span
></p> |
| 1073 <p id='t482' class='exc'> <span class='key'>if</span>
<span class='nam'>self</span><span class='op'>.</span><span class='nam'>STOP_MA
RKER</span><span class='op'>.</span><span class='nam'>search</span><span class='
op'>(</span><span class='nam'>line</span><span class='op'>)</span><span class='o
p'>:</span><span class='strut'> </span></p> |
| 1074 <p id='t483' class='exc'> <span class='key'>br
eak</span><span class='strut'> </span></p> |
| 1075 <p id='t484' class='pln'><span class='strut'> </span></p> |
| 1076 <p id='t485' class='exc'> <span class='key'>if</span>
<span class='key'>not</span> <span class='nam'>self</span><span class='op'>.</s
pan><span class='nam'>_ShouldIgnoreLine</span><span class='op'>(</span><span cla
ss='nam'>line</span><span class='op'>)</span><span class='op'>:</span><span clas
s='strut'> </span></p> |
| 1077 <p id='t486' class='exc'> <span class='nam'>se
lf</span><span class='op'>.</span><span class='nam'>ExtractFiles</span><span cla
ss='op'>(</span><span class='nam'>line</span><span class='op'>,</span> <span cla
ss='nam'>signal</span><span class='op'>)</span><span class='strut'> </span>
</p> |
| 1078 <p id='t487' class='pln'><span class='strut'> </span></p> |
| 1079 <p id='t488' class='exc'> <span class='nam'>index</span> <sp
an class='op'>-=</span> <span class='num'>1</span><span class='strut'> </sp
an></p> |
| 1080 <p id='t489' class='stm run hide_run'> <span class='key'>return</sp
an> <span class='nam'>signal</span><span class='strut'> </span></p> |
| 1081 <p id='t490' class='pln'><span class='strut'> </span></p> |
| 1082 <p id='t491' class='pln'><span class='com'># TODO(lijeffrey): Several steps are
named similarly and may use the same</span><span class='strut'> </span></p> |
| 1083 <p id='t492' class='pln'><span class='com'># extractor. We may need to implement
a solution to map a name to an extractor</span><span class='strut'> </span
></p> |
| 1084 <p id='t493' class='pln'><span class='com'># in a cleaner fashion, though there
may be some shortcomings of special-case</span><span class='strut'> </span>
</p> |
| 1085 <p id='t494' class='pln'><span class='com'># extractors that match a name patter
n but do not use the same extractors.</span><span class='strut'> </span></p
> |
| 1086 <p id='t495' class='stm run hide_run'><span class='nam'>EXTRACTORS</span> <span
class='op'>=</span> <span class='op'>{</span><span class='strut'> </span></
p> |
| 1087 <p id='t496' class='pln'> <span class='str'>'compile'</span
><span class='op'>:</span> <span class='nam'>CompileStepExtractor</span><span cl
ass='op'>,</span><span class='strut'> </span></p> |
| 1088 <p id='t497' class='pln'> <span class='str'>'check_perms'</
span><span class='op'>:</span> <span class='nam'>CheckPermExtractor</span><span
class='op'>,</span><span class='strut'> </span></p> |
| 1089 <p id='t498' class='pln'> <span class='str'>'sizes'</span><
span class='op'>:</span> <span class='nam'>CheckSizesExtractor</span><span class
='op'>,</span><span class='strut'> </span></p> |
| 1090 <p id='t499' class='pln'> <span class='str'>'Instrumentation te
st ChromePublicTest'</span><span class='op'>:</span> <span class='nam'>Instr
umentationTestExtractor</span><span class='op'>,</span><span class='strut'> 
;</span></p> |
| 1091 <p id='t500' class='pln'> <span class='str'>'Instrumentation te
st ContentShellTest'</span><span class='op'>:</span> <span class='nam'>Instr
umentationTestExtractor</span><span class='op'>,</span><span class='strut'> 
;</span></p> |
| 1092 <p id='t501' class='pln'> <span class='str'>'Instrumentation te
st AndroidWebViewTest'</span><span class='op'>:</span> <span class='nam'>Ins
trumentationTestExtractor</span><span class='op'>,</span><span class='strut'>&nb
sp;</span></p> |
| 1093 <p id='t502' class='pln'> <span class='str'>'Instrumentation te
st ChromeSyncShellTest'</span><span class='op'>:</span> <span class='nam'>In
strumentationTestExtractor</span><span class='op'>,</span><span class='strut'>&n
bsp;</span></p> |
| 1094 <p id='t503' class='pln'> <span class='str'>'base_junit_tests&#
39;</span><span class='op'>:</span> <span class='nam'>JunitTestExtractor</span><
span class='op'>,</span><span class='strut'> </span></p> |
| 1095 <p id='t504' class='pln'> <span class='str'>'chrome_junit_tests
'</span><span class='op'>:</span> <span class='nam'>JunitTestExtractor</span
><span class='op'>,</span><span class='strut'> </span></p> |
| 1096 <p id='t505' class='pln'> <span class='str'>'components_junit_t
ests'</span><span class='op'>:</span> <span class='nam'>JunitTestExtractor</
span><span class='op'>,</span><span class='strut'> </span></p> |
| 1097 <p id='t506' class='pln'> <span class='str'>'content_junit_test
s'</span><span class='op'>:</span> <span class='nam'>JunitTestExtractor</spa
n><span class='op'>,</span><span class='strut'> </span></p> |
| 1098 <p id='t507' class='pln'> <span class='str'>'junit_unit_tests&#
39;</span><span class='op'>:</span> <span class='nam'>JunitTestExtractor</span><
span class='op'>,</span><span class='strut'> </span></p> |
| 1099 <p id='t508' class='pln'> <span class='str'>'net_junit_tests
9;</span><span class='op'>:</span> <span class='nam'>JunitTestExtractor</span><s
pan class='op'>,</span><span class='strut'> </span></p> |
| 1100 <p id='t509' class='pln'> <span class='str'>'runhooks'</spa
n><span class='op'>:</span> <span class='nam'>RunhooksExtractor</span><span clas
s='op'>,</span><span class='strut'> </span></p> |
| 1101 <p id='t510' class='pln'> <span class='str'>'gclient runhooks&#
39;</span><span class='op'>:</span> <span class='nam'>RunhooksExtractor</span><s
pan class='strut'> </span></p> |
| 1102 <p id='t511' class='pln'><span class='op'>}</span><span class='strut'> </sp
an></p> |
| 1103 <p id='t512' class='pln'><span class='strut'> </span></p> |
| 1104 <p id='t513' class='pln'><span class='strut'> </span></p> |
| 1105 <p id='t514' class='stm run hide_run'><span class='key'>def</span> <span class='
nam'>ExtractSignal</span><span class='op'>(</span><span class='nam'>master_name<
/span><span class='op'>,</span> <span class='nam'>bot_name</span><span class='op
'>,</span> <span class='nam'>step_name</span><span class='op'>,</span> <span cla
ss='nam'>test_name</span><span class='op'>,</span> <span class='nam'>failure_log
</span><span class='op'>)</span><span class='op'>:</span><span class='strut'>&nb
sp;</span></p> |
| 1106 <p id='t515' class='pln'> <span class='str'>"""Uses an appr
opriate extractor to extract failure signals.</span><span class='strut'> </
span></p> |
| 1107 <p id='t516' class='pln'><span class='strut'> </span></p> |
| 1108 <p id='t517' class='pln'><span class='str'> Returns:</span><span class='st
rut'> </span></p> |
| 1109 <p id='t518' class='pln'><span class='str'> A FailureSignal.</span>
<span class='strut'> </span></p> |
| 1110 <p id='t519' class='pln'><span class='str'> """</span><span
class='strut'> </span></p> |
| 1111 <p id='t520' class='pln'> <span class='com'># Fall back to a general-but-m
aybe-not-accurate extractor.</span><span class='strut'> </span></p> |
| 1112 <p id='t521' class='stm run hide_run'> <span class='nam'>extractor_class</
span> <span class='op'>=</span> <span class='nam'>EXTRACTORS</span><span class='
op'>.</span><span class='nam'>get</span><span class='op'>(</span><span class='na
m'>step_name</span><span class='op'>,</span> <span class='nam'>GeneralExtractor<
/span><span class='op'>)</span><span class='strut'> </span></p> |
| 1113 <p id='t522' class='stm run hide_run'> <span class='key'>return</span> <sp
an class='nam'>extractor_class</span><span class='op'>(</span><span class='op'>)
</span><span class='op'>.</span><span class='nam'>Extract</span><span class='op'
>(</span><span class='strut'> </span></p> |
| 1114 <p id='t523' class='pln'> <span class='nam'>failure_log</spa
n><span class='op'>,</span> <span class='nam'>test_name</span><span class='op'>,
</span> <span class='nam'>step_name</span><span class='op'>,</span> <span class=
'nam'>bot_name</span><span class='op'>,</span> <span class='nam'>master_name</sp
an><span class='op'>)</span><span class='strut'> </span></p> |
| 1115 |
| 1116 </td> |
| 1117 </tr> |
| 1118 </table> |
| 1119 </div> |
| 1120 |
| 1121 <div id='footer'> |
| 1122 <div class='content'> |
| 1123 <p> |
| 1124 <a class='nav' href='index.html'>« index</a> <a c
lass='nav' href='http://nedbatchelder.com/code/coverage'>coverage.py v3.7.1</a> |
| 1125 </p> |
| 1126 </div> |
| 1127 </div> |
| 1128 |
| 1129 </body> |
| 1130 </html> |
| OLD | NEW |