Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(50)

Side by Side Diff: appengine/findit_copy/.tmp/coverage/appengine_findit_waterfall_extractors.html

Issue 2003423003: Merge branch 'blacklist_paths' into only_analyze_top_n_frames Base URL: https://chromium.googlesource.com/infra/infra.git@blacklist_paths
Patch Set: Created 4 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(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 &nbsp;
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> &nbsp; toggle line displays
48 </p>
49 <p class='keyhelp'>
50 <span class='key'>j</span>
51 <span class='key'>k</span> &nbsp; next/prev highlighted chunk
52 </p>
53 <p class='keyhelp'>
54 <span class='key'>0</span> &nbsp; (zero) top of page
55 </p>
56 <p class='keyhelp'>
57 <span class='key'>1</span> &nbsp; (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'>&nbsp;</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'>&nbsp;</span></p>
594 <p id='t3' class='pln'><span class='com'># found in the LICENSE file.</span><spa n class='strut'>&nbsp;</span></p>
595 <p id='t4' class='pln'><span class='strut'>&nbsp;</span></p>
596 <p id='t5' class='stm run hide_run'><span class='key'>import</span> <span class= 'nam'>logging</span><span class='strut'>&nbsp;</span></p>
597 <p id='t6' class='stm run hide_run'><span class='key'>import</span> <span class= 'nam'>os</span><span class='strut'>&nbsp;</span></p>
598 <p id='t7' class='stm run hide_run'><span class='key'>import</span> <span class= 'nam'>re</span><span class='strut'>&nbsp;</span></p>
599 <p id='t8' class='pln'><span class='strut'>&nbsp;</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'>&nbsp;</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'>&nbsp;</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'>&nbsp;</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'>&nbsp;</span></p>
604 <p id='t13' class='pln'><span class='strut'>&nbsp;</span></p>
605 <p id='t14' class='pln'><span class='strut'>&nbsp;</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'>&nbsp; <span class='str'>&quot;&quot;&quot;A general ext ractor.</span><span class='strut'>&nbsp;</span></p>
608 <p id='t17' class='pln'><span class='strut'>&nbsp;</span></p>
609 <p id='t18' class='pln'><span class='str'>&nbsp; It extracts file name and line numbers.</span><span class='strut'>&nbsp;</span></p>
610 <p id='t19' class='pln'><span class='str'>&nbsp; &quot;&quot;&quot;</span><span class='strut'>&nbsp;</span></p>
611 <p id='t20' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
612 <p id='t21' class='pln'>&nbsp; &nbsp; &nbsp; <span class='str'>r&#39;.*Indirect leak of \d+ byte\(s\) in \d+ object\(s\) allocated from:.*&#39;</span><span clas s='op'>)</span><span class='strut'>&nbsp;</span></p>
613 <p id='t22' class='pln'><span class='strut'>&nbsp;</span></p>
614 <p id='t23' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
615 <p id='t24' class='stm run hide_run'>&nbsp; &nbsp; <span class='nam'>in_expected _crash</span> <span class='op'>=</span> <span class='nam'>False</span><span clas s='strut'>&nbsp;</span></p>
616 <p id='t25' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</sp an></p>
617 <p id='t26' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span ></p>
618 <p id='t27' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
619 <p id='t28' class='pln'><span class='strut'>&nbsp;</span></p>
620 <p id='t29' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <span class='key'>if</ span> <span class='str'>&#39;::CrashIntentionally()&#39;</span> <span class='key '>in</span> <span class='nam'>frame</span><span class='op'>:</span><span class=' strut'>&nbsp;</span></p>
621 <p id='t30' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='na m'>in_expected_crash</span> <span class='op'>=</span> <span class='nam'>True</sp an><span class='strut'>&nbsp;</span></p>
622 <p id='t31' class='pln'><span class='strut'>&nbsp;</span></p>
623 <p id='t32' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&lt;=</span><span class='strut'>&nbsp;</span ></p>
624 <p id='t33' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
625 <p id='t34' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;< /span></p>
626 <p id='t35' class='pln'><span class='strut'>&nbsp;</span></p>
627 <p id='t36' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
628 <p id='t37' class='stm run hide_run'>&nbsp; &nbsp; <span class='nam'>frames_with _filenames</span> <span class='op'>=</span> <span class='op'>[</span><span class ='op'>]</span><span class='strut'>&nbsp;</span></p>
629 <p id='t38' class='pln'><span class='strut'>&nbsp;</span></p>
630 <p id='t39' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;< /span></p>
631 <p id='t40' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
632 <p id='t41' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span ></p>
633 <p id='t42' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
634 <p id='t43' class='pln'><span class='strut'>&nbsp;</span></p>
635 <p id='t44' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</sp an></p>
636 <p id='t45' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
637 <p id='t46' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span>< /p>
638 <p id='t47' class='pln'><span class='strut'>&nbsp;</span></p>
639 <p id='t48' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
640 <p id='t49' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
641 <p id='t50' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
642 <p id='t51' class='pln'><span class='strut'>&nbsp;</span></p>
643 <p id='t52' class='stm run hide_run'>&nbsp; &nbsp; <span class='nam'>i</span> <s pan class='op'>=</span> <span class='num'>0</span><span class='strut'>&nbsp;</sp an></p>
644 <p id='t53' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
645 <p id='t54' class='pln'><span class='strut'>&nbsp;</span></p>
646 <p id='t55' class='stm run hide_run'>&nbsp; &nbsp; <span class='key'>while</span > <span class='nam'>i</span> <span class='op'>&lt;</span> <span class='nam'>end_ index</span><span class='op'>:</span><span class='strut'>&nbsp;</span></p>
647 <p id='t56' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
648 <p id='t57' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
649 <p id='t58' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='nam'>lin e</span><span class='op'>)</span><span class='strut'>&nbsp;</span></p>
650 <p id='t59' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <span class='key'>if</ span> <span class='nam'>cpp_stacktrace_match</span><span class='op'>:</span><spa n class='strut'>&nbsp;</span></p>
651 <p id='t60' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='com'># Handle c pp failure stacktraces.</span><span class='strut'>&nbsp;</span></p>
652 <p id='t61' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='na m'>start</span> <span class='op'>=</span> <span class='nam'>i</span><span class= 'strut'>&nbsp;</span></p>
653 <p id='t62' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <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>&nbsp; <s pan class='com'># pragma: no cover</span><span class='strut'>&nbsp;</span></p>
654 <p id='t63' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p >
655 <p id='t64' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='n am'>i</span> <span class='op'>+=</span> <span class='num'>1</span><span class='s trut'>&nbsp;</span></p>
656 <p id='t65' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='key'>els e</span><span class='op'>:</span><span class='strut'>&nbsp;</span></p>
657 <p id='t66' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='k ey'>break</span><span class='strut'>&nbsp;</span></p>
658 <p id='t67' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='na m'>end</span> <span class='op'>=</span> <span class='nam'>i</span><span class='s trut'>&nbsp;</span></p>
659 <p id='t68' class='pln'><span class='strut'>&nbsp;</span></p>
660 <p id='t69' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='ke y'>if</span> <span class='op'>(</span><span class='nam'>start</span> <span class ='op'>&gt;=</span> <span class='num'>1</span> <span class='key'>and</span><span class='strut'>&nbsp;</span></p>
661 <p id='t70' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
662 <p id='t71' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
663 <p id='t72' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='com'># I gnore stack trace of an indirect leak.</span><span class='strut'>&nbsp;</span></ p>
664 <p id='t73' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span cl ass='key'>continue</span><span class='strut'>&nbsp;</span></p>
665 <p id='t74' class='pln'><span class='strut'>&nbsp;</span></p>
666 <p id='t75' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
667 <p id='t76' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
668 <p id='t77' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</spa n></p>
669 <p id='t78' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='com'># Handle p ython failure stacktraces.</span><span class='strut'>&nbsp;</span></p>
670 <p id='t79' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='na m'>i</span> <span class='op'>+=</span> <span class='num'>1</span><span class='st rut'>&nbsp;</span></p>
671 <p id='t80' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='na m'>start</span> <span class='op'>=</span> <span class='nam'>i</span><span class= 'strut'>&nbsp;</span></p>
672 <p id='t81' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='key'>while</spa n> <span class='nam'>i</span> <span class='op'>&lt;</span> <span class='nam'>end _index</span><span class='op'>:</span>&nbsp; <span class='com'># pragma: no cove r</span><span class='strut'>&nbsp;</span></p>
673 <p id='t82' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
674 <p id='t83' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
675 <p id='t84' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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' >&nbsp;</span></p>
676 <p id='t85' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='n am'>i</span> <span class='op'>+=</span> <span class='num'>2</span><span class='s trut'>&nbsp;</span></p>
677 <p id='t86' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='key'>els e</span><span class='op'>:</span><span class='strut'>&nbsp;</span></p>
678 <p id='t87' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='k ey'>break</span><span class='strut'>&nbsp;</span></p>
679 <p id='t88' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='na m'>end</span> <span class='op'>=</span> <span class='nam'>i</span><span class='s trut'>&nbsp;</span></p>
680 <p id='t89' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
681 <p id='t90' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
682 <p id='t91' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <span class='key'>elif </span> <span class='str'>&#39;GMOCK WARNING&#39;</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'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='com'># Ignore G MOCK WARNING statements.</span><span class='strut'>&nbsp;</span></p>
684 <p id='t93' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='na m'>start</span> <span class='op'>=</span> <span class='nam'>i</span><span class= 'strut'>&nbsp;</span></p>
685 <p id='t94' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <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>&nbsp; <span class='com'># pragma: no cover</span><span class='strut'>&nbsp;</span></p>
686 <p id='t95' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='key'>if< /span> <span class='op'>(</span><span class='str'>&#39;You can safely ignore the above warning unless this call &#39;</span><span class='strut'>&nbsp;</span></p >
687 <p id='t96' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span c lass='str'>&#39;should not happen.&#39;</span><span class='op'>)</span> <span cl ass='key'>in</span> <span class='nam'>l</span><span class='op'>:</span><span cla ss='strut'>&nbsp;</span></p>
688 <p id='t97' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='c om'># The end line in GMOCK WARNING statements.</span><span class='strut'>&nbsp; </span></p>
689 <p id='t98' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='k ey'>break</span><span class='strut'>&nbsp;</span></p>
690 <p id='t99' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp; &nbsp; &nbsp; <span class='key'>else</span><span class='op'>:</span><span class='strut'>&nbsp;</span></p>
692 <p id='t101' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
693 <p id='t102' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'> &nbsp;</span></p>
694 <p id='t103' class='pln'><span class='strut'>&nbsp;</span></p>
695 <p id='t104' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
697 <p id='t106' class='stm run hide_run'>&nbsp; &nbsp; <span class='key'>return</sp an> <span class='nam'>signal</span><span class='strut'>&nbsp;</span></p>
698 <p id='t107' class='pln'><span class='strut'>&nbsp;</span></p>
699 <p id='t108' class='pln'><span class='strut'>&nbsp;</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'>&nbsp;</span></p>
701 <p id='t110' class='pln'>&nbsp; <span class='str'>&quot;&quot;&quot;For compile step, extracts files and identifies failed targets.&quot;&quot;&quot;</span><spa n class='strut'>&nbsp;</span></p>
702 <p id='t111' class='stm run hide_run'>&nbsp; <span class='nam'>FAILURE_START_LIN E_PREFIX</span> <span class='op'>=</span> <span class='str'>&#39;FAILED: &#39;</ span><span class='strut'>&nbsp;</span></p>
703 <p id='t112' class='stm run hide_run'>&nbsp; <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&#39;FAILED with \d+:&#39;</span><span class='op'>)</span><span class ='strut'>&nbsp;</span></p>
704 <p id='t113' class='stm run hide_run'>&nbsp; <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&#39;gomacc|clang\+\+&#39;</span><span class='op'>)</span><span clas s='strut'>&nbsp;</span></p>
705 <p id='t114' class='pln'><span class='strut'>&nbsp;</span></p>
706 <p id='t115' class='pln'>&nbsp; <span class='com'># TODO(lijeffrey): In some cas es on mac, the target may have quotes wrapped</span><span class='strut'>&nbsp;</ span></p>
707 <p id='t116' class='pln'>&nbsp; <span class='com'># around the target, i.e. &quo t;Chromium Framework&quot; and we will need to determine</span><span class='stru t'>&nbsp;</span></p>
708 <p id='t117' class='pln'>&nbsp; <span class='com'># whether or not the quotes sh ould be included. If so, then this todo/comment</span><span class='strut'>&nbsp; </span></p>
709 <p id='t118' class='pln'>&nbsp; <span class='com'># can be removed, but if not t hen we want to replace the target group with</span><span class='strut'>&nbsp;</s pan></p>
710 <p id='t119' class='pln'>&nbsp; <span class='com'># (&quot;([^&quot;]+)&quot;|([ ^\s-]+)) instead.</span><span class='strut'>&nbsp;</span></p>
711 <p id='t120' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
712 <p id='t121' class='pln'>&nbsp; &nbsp; &nbsp; <span class='str'>r&#39;(?:-c ([^\ s-]+))? -o ((&quot;[^&quot;]+&quot;)|([^\s-]+))&#39;</span><span class='op'>)</s pan><span class='strut'>&nbsp;</span></p>
713 <p id='t122' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
714 <p id='t123' class='pln'>&nbsp; &nbsp; &nbsp; <span class='str'>r&#39;/c ([^\s-] +)\s+/Fo([^\s-]+)&#39;</span><span class='op'>)</span><span class='strut'>&nbsp; </span></p>
715 <p id='t124' class='stm run hide_run'>&nbsp; <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&#39;/OUT:([^\s-]+)&#39;</span><span class='op'>)</span><span class ='strut'>&nbsp;</span></p>
716 <p id='t125' class='pln'><span class='strut'>&nbsp;</span></p>
717 <p id='t126' class='stm run hide_run'>&nbsp; <span class='nam'>NINJA_FAILURE_END _LINE_PREFIX</span> <span class='op'>=</span> <span class='str'>&#39;ninja: buil d stopped&#39;</span><span class='strut'>&nbsp;</span></p>
718 <p id='t127' class='stm run hide_run'>&nbsp; <span class='nam'>NINJA_ERROR_LINE_ PREFIX</span> <span class='op'>=</span> <span class='str'>&#39;ninja: error&#39; </span><span class='strut'>&nbsp;</span></p>
719 <p id='t128' class='stm run hide_run'>&nbsp; <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&#39;^\d+ errors? generated.&#39;</span><span class='op'>)</span><span cl ass='strut'>&nbsp;</span></p>
720 <p id='t129' class='stm run hide_run'>&nbsp; <span class='nam'>IOS_ERROR_LINE_ST ART_PREFIX</span> <span class='op'>=</span> <span class='str'>&#39;CompileC&#39; </span><span class='strut'>&nbsp;</span></p>
721 <p id='t130' class='pln'><span class='strut'>&nbsp;</span></p>
722 <p id='t131' class='stm run hide_run'>&nbsp; <span class='nam'>IOS_BUILDER_NAMES _FOR_COMPILE</span> <span class='op'>=</span> <span class='op'>[</span><span cla ss='str'>&#39;iOS_Simulator_(dbg)&#39;</span><span class='op'>,</span> <span cla ss='str'>&#39;iOS_Device&#39;</span><span class='op'>]</span><span class='strut' >&nbsp;</span></p>
723 <p id='t132' class='stm run hide_run'>&nbsp; <span class='nam'>MAC_MASTER_NAME_F OR_COMPILE</span> <span class='op'>=</span> <span class='str'>&#39;chromium.mac& #39;</span><span class='strut'>&nbsp;</span></p>
724 <p id='t133' class='pln'><span class='strut'>&nbsp;</span></p>
725 <p id='t134' class='stm run hide_run'>&nbsp; <span class='nam'>GOMA_COMPILER_PRE FIX</span> <span class='op'>=</span> <span class='op'>(</span><span class='strut '>&nbsp;</span></p>
726 <p id='t135' class='pln'>&nbsp; &nbsp; &nbsp; <span class='str'>r&#39;\S*/gomacc &#39;</span><span class='strut'>&nbsp;</span></p>
727 <p id='t136' class='pln'>&nbsp; &nbsp; &nbsp;&nbsp; <span class='str'>&#39;\S+(? :clang\+\+|androideabi-gcc|androideabi-g\+\+)&#39;</span><span class='strut'>&nb sp;</span></p>
728 <p id='t137' class='pln'>&nbsp; <span class='op'>)</span><span class='strut'>&nb sp;</span></p>
729 <p id='t138' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
730 <p id='t139' class='pln'>&nbsp; &nbsp; &nbsp; <span class='str'>r&#39;^FAILED: % s -MMD -MF (obj/[^\s-]+\.o)\.d .* &#39;</span><span class='strut'>&nbsp;</span>< /p>
731 <p id='t140' class='pln'>&nbsp; &nbsp; &nbsp;&nbsp; <span class='str'>&#39;-c ([ ^\s-]+(?:cc|c|cpp|m|mm)) -o \\1$&#39;</span> <span class='op'>%</span> <span cla ss='op'>(</span><span class='strut'>&nbsp;</span></p>
732 <p id='t141' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp; <span class='n am'>GOMA_COMPILER_PREFIX</span><span class='op'>)</span><span class='op'>)</span ><span class='strut'>&nbsp;</span></p>
733 <p id='t142' class='pln'><span class='strut'>&nbsp;</span></p>
734 <p id='t143' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
735 <p id='t144' class='pln'>&nbsp; &nbsp; &nbsp; <span class='str'>r&#39;^FAILED: % s -Wl,.* -o (\S+) -Wl,--start-group .*$&#39;</span> <span class='op'>%</span> <s pan class='op'>(</span><span class='strut'>&nbsp;</span></p>
736 <p id='t145' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='nam'>GO MA_COMPILER_PREFIX</span><span class='op'>)</span><span class='op'>)</span><span class='strut'>&nbsp;</span></p>
737 <p id='t146' class='pln'><span class='strut'>&nbsp;</span></p>
738 <p id='t147' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
739 <p id='t148' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
740 <p id='t149' class='stm run hide_run'>&nbsp; &nbsp; <span class='key'>if</span> <span class='nam'>match</span><span class='op'>:</span><span class='strut'>&nbsp ;</span></p>
741 <p id='t150' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
742 <p id='t151' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
743 <p id='t152' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
744 <p id='t153' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='str'>&# 39;target&#39;</span><span class='op'>:</span> <span class='nam'>target</span><s pan class='op'>,</span><span class='strut'>&nbsp;</span></p>
745 <p id='t154' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='str'>&# 39;source&#39;</span><span class='op'>:</span> <span class='nam'>source</span><s pan class='op'>,</span><span class='strut'>&nbsp;</span></p>
746 <p id='t155' class='pln'>&nbsp; &nbsp; &nbsp; <span class='op'>}</span><span cla ss='op'>)</span><span class='strut'>&nbsp;</span></p>
747 <p id='t156' class='pln'>&nbsp; &nbsp; <span class='key'>else</span><span class= 'op'>:</span><span class='strut'>&nbsp;</span></p>
748 <p id='t157' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
749 <p id='t158' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <span class='key'>if< /span> <span class='nam'>match</span><span class='op'>:</span><span class='strut '>&nbsp;</span></p>
750 <p id='t159' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></ p>
751 <p id='t160' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span>< /p>
752 <p id='t161' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class=' str'>&#39;target&#39;</span><span class='op'>:</span> <span class='nam'>target</ span><span class='op'>,</span><span class='strut'>&nbsp;</span></p>
753 <p id='t162' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='op'>}</span><s pan class='op'>)</span><span class='strut'>&nbsp;</span></p>
754 <p id='t163' class='pln'>&nbsp; &nbsp; &nbsp; <span class='key'>else</span><span class='op'>:</span><span class='strut'>&nbsp;</span></p>
755 <p id='t164' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='n am'>logging</span><span class='op'>.</span><span class='nam'>warn</span><span cl ass='op'>(</span><span class='str'>&#39;Unknown failure type: %s&#39;</span><spa n class='op'>,</span> <span class='nam'>line</span><span class='op'>)</span><spa n class='strut'>&nbsp;</span></p>
756 <p id='t165' class='pln'><span class='strut'>&nbsp;</span></p>
757 <p id='t166' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
758 <p id='t167' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
759 <p id='t168' class='pln'><span class='strut'>&nbsp;</span></p>
760 <p id='t169' class='stm run hide_run'>&nbsp; &nbsp; <span class='key'>if</span> <span class='nam'>match</span><span class='op'>:</span><span class='strut'>&nbsp ;</span></p>
761 <p id='t170' class='pln'>&nbsp; &nbsp; &nbsp; <span class='com'># For non-window s builds, build lines should contain either gomacc or</span><span class='strut'> &nbsp;</span></p>
762 <p id='t171' class='pln'>&nbsp; &nbsp; &nbsp; <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'>&nbsp; &nbsp; &nbsp; <span class='com'># gomacc/clang++ to avoid extracting false positives in the failure line.</span><span class='str ut'>&nbsp;</span></p>
764 <p id='t173' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span ></p>
765 <p id='t174' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
766 <p id='t175' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='k ey'>return</span><span class='strut'>&nbsp;</span></p>
767 <p id='t176' class='pln'><span class='strut'>&nbsp;</span></p>
768 <p id='t177' class='pln'>&nbsp; &nbsp; &nbsp; <span class='com'># Only begin ext racting the targets starting from the index of gomacc or</span><span class='stru t'>&nbsp;</span></p>
769 <p id='t178' class='pln'>&nbsp; &nbsp; &nbsp; <span class='com'># clang++ showin g up in the line.</span><span class='strut'>&nbsp;</span></p>
770 <p id='t179' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
771 <p id='t180' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
772 <p id='t181' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
773 <p id='t182' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
774 <p id='t183' class='pln'><span class='strut'>&nbsp;</span></p>
775 <p id='t184' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <span class='key'>if< /span> <span class='nam'>source_file</span><span class='op'>:</span><span class= 'strut'>&nbsp;</span></p>
776 <p id='t185' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='com'># Failure is a compile failure.</span><span class='strut'>&nbsp;</span></p>
777 <p id='t186' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span>< /p>
778 <p id='t187' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class=' str'>&#39;target&#39;</span><span class='op'>:</span> <span class='nam'>target</ span><span class='op'>,</span><span class='strut'>&nbsp;</span></p>
779 <p id='t188' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class=' str'>&#39;source&#39;</span><span class='op'>:</span> <span class='nam'>source_f ile</span><span class='strut'>&nbsp;</span></p>
780 <p id='t189' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='op'>}</span><s pan class='op'>)</span><span class='strut'>&nbsp;</span></p>
781 <p id='t190' class='pln'>&nbsp; &nbsp; &nbsp; <span class='key'>else</span><span class='op'>:</span><span class='strut'>&nbsp;</span></p>
782 <p id='t191' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='com'># Failure is a linker error.</span><span class='strut'>&nbsp;</span></p>
783 <p id='t192' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span>< /p>
784 <p id='t193' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class=' str'>&#39;target&#39;</span><span class='op'>:</span> <span class='nam'>target</ span><span class='strut'>&nbsp;</span></p>
785 <p id='t194' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='op'>}</span><s pan class='op'>)</span><span class='strut'>&nbsp;</span></p>
786 <p id='t195' class='pln'>&nbsp; &nbsp; <span class='key'>else</span><span class= 'op'>:</span><span class='strut'>&nbsp;</span></p>
787 <p id='t196' class='pln'>&nbsp; &nbsp; &nbsp; <span class='com'># If no match wa s found using Linux pattern matching, fallback to Windows.</span><span class='st rut'>&nbsp;</span></p>
788 <p id='t197' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span>< /p>
789 <p id='t198' class='pln'><span class='strut'>&nbsp;</span></p>
790 <p id='t199' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <span class='key'>if< /span> <span class='nam'>match</span><span class='op'>:</span><span class='strut '>&nbsp;</span></p>
791 <p id='t200' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='com'># Failure is a compile failure.</span><span class='strut'>&nbsp;</span></p>
792 <p id='t201' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</sp an></p>
793 <p id='t202' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</sp an></p>
794 <p id='t203' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span>< /p>
795 <p id='t204' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class=' str'>&#39;target&#39;</span><span class='op'>:</span> <span class='nam'>object_f ile</span><span class='op'>,</span><span class='strut'>&nbsp;</span></p>
796 <p id='t205' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class=' str'>&#39;source&#39;</span><span class='op'>:</span> <span class='nam'>source_f ile</span><span class='strut'>&nbsp;</span></p>
797 <p id='t206' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='op'>}</span><s pan class='op'>)</span><span class='strut'>&nbsp;</span></p>
798 <p id='t207' class='pln'>&nbsp; &nbsp; &nbsp; <span class='key'>else</span><span class='op'>:</span><span class='strut'>&nbsp;</span></p>
799 <p id='t208' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></ p>
800 <p id='t209' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='k ey'>if</span> <span class='nam'>match</span><span class='op'>:</span><span class ='strut'>&nbsp;</span></p>
801 <p id='t210' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='com'># Failure is a linker error.</span><span class='strut'>&nbsp;</span></p>
802 <p id='t211' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</ span></p>
803 <p id='t212' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&#39;targ et&#39;</span><span class='op'>:</span> <span class='nam'>target</span><span cla ss='op'>}</span><span class='op'>)</span><span class='strut'>&nbsp;</span></p>
804 <p id='t213' class='pln'><span class='strut'>&nbsp;</span></p>
805 <p id='t214' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
806 <p id='t215' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
807 <p id='t216' class='stm run hide_run'>&nbsp; &nbsp; <span class='nam'>failure_st arted</span> <span class='op'>=</span> <span class='nam'>False</span><span class ='strut'>&nbsp;</span></p>
808 <p id='t217' class='pln'><span class='strut'>&nbsp;</span></p>
809 <p id='t218' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
810 <p id='t219' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
811 <p id='t220' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <span class='nam'>err or_lines</span> <span class='op'>=</span> <span class='op'>[</span><span class=' op'>]</span><span class='strut'>&nbsp;</span></p>
812 <p id='t221' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
813 <p id='t222' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
815 <p id='t224' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span c lass='nam'>failure_started</span> <span class='op'>=</span> <span class='nam'>Tr ue</span><span class='strut'>&nbsp;</span></p>
816 <p id='t225' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span c lass='key'>continue</span><span class='strut'>&nbsp;</span></p>
817 <p id='t226' class='pln'><span class='strut'>&nbsp;</span></p>
818 <p id='t227' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='k ey'>if</span> <span class='nam'>failure_started</span><span class='op'>:</span>< span class='strut'>&nbsp;</span></p>
819 <p id='t228' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</s pan></p>
820 <p id='t229' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='nam'>failure_started</span> <span class='op'>=</span> <span class=' nam'>False</span><span class='strut'>&nbsp;</span></p>
821 <p id='t230' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
822 <p id='t231' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
823 <p id='t232' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='nam'>error_lines</span> <span class='op'>=</span> <span class='op'> [</span><span class='op'>]</span><span class='strut'>&nbsp;</span></p>
824 <p id='t233' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='key'>el se</span><span class='op'>:</span><span class='strut'>&nbsp;</span></p>
825 <p id='t234' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
826 <p id='t235' class='pln'>&nbsp; &nbsp; <span class='key'>else</span><span class= 'op'>:</span><span class='strut'>&nbsp;</span></p>
827 <p id='t236' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
828 <p id='t237' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='nam'>ma ster_name</span><span class='op'>,</span> <span class='nam'>bot_name</span><span class='op'>)</span><span class='strut'>&nbsp;</span></p>
829 <p id='t238' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
830 <p id='t239' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
831 <p id='t240' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span c lass='key'>if</span> <span class='nam'>strict_regex</span><span class='op'>:</sp an><span class='strut'>&nbsp;</span></p>
832 <p id='t241' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
833 <p id='t242' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='key'>el se</span><span class='op'>:</span><span class='strut'>&nbsp;</span></p>
834 <p id='t243' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
835 <p id='t244' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
836 <p id='t245' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='nam'>failure_started</span> <span class='op'>=</span> <span class=' nam'>True</span><span class='strut'>&nbsp;</span></p>
837 <p id='t246' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='key'>co ntinue</span>&nbsp; <span class='com'># pragma: no cover</span><span class='stru t'>&nbsp;</span></p>
838 <p id='t247' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
839 <p id='t248' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='com'># It is possible the target and source file associated with a compile</span><span class='strut'>&nbsp;</span></p>
840 <p id='t249' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='com'># failure is logged outside a &#39;FAILED: ... 1 error generated&#39; block,</span ><span class='strut'>&nbsp;</span></p>
841 <p id='t250' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='com'># so extract regardless of failure_started.</span><span class='strut'>&nbsp;</span ></p>
842 <p id='t251' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span c lass='key'>if</span> <span class='key'>not</span> <span class='nam'>strict_regex </span><span class='op'>:</span><span class='strut'>&nbsp;</span></p>
843 <p id='t252' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
844 <p id='t253' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
845 <p id='t254' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span c lass='nam'>failure_started</span> <span class='op'>=</span> <span class='nam'>Fa lse</span><span class='strut'>&nbsp;</span></p>
846 <p id='t255' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
847 <p id='t256' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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>&nbsp; <span cl ass='com'># pragma: no cover</span><span class='strut'>&nbsp;</span></p>
848 <p id='t257' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='key'>br eak</span><span class='strut'>&nbsp;</span></p>
849 <p id='t258' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
850 <p id='t259' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='com'># either within the compile errors or is a ninja error.</span><span class='strut'> &nbsp;</span></p>
851 <p id='t260' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'> &nbsp;</span></p>
852 <p id='t261' class='pln'><span class='strut'>&nbsp;</span></p>
853 <p id='t262' class='stm run hide_run'>&nbsp; &nbsp; <span class='key'>return</sp an> <span class='nam'>signal</span><span class='strut'>&nbsp;</span></p>
854 <p id='t263' class='pln'><span class='strut'>&nbsp;</span></p>
855 <p id='t264' class='pln'><span class='strut'>&nbsp;</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' >&nbsp;</span></p>
857 <p id='t266' class='pln'>&nbsp; <span class='str'>&quot;&quot;&quot;For CheckPer m, only extracts files.&quot;&quot;&quot;</span><span class='strut'>&nbsp;</span ></p>
858 <p id='t267' class='pln'><span class='strut'>&nbsp;</span></p>
859 <p id='t268' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
860 <p id='t269' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
861 <p id='t270' class='pln'><span class='strut'>&nbsp;</span></p>
862 <p id='t271' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
863 <p id='t272' class='exc'>&nbsp; &nbsp; &nbsp; <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'>&#39;FAILED&#39;</span><span class ='op'>)</span><span class='op'>:</span>&nbsp; <span class='com'># pragma: no cov er</span><span class='strut'>&nbsp;</span></p>
864 <p id='t273' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='com'># This is where the failure message starts.</span><span class='strut'>&nbsp;</span></p>
865 <p id='t274' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='com'># As we d o reverse check, we should stop here.</span><span class='strut'>&nbsp;</span></p >
866 <p id='t275' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='key'>break</sp an><span class='strut'>&nbsp;</span></p>
867 <p id='t276' class='pln'><span class='strut'>&nbsp;</span></p>
868 <p id='t277' class='pln'>&nbsp; &nbsp; &nbsp; <span class='com'># Extract files. </span><span class='strut'>&nbsp;</span></p>
869 <p id='t278' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
870 <p id='t279' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
871 <p id='t280' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
872 <p id='t281' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp; <span class='nam'>line_number</span><span class='op' >)</span><span class='strut'>&nbsp;</span></p>
873 <p id='t282' class='pln'><span class='strut'>&nbsp;</span></p>
874 <p id='t283' class='stm run hide_run'>&nbsp; &nbsp; <span class='key'>return</sp an> <span class='nam'>signal</span><span class='strut'>&nbsp;</span></p>
875 <p id='t284' class='pln'><span class='strut'>&nbsp;</span></p>
876 <p id='t285' class='pln'><span class='strut'>&nbsp;</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 '>&nbsp;</span></p>
878 <p id='t287' class='pln'>&nbsp; <span class='str'>&quot;&quot;&quot;For Sizes, o nly extract files.&quot;&quot;&quot;</span><span class='strut'>&nbsp;</span></p>
879 <p id='t288' class='stm run hide_run'>&nbsp; <span class='nam'>BEGINNING_MARKER< /span> <span class='op'>=</span> <span class='str'>&#39;# Static initializers in &#39;</span><span class='strut'>&nbsp;</span></p>
880 <p id='t289' class='stm run hide_run'>&nbsp; <span class='nam'>HINT_MARKER</span > <span class='op'>=</span> <span class='str'>&#39;# HINT:&#39;</span><span clas s='strut'>&nbsp;</span></p>
881 <p id='t290' class='stm run hide_run'>&nbsp; <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'>&#39;# Found \\d+ static initializers in \\d+ files?\\.&#39;</span><span class='op'>)< /span><span class='strut'>&nbsp;</span></p>
882 <p id='t291' class='pln'><span class='strut'>&nbsp;</span></p>
883 <p id='t292' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
884 <p id='t293' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
885 <p id='t294' class='stm run hide_run'>&nbsp; &nbsp; <span class='nam'>failure_st arted</span> <span class='op'>=</span> <span class='nam'>False</span><span class ='strut'>&nbsp;</span></p>
886 <p id='t295' class='pln'><span class='strut'>&nbsp;</span></p>
887 <p id='t296' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
888 <p id='t297' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
889 <p id='t298' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='n am'>failure_started</span> <span class='op'>=</span> <span class='nam'>True</spa n><span class='strut'>&nbsp;</span></p>
890 <p id='t299' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='k ey'>continue</span><span class='strut'>&nbsp;</span></p>
891 <p id='t300' class='pln'><span class='strut'>&nbsp;</span></p>
892 <p id='t301' class='pln'>&nbsp; &nbsp; &nbsp; <span class='com'># Skip hints.</s pan><span class='strut'>&nbsp;</span></p>
893 <p id='t302' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
894 <p id='t303' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='k ey'>continue</span><span class='strut'>&nbsp;</span></p>
895 <p id='t304' class='pln'><span class='strut'>&nbsp;</span></p>
896 <p id='t305' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
897 <p id='t306' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='n am'>failure_started</span> <span class='op'>=</span> <span class='nam'>False</sp an><span class='strut'>&nbsp;</span></p>
898 <p id='t307' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='k ey'>continue</span><span class='strut'>&nbsp;</span></p>
899 <p id='t308' class='pln'><span class='strut'>&nbsp;</span></p>
900 <p id='t309' class='pln'>&nbsp; &nbsp; &nbsp; <span class='com'># Begin extracti ng file names.</span><span class='strut'>&nbsp;</span></p>
901 <p id='t310' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <span class='key'>if< /span> <span class='nam'>failure_started</span><span class='op'>:</span><span cl ass='strut'>&nbsp;</span></p>
902 <p id='t311' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;< /span></p>
903 <p id='t312' class='pln'><span class='strut'>&nbsp;</span></p>
904 <p id='t313' class='stm run hide_run'>&nbsp; &nbsp; <span class='key'>return</sp an> <span class='nam'>signal</span><span class='strut'>&nbsp;</span></p>
905 <p id='t314' class='pln'><span class='strut'>&nbsp;</span></p>
906 <p id='t315' class='pln'><span class='strut'>&nbsp;</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'>&nbsp;</span></p>
908 <p id='t317' class='pln'>&nbsp; <span class='str'>&quot;&quot;&quot;An extractor for java-based Android tests.</span><span class='strut'>&nbsp;</span></p>
909 <p id='t318' class='pln'><span class='strut'>&nbsp;</span></p>
910 <p id='t319' class='pln'><span class='str'>&nbsp; &nbsp; Note this extractor sho uld not be used directly, but contains shared</span><span class='strut'>&nbsp;</ span></p>
911 <p id='t320' class='pln'><span class='str'>&nbsp; &nbsp; constants and functions to be used by its children classes.</span><span class='strut'>&nbsp;</span></p>
912 <p id='t321' class='pln'><span class='str'>&nbsp; &quot;&quot;&quot;</span><span class='strut'>&nbsp;</span></p>
913 <p id='t322' class='pln'>&nbsp; <span class='com'># White-list of java packages to consider.</span><span class='strut'>&nbsp;</span></p>
914 <p id='t323' class='stm run hide_run'>&nbsp; <span class='nam'>JAVA_PACKAGES_TO_ CONSIDER</span> <span class='op'>=</span> <span class='op'>[</span><span class=' str'>&#39;org.chromium.&#39;</span><span class='op'>]</span><span class='strut'> &nbsp;</span></p>
915 <p id='t324' class='pln'><span class='strut'>&nbsp;</span></p>
916 <p id='t325' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
917 <p id='t326' class='pln'>&nbsp; &nbsp; &nbsp; <span class='str'>r&#39;((?P&lt;pa ckage_classname&gt;(?:\w+(?:\$\w+)?\.)+)(?P&lt;method&gt;&lt;?\w+&gt;?))&#39;</s pan><span class='op'>)</span><span class='strut'>&nbsp;</span></p>
918 <p id='t327' class='pln'><span class='strut'>&nbsp;</span></p>
919 <p id='t328' class='stm run hide_run'>&nbsp; <span class='nam'>JAVA_STACK_TRACE_ START_MARKERS</span> <span class='op'>=</span> <span class='op'>[</span><span cl ass='str'>&#39;Caused by:&#39;</span><span class='op'>]</span><span class='strut '>&nbsp;</span></p>
920 <p id='t329' class='pln'><span class='strut'>&nbsp;</span></p>
921 <p id='t330' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
922 <p id='t331' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
923 <p id='t332' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span ></p>
924 <p id='t333' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='k ey'>return</span> <span class='nam'>True</span><span class='strut'>&nbsp;</span> </p>
925 <p id='t334' class='stm run hide_run'>&nbsp; &nbsp; <span class='key'>return</sp an> <span class='nam'>False</span><span class='strut'>&nbsp;</span></p>
926 <p id='t335' class='pln'><span class='strut'>&nbsp;</span></p>
927 <p id='t336' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
928 <p id='t337' class='exc'>&nbsp; &nbsp; <span class='key'>if</span> <span class=' nam'>package_filename</span><span class='op'>:</span>&nbsp; <span class='com'># pragma: no cover</span><span class='strut'>&nbsp;</span></p>
929 <p id='t338' class='exc'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
930 <p id='t339' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</spa n></p>
931 <p id='t340' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='key'>re turn</span> <span class='nam'>True</span><span class='strut'>&nbsp;</span></p>
932 <p id='t341' class='stm run hide_run'>&nbsp; &nbsp; <span class='key'>return</sp an> <span class='nam'>False</span><span class='strut'>&nbsp;</span></p>
933 <p id='t342' class='pln'><span class='strut'>&nbsp;</span></p>
934 <p id='t343' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
935 <p id='t344' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
936 <p id='t345' class='stm run hide_run'>&nbsp; &nbsp; <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'>&#39;package_classname&#39;</span><span class='op'>)</span><span cla ss='strut'>&nbsp;</span></p>
937 <p id='t346' class='stm run hide_run'>&nbsp; &nbsp; <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'>&#39;filename&#39;</span><span class='op'>)</span><span class='strut'>&nbsp;< /span></p>
938 <p id='t347' class='stm run hide_run'>&nbsp; &nbsp; <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'>&#39;line_number&#39;</span><span class='op'>)</span><span class='strut'>& nbsp;</span></p>
939 <p id='t348' class='pln'><span class='strut'>&nbsp;</span></p>
940 <p id='t349' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span ></p>
941 <p id='t350' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <span class='key'>if< /span> <span class='nam'>filename</span><span class='op'>:</span><span class='st rut'>&nbsp;</span></p>
942 <p id='t351' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span> </p>
943 <p id='t352' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class=' str'>&#39;/&#39;</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 '>&#39;.&#39;</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'>&nbsp;</span></p>
944 <p id='t353' class='pln'>&nbsp; &nbsp; &nbsp; <span class='key'>else</span><span class='op'>:</span><span class='strut'>&nbsp;</span></p>
945 <p id='t354' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='n am'>file_path</span> <span class='op'>=</span> <span class='str'>&#39;/&#39;</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'>&#39;.&#39;</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'>&#39;.java&#39;</sp an><span class='strut'>&nbsp;</span></p>
946 <p id='t355' class='stm run hide_run'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</spa n></p>
947 <p id='t356' class='pln'><span class='strut'>&nbsp;</span></p>
948 <p id='t357' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
949 <p id='t358' class='exc'>&nbsp; &nbsp; <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'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='str'>&#39;Extr act should be implemented in the child class.&#39;</span><span class='op'>)</spa n>&nbsp; <span class='com'># pragma: no cover</span><span class='strut'>&nbsp;</ span></p>
951 <p id='t360' class='pln'><span class='strut'>&nbsp;</span></p>
952 <p id='t361' class='pln'><span class='strut'>&nbsp;</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'>&nbsp;</span></p>
954 <p id='t363' class='pln'>&nbsp; <span class='str'>&quot;&quot;&quot;For Instrume ntation tests.&quot;&quot;&quot;</span><span class='strut'>&nbsp;</span></p>
955 <p id='t364' class='pln'>&nbsp; <span class='com'># Beginning marker for Java st ack trace.</span><span class='strut'>&nbsp;</span></p>
956 <p id='t365' class='stm run hide_run'>&nbsp; <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&#39;^.*\[FAIL] .*\#.*:&#39;</span><span class='op'>)</span><s pan class='strut'>&nbsp;</span></p>
957 <p id='t366' class='pln'><span class='strut'>&nbsp;</span></p>
958 <p id='t367' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
959 <p id='t368' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
960 <p id='t369' class='stm run hide_run'>&nbsp; &nbsp; <span class='nam'>failure_st arted</span> <span class='op'>=</span> <span class='nam'>False</span><span class ='strut'>&nbsp;</span></p>
961 <p id='t370' class='stm run hide_run'>&nbsp; &nbsp; <span class='nam'>in_failure _stacktrace_within_range</span> <span class='op'>=</span> <span class='nam'>Fals e</span><span class='strut'>&nbsp;</span></p>
962 <p id='t371' class='stm run hide_run'>&nbsp; &nbsp; <span class='nam'>java_stack _frame_index</span> <span class='op'>=</span> <span class='num'>0</span><span cl ass='strut'>&nbsp;</span></p>
963 <p id='t372' class='pln'><span class='strut'>&nbsp;</span></p>
964 <p id='t373' class='exc'>&nbsp; &nbsp; <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>&nbsp; <span class='com '># pragma: no cover</span><span class='strut'>&nbsp;</span></p>
965 <p id='t374' class='exc'>&nbsp; &nbsp; &nbsp; <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'>&#39;Detailed Log s&#39;</span><span class='op'>)</span><span class='op'>:</span><span class='stru t'>&nbsp;</span></p>
966 <p id='t375' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='nam'>failure_s tarted</span> <span class='op'>=</span> <span class='nam'>True</span><span class ='strut'>&nbsp;</span></p>
967 <p id='t376' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='key'>continue< /span><span class='strut'>&nbsp;</span></p>
968 <p id='t377' class='pln'><span class='strut'>&nbsp;</span></p>
969 <p id='t378' class='exc'>&nbsp; &nbsp; &nbsp; <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'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
971 <p id='t380' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
972 <p id='t381' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='nam'>in _failure_stacktrace_within_range</span> <span class='op'>=</span> <span class='n am'>True</span><span class='strut'>&nbsp;</span></p>
973 <p id='t382' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='nam'>ja va_stack_frame_index</span> <span class='op'>=</span> <span class='num'>0</span> <span class='strut'>&nbsp;</span></p>
974 <p id='t383' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='key'>co ntinue</span><span class='strut'>&nbsp;</span></p>
975 <p id='t384' class='pln'><span class='strut'>&nbsp;</span></p>
976 <p id='t385' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&#39;Summary&#39;</span><span class='op'>)</span><span class='op'>:</span><span class='strut'>&nbsp;</span></ p>
977 <p id='t386' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='key'>br eak</span><span class='strut'>&nbsp;</span></p>
978 <p id='t387' class='pln'><span class='strut'>&nbsp;</span></p>
979 <p id='t388' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='key'>if</span> <span class='nam'>in_failure_stacktrace_within_range</span><span class='op'>:</ span><span class='strut'>&nbsp;</span></p>
980 <p id='t389' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</s pan></p>
981 <p id='t390' class='pln'><span class='strut'>&nbsp;</span></p>
982 <p id='t391' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='key'>if </span> <span class='nam'>match</span><span class='op'>:</span><span class='stru t'>&nbsp;</span></p>
983 <p id='t392' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
984 <p id='t393' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class=' nam'>java_stack_frame_index</span> <span class='op'>+=</span> <span class='num'> 1</span><span class='strut'>&nbsp;</span></p>
985 <p id='t394' class='pln'><span class='strut'>&nbsp;</span></p>
986 <p id='t395' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class=' com'># Only extract the top several frames of each stack.</span><span class='str ut'>&nbsp;</span></p>
987 <p id='t396' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class=' key'>if</span> <span class='op'>(</span><span class='nam'>java_stack_frame_index </span> <span class='op'>&gt;=</span><span class='strut'>&nbsp;</span></p>
988 <p id='t397' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
989 <p id='t398' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='nam'>in_failure_stacktrace_within_range</span> <span class='op'>=</span> <span class='nam'>False</span><span class='strut'>&nbsp;</span></p>
990 <p id='t399' class='pln'><span class='strut'>&nbsp;</span></p>
991 <p id='t400' class='stm run hide_run'>&nbsp; &nbsp; <span class='key'>return</sp an> <span class='nam'>signal</span><span class='strut'>&nbsp;</span></p>
992 <p id='t401' class='pln'><span class='strut'>&nbsp;</span></p>
993 <p id='t402' class='pln'><span class='strut'>&nbsp;</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'>&nbsp;</span></p>
995 <p id='t404' class='pln'>&nbsp; <span class='str'>&quot;&quot;&quot;For Junit te sts.&quot;&quot;&quot;</span><span class='strut'>&nbsp;</span></p>
996 <p id='t405' class='stm run hide_run'>&nbsp; <span class='nam'>TEST_START_MARKER </span> <span class='op'>=</span> <span class='str'>&#39;[ RUN&nbsp; &nbsp; &nbs p; ]&#39;</span><span class='strut'>&nbsp;</span></p>
997 <p id='t406' class='stm run hide_run'>&nbsp; <span class='nam'>TEST_FAILED_MARKE R</span> <span class='op'>=</span> <span class='str'>&#39;[&nbsp;&nbsp; FAILED ] &#39;</span><span class='strut'>&nbsp;</span></p>
998 <p id='t407' class='pln'><span class='strut'>&nbsp;</span></p>
999 <p id='t408' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
1000 <p id='t409' class='stm run hide_run'>&nbsp; &nbsp; <span class='nam'>in_failure _stacktrace_within_range</span> <span class='op'>=</span> <span class='nam'>Fals e</span><span class='strut'>&nbsp;</span></p>
1001 <p id='t410' class='stm run hide_run'>&nbsp; &nbsp; <span class='nam'>java_stack _frame_index</span> <span class='op'>=</span> <span class='num'>0</span><span cl ass='strut'>&nbsp;</span></p>
1002 <p id='t411' class='pln'><span class='strut'>&nbsp;</span></p>
1003 <p id='t412' class='pln'>&nbsp; &nbsp; <span class='com'># Find first failure st acktrace.</span><span class='strut'>&nbsp;</span></p>
1004 <p id='t413' class='stm run hide_run'>&nbsp; &nbsp; <span class='nam'>index</spa n> <span class='op'>=</span> <span class='num'>0</span><span class='strut'>&nbsp ;</span></p>
1005 <p id='t414' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
1006 <p id='t415' class='exc'>&nbsp; &nbsp; <span class='key'>while</span> <span clas s='nam'>index</span> <span class='op'>&lt;</span> <span class='nam'>end_index</s pan><span class='op'>:</span>&nbsp; <span class='com'># pragma: no cover</span>< span class='strut'>&nbsp;</span></p>
1007 <p id='t416' class='exc'>&nbsp; &nbsp; &nbsp; <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'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
1009 <p id='t418' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='nam'>in_failur e_stacktrace_within_range</span> <span class='op'>=</span> <span class='nam'>Tru e</span><span class='strut'>&nbsp;</span></p>
1010 <p id='t419' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='key'>break</sp an><span class='strut'>&nbsp;</span></p>
1011 <p id='t420' class='exc'>&nbsp; &nbsp; &nbsp; <span class='nam'>index</span> <sp an class='op'>+=</span> <span class='num'>1</span><span class='strut'>&nbsp;</sp an></p>
1012 <p id='t421' class='pln'><span class='strut'>&nbsp;</span></p>
1013 <p id='t422' class='exc'>&nbsp; &nbsp; <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>&nbsp; <span class='com'># pra gma: no cover</span><span class='strut'>&nbsp;</span></p>
1014 <p id='t423' class='exc'>&nbsp; &nbsp; &nbsp; <span class='key'>if</span> <span class='nam'>in_failure_stacktrace_within_range</span><span class='op'>:</span><s pan class='strut'>&nbsp;</span></p>
1015 <p id='t424' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p >
1016 <p id='t425' class='pln'><span class='strut'>&nbsp;</span></p>
1017 <p id='t426' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='nam'>ja va_stack_frame_index</span> <span class='op'>+=</span> <span class='num'>1</span ><span class='strut'>&nbsp;</span></p>
1020 <p id='t429' class='pln'><span class='strut'>&nbsp;</span></p>
1021 <p id='t430' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='key'>if </span> <span class='op'>(</span><span class='nam'>java_stack_frame_index</span> <span class='op'>&gt;=</span><span class='strut'>&nbsp;</span></p>
1023 <p id='t432' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
1024 <p id='t433' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class=' nam'>in_failure_stacktrace_within_range</span> <span class='op'>=</span> <span c lass='nam'>False</span><span class='strut'>&nbsp;</span></p>
1025 <p id='t434' class='pln'><span class='strut'>&nbsp;</span></p>
1026 <p id='t435' class='exc'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
1027 <p id='t436' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='nam'>in_failur e_stacktrace_within_range</span> <span class='op'>=</span> <span class='nam'>Tru e</span><span class='strut'>&nbsp;</span></p>
1028 <p id='t437' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='nam'>java_stac k_frame_index</span> <span class='op'>=</span> <span class='num'>0</span><span c lass='strut'>&nbsp;</span></p>
1029 <p id='t438' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='key'>continue< /span><span class='strut'>&nbsp;</span></p>
1030 <p id='t439' class='pln'><span class='strut'>&nbsp;</span></p>
1031 <p id='t440' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
1032 <p id='t441' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
1033 <p id='t442' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
1034 <p id='t443' class='pln'><span class='strut'>&nbsp;</span></p>
1035 <p id='t444' class='stm run hide_run'>&nbsp; &nbsp; <span class='nam'>index</spa n> <span class='op'>=</span> <span class='num'>0</span><span class='strut'>&nbsp ;</span></p>
1036 <p id='t445' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
1039 <p id='t448' class='exc'>&nbsp; &nbsp; <span class='key'>while</span> <span clas s='nam'>index</span> <span class='op'>&lt;</span> <span class='nam'>end</span><s pan class='op'>:</span>&nbsp; <span class='com'># pragma: no cover</span><span c lass='strut'>&nbsp;</span></p>
1040 <p id='t449' class='exc'>&nbsp; &nbsp; &nbsp; <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'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
1042 <p id='t451' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
1043 <p id='t452' class='exc'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
1044 <p id='t453' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='com'># Extract the test that failed as a possible signal.</span><span class='strut'>&nbsp;</sp an></p>
1045 <p id='t454' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
1046 <p id='t455' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</spa n></p>
1047 <p id='t456' class='pln'><span class='strut'>&nbsp;</span></p>
1048 <p id='t457' class='pln'>&nbsp; &nbsp; &nbsp; &nbsp; <span class='com'># Extract the rest of the stacks associated with this failure.</span><span class='strut'> &nbsp;</span></p>
1049 <p id='t458' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</ span></p>
1050 <p id='t459' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <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'> &nbsp;</span></p>
1051 <p id='t460' class='exc'>&nbsp; &nbsp; &nbsp; <span class='nam'>index</span> <sp an class='op'>+=</span> <span class='num'>1</span><span class='strut'>&nbsp;</sp an></p>
1052 <p id='t461' class='stm run hide_run'>&nbsp; &nbsp; <span class='key'>return</sp an> <span class='nam'>signal</span><span class='strut'>&nbsp;</span></p>
1053 <p id='t462' class='pln'><span class='strut'>&nbsp;</span></p>
1054 <p id='t463' class='pln'><span class='strut'>&nbsp;</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'> &nbsp;</span></p>
1056 <p id='t465' class='pln'>&nbsp; <span class='str'>&quot;&quot;&quot;For runhooks and gclient runhooks.&quot;&quot;&quot;</span><span class='strut'>&nbsp;</span> </p>
1057 <p id='t466' class='stm run hide_run'>&nbsp; <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 '>&#39;@@@.+@@@&#39;</span><span class='op'>)</span><span class='strut'>&nbsp;</ span></p>
1058 <p id='t467' class='stm run hide_run'>&nbsp; <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'>&#39; ________ running&#39;</span><span class='op'>)</span><span class='strut'>&nbsp;< /span></p>
1059 <p id='t468' class='pln'><span class='strut'>&nbsp;</span></p>
1060 <p id='t469' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
1061 <p id='t470' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
1062 <p id='t471' class='pln'><span class='strut'>&nbsp;</span></p>
1063 <p id='t472' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
1064 <p id='t473' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
1065 <p id='t474' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
1066 <p id='t475' class='pln'><span class='strut'>&nbsp;</span></p>
1067 <p id='t476' class='stm run hide_run'>&nbsp; &nbsp; <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'>&nbsp;</span></p>
1068 <p id='t477' class='pln'><span class='strut'>&nbsp;</span></p>
1069 <p id='t478' class='exc'>&nbsp; &nbsp; <span class='key'>while</span> <span clas s='nam'>index</span> <span class='op'>&gt;=</span> <span class='num'>0</span><sp an class='op'>:</span>&nbsp; <span class='com'># pragma: no cover</span><span cl ass='strut'>&nbsp;</span></p>
1070 <p id='t479' class='pln'>&nbsp; &nbsp; &nbsp; <span class='com'># Start at the b ottom of the log and read up.</span><span class='strut'>&nbsp;</span></p>
1071 <p id='t480' class='exc'>&nbsp; &nbsp; &nbsp; <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'>&nbsp; &nbsp; &nbsp; <span class='key'>if</span> <span class='nam'>line</span><span class='op'>:</span><span class='strut'>&nbsp;</span ></p>
1073 <p id='t482' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
1074 <p id='t483' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span class='key'>br eak</span><span class='strut'>&nbsp;</span></p>
1075 <p id='t484' class='pln'><span class='strut'>&nbsp;</span></p>
1076 <p id='t485' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span></p>
1077 <p id='t486' class='exc'>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <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'>&nbsp;</span> </p>
1078 <p id='t487' class='pln'><span class='strut'>&nbsp;</span></p>
1079 <p id='t488' class='exc'>&nbsp; &nbsp; &nbsp; <span class='nam'>index</span> <sp an class='op'>-=</span> <span class='num'>1</span><span class='strut'>&nbsp;</sp an></p>
1080 <p id='t489' class='stm run hide_run'>&nbsp; &nbsp; <span class='key'>return</sp an> <span class='nam'>signal</span><span class='strut'>&nbsp;</span></p>
1081 <p id='t490' class='pln'><span class='strut'>&nbsp;</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'>&nbsp;</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'>&nbsp;</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'>&nbsp;</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'>&nbsp;</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'>&nbsp;</span></ p>
1087 <p id='t496' class='pln'>&nbsp; &nbsp; <span class='str'>&#39;compile&#39;</span ><span class='op'>:</span> <span class='nam'>CompileStepExtractor</span><span cl ass='op'>,</span><span class='strut'>&nbsp;</span></p>
1088 <p id='t497' class='pln'>&nbsp; &nbsp; <span class='str'>&#39;check_perms&#39;</ span><span class='op'>:</span> <span class='nam'>CheckPermExtractor</span><span class='op'>,</span><span class='strut'>&nbsp;</span></p>
1089 <p id='t498' class='pln'>&nbsp; &nbsp; <span class='str'>&#39;sizes&#39;</span>< span class='op'>:</span> <span class='nam'>CheckSizesExtractor</span><span class ='op'>,</span><span class='strut'>&nbsp;</span></p>
1090 <p id='t499' class='pln'>&nbsp; &nbsp; <span class='str'>&#39;Instrumentation te st ChromePublicTest&#39;</span><span class='op'>:</span> <span class='nam'>Instr umentationTestExtractor</span><span class='op'>,</span><span class='strut'>&nbsp ;</span></p>
1091 <p id='t500' class='pln'>&nbsp; &nbsp; <span class='str'>&#39;Instrumentation te st ContentShellTest&#39;</span><span class='op'>:</span> <span class='nam'>Instr umentationTestExtractor</span><span class='op'>,</span><span class='strut'>&nbsp ;</span></p>
1092 <p id='t501' class='pln'>&nbsp; &nbsp; <span class='str'>&#39;Instrumentation te st AndroidWebViewTest&#39;</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'>&nbsp; &nbsp; <span class='str'>&#39;Instrumentation te st ChromeSyncShellTest&#39;</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'>&nbsp; &nbsp; <span class='str'>&#39;base_junit_tests&# 39;</span><span class='op'>:</span> <span class='nam'>JunitTestExtractor</span>< span class='op'>,</span><span class='strut'>&nbsp;</span></p>
1095 <p id='t504' class='pln'>&nbsp; &nbsp; <span class='str'>&#39;chrome_junit_tests &#39;</span><span class='op'>:</span> <span class='nam'>JunitTestExtractor</span ><span class='op'>,</span><span class='strut'>&nbsp;</span></p>
1096 <p id='t505' class='pln'>&nbsp; &nbsp; <span class='str'>&#39;components_junit_t ests&#39;</span><span class='op'>:</span> <span class='nam'>JunitTestExtractor</ span><span class='op'>,</span><span class='strut'>&nbsp;</span></p>
1097 <p id='t506' class='pln'>&nbsp; &nbsp; <span class='str'>&#39;content_junit_test s&#39;</span><span class='op'>:</span> <span class='nam'>JunitTestExtractor</spa n><span class='op'>,</span><span class='strut'>&nbsp;</span></p>
1098 <p id='t507' class='pln'>&nbsp; &nbsp; <span class='str'>&#39;junit_unit_tests&# 39;</span><span class='op'>:</span> <span class='nam'>JunitTestExtractor</span>< span class='op'>,</span><span class='strut'>&nbsp;</span></p>
1099 <p id='t508' class='pln'>&nbsp; &nbsp; <span class='str'>&#39;net_junit_tests&#3 9;</span><span class='op'>:</span> <span class='nam'>JunitTestExtractor</span><s pan class='op'>,</span><span class='strut'>&nbsp;</span></p>
1100 <p id='t509' class='pln'>&nbsp; &nbsp; <span class='str'>&#39;runhooks&#39;</spa n><span class='op'>:</span> <span class='nam'>RunhooksExtractor</span><span clas s='op'>,</span><span class='strut'>&nbsp;</span></p>
1101 <p id='t510' class='pln'>&nbsp; &nbsp; <span class='str'>&#39;gclient runhooks&# 39;</span><span class='op'>:</span> <span class='nam'>RunhooksExtractor</span><s pan class='strut'>&nbsp;</span></p>
1102 <p id='t511' class='pln'><span class='op'>}</span><span class='strut'>&nbsp;</sp an></p>
1103 <p id='t512' class='pln'><span class='strut'>&nbsp;</span></p>
1104 <p id='t513' class='pln'><span class='strut'>&nbsp;</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'>&nbsp; <span class='str'>&quot;&quot;&quot;Uses an appr opriate extractor to extract failure signals.</span><span class='strut'>&nbsp;</ span></p>
1107 <p id='t516' class='pln'><span class='strut'>&nbsp;</span></p>
1108 <p id='t517' class='pln'><span class='str'>&nbsp; Returns:</span><span class='st rut'>&nbsp;</span></p>
1109 <p id='t518' class='pln'><span class='str'>&nbsp; &nbsp; A FailureSignal.</span> <span class='strut'>&nbsp;</span></p>
1110 <p id='t519' class='pln'><span class='str'>&nbsp; &quot;&quot;&quot;</span><span class='strut'>&nbsp;</span></p>
1111 <p id='t520' class='pln'>&nbsp; <span class='com'># Fall back to a general-but-m aybe-not-accurate extractor.</span><span class='strut'>&nbsp;</span></p>
1112 <p id='t521' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
1113 <p id='t522' class='stm run hide_run'>&nbsp; <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'>&nbsp;</span></p>
1114 <p id='t523' class='pln'>&nbsp; &nbsp; &nbsp; <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'>&nbsp;</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'>&#xab; index</a> &nbsp; &nbsp; <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>
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698