blob: f2e87fe2b6522cc52435d1149bae60765161cf8b [file] [log] [blame]
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<meta name="generator" content="Doxygen 1.8.6"/>
<title>Impala: fe/src/test/java/com/cloudera/impala/testutil/TestFileParser.java Source File</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<link href="navtree.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="resize.js"></script>
<script type="text/javascript" src="navtree.js"></script>
<script type="text/javascript">
$(document).ready(initResizable);
$(window).load(resizeHeight);
</script>
<link href="search/search.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="search/search.js"></script>
<script type="text/javascript">
$(document).ready(function() { searchBox.OnSelectItem(0); });
</script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
<tbody>
<tr style="height: 56px;">
<td style="padding-left: 0.5em;">
<div id="projectname">Impala
</div>
<div id="projectbrief">Impalaistheopensource,nativeanalyticdatabaseforApacheHadoop.</div>
</td>
</tr>
</tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.6 -->
<script type="text/javascript">
var searchBox = new SearchBox("searchBox", "search",false,'Search');
</script>
<div id="navrow1" class="tabs">
<ul class="tablist">
<li><a href="index.html"><span>Main&#160;Page</span></a></li>
<li><a href="namespaces.html"><span>Namespaces</span></a></li>
<li><a href="annotated.html"><span>Classes</span></a></li>
<li class="current"><a href="files.html"><span>Files</span></a></li>
<li>
<div id="MSearchBox" class="MSearchBoxInactive">
<span class="left">
<img id="MSearchSelect" src="search/mag_sel.png"
onmouseover="return searchBox.OnSearchSelectShow()"
onmouseout="return searchBox.OnSearchSelectHide()"
alt=""/>
<input type="text" id="MSearchField" value="Search" accesskey="S"
onfocus="searchBox.OnSearchFieldFocus(true)"
onblur="searchBox.OnSearchFieldFocus(false)"
onkeyup="searchBox.OnSearchFieldChange(event)"/>
</span><span class="right">
<a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
</span>
</div>
</li>
</ul>
</div>
<div id="navrow2" class="tabs2">
<ul class="tablist">
<li><a href="files.html"><span>File&#160;List</span></a></li>
<li><a href="globals.html"><span>File&#160;Members</span></a></li>
</ul>
</div>
</div><!-- top -->
<div id="side-nav" class="ui-resizable side-nav-resizable">
<div id="nav-tree">
<div id="nav-tree-contents">
<div id="nav-sync" class="sync"></div>
</div>
</div>
<div id="splitbar" style="-moz-user-select:none;"
class="ui-resizable-handle">
</div>
</div>
<script type="text/javascript">
$(document).ready(function(){initNavTree('TestFileParser_8java_source.html','');});
</script>
<div id="doc-content">
<!-- window showing the filter options -->
<div id="MSearchSelectWindow"
onmouseover="return searchBox.OnSearchSelectShow()"
onmouseout="return searchBox.OnSearchSelectHide()"
onkeydown="return searchBox.OnSearchSelectKey(event)">
<a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(0)"><span class="SelectionMark">&#160;</span>All</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(1)"><span class="SelectionMark">&#160;</span>Classes</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(2)"><span class="SelectionMark">&#160;</span>Namespaces</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(3)"><span class="SelectionMark">&#160;</span>Files</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(4)"><span class="SelectionMark">&#160;</span>Functions</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(5)"><span class="SelectionMark">&#160;</span>Variables</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(6)"><span class="SelectionMark">&#160;</span>Typedefs</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(7)"><span class="SelectionMark">&#160;</span>Enumerations</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(8)"><span class="SelectionMark">&#160;</span>Enumerator</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(9)"><span class="SelectionMark">&#160;</span>Friends</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(10)"><span class="SelectionMark">&#160;</span>Macros</a></div>
<!-- iframe showing the search results (closed by default) -->
<div id="MSearchResultsWindow">
<iframe src="javascript:void(0)" frameborder="0"
name="MSearchResults" id="MSearchResults">
</iframe>
</div>
<div class="header">
<div class="headertitle">
<div class="title">TestFileParser.java</div> </div>
</div><!--header-->
<div class="contents">
<a href="TestFileParser_8java.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno"> 1</span>&#160;<span class="comment">// Copyright (c) 2012 Cloudera, Inc. All rights reserved.</span></div>
<div class="line"><a name="l00002"></a><span class="lineno"> 2</span>&#160;</div>
<div class="line"><a name="l00003"></a><span class="lineno"> 3</span>&#160;<span class="keyword">package </span>com.cloudera.impala.testutil;</div>
<div class="line"><a name="l00004"></a><span class="lineno"> 4</span>&#160;</div>
<div class="line"><a name="l00005"></a><span class="lineno"> 5</span>&#160;<span class="keyword">import</span> <span class="keyword">static</span> org.junit.Assert.fail;</div>
<div class="line"><a name="l00006"></a><span class="lineno"> 6</span>&#160;</div>
<div class="line"><a name="l00007"></a><span class="lineno"> 7</span>&#160;<span class="keyword">import</span> java.io.BufferedReader;</div>
<div class="line"><a name="l00008"></a><span class="lineno"> 8</span>&#160;<span class="keyword">import</span> java.io.File;</div>
<div class="line"><a name="l00009"></a><span class="lineno"> 9</span>&#160;<span class="keyword">import</span> java.io.FileReader;</div>
<div class="line"><a name="l00010"></a><span class="lineno"> 10</span>&#160;<span class="keyword">import</span> java.io.IOException;</div>
<div class="line"><a name="l00011"></a><span class="lineno"> 11</span>&#160;<span class="keyword">import</span> java.util.ArrayList;</div>
<div class="line"><a name="l00012"></a><span class="lineno"> 12</span>&#160;<span class="keyword">import</span> java.util.EnumMap;</div>
<div class="line"><a name="l00013"></a><span class="lineno"> 13</span>&#160;<span class="keyword">import</span> java.util.List;</div>
<div class="line"><a name="l00014"></a><span class="lineno"> 14</span>&#160;<span class="keyword">import</span> java.util.Scanner;</div>
<div class="line"><a name="l00015"></a><span class="lineno"> 15</span>&#160;</div>
<div class="line"><a name="l00016"></a><span class="lineno"> 16</span>&#160;<span class="keyword">import</span> org.apache.log4j.Logger;</div>
<div class="line"><a name="l00017"></a><span class="lineno"> 17</span>&#160;</div>
<div class="line"><a name="l00018"></a><span class="lineno"> 18</span>&#160;<span class="keyword">import</span> com.google.common.base.Joiner;</div>
<div class="line"><a name="l00019"></a><span class="lineno"> 19</span>&#160;<span class="keyword">import</span> com.google.common.collect.Lists;</div>
<div class="line"><a name="l00020"></a><span class="lineno"> 20</span>&#160;<span class="keyword">import</span> com.google.common.collect.Maps;</div>
<div class="line"><a name="l00021"></a><span class="lineno"> 21</span>&#160;</div>
<div class="line"><a name="l00051"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html"> 51</a></span>&#160;<span class="keyword">public</span> <span class="keyword">class </span><a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html">TestFileParser</a> {</div>
<div class="line"><a name="l00052"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a789f5fbc89b3122f3c40ba0f63a81289"> 52</a></span>&#160; <span class="keyword">private</span> <span class="keyword">static</span> <span class="keyword">final</span> Logger <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a789f5fbc89b3122f3c40ba0f63a81289">LOG</a> = Logger.getLogger(TestCase.class);</div>
<div class="line"><a name="l00053"></a><span class="lineno"> 53</span>&#160;</div>
<div class="line"><a name="l00057"></a><span class="lineno"><a class="line" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html"> 57</a></span>&#160; <span class="keyword">public</span> <span class="keyword">enum</span> <a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html">Section</a> {</div>
<div class="line"><a name="l00058"></a><span class="lineno"><a class="line" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a462d7d404b0713d1d521c582d62ef0ba"> 58</a></span>&#160; <a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a462d7d404b0713d1d521c582d62ef0ba">QUERY</a>,</div>
<div class="line"><a name="l00059"></a><span class="lineno"><a class="line" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a6bf929527a84a0d1ac6cd49af8f7f9ce"> 59</a></span>&#160; <a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a6bf929527a84a0d1ac6cd49af8f7f9ce">TYPES</a>,</div>
<div class="line"><a name="l00060"></a><span class="lineno"><a class="line" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a193ad5d5e45787ec673ec66feb0c5f5b"> 60</a></span>&#160; <a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a193ad5d5e45787ec673ec66feb0c5f5b">COLLABELS</a>,</div>
<div class="line"><a name="l00061"></a><span class="lineno"><a class="line" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#ae5f0ef405c4045be59e5068b9437b496"> 61</a></span>&#160; <a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#ae5f0ef405c4045be59e5068b9437b496">RESULTS</a>,</div>
<div class="line"><a name="l00062"></a><span class="lineno"><a class="line" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a52b2fe668d828145d7d81331bc3f01c8"> 62</a></span>&#160; <a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a52b2fe668d828145d7d81331bc3f01c8">PLAN</a>,</div>
<div class="line"><a name="l00063"></a><span class="lineno"><a class="line" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a06182a858208bd23a9433699c153928b"> 63</a></span>&#160; <a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a06182a858208bd23a9433699c153928b">DISTRIBUTEDPLAN</a>,</div>
<div class="line"><a name="l00064"></a><span class="lineno"><a class="line" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a8568e931e029b23b759a6270f4a8394b"> 64</a></span>&#160; <a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a8568e931e029b23b759a6270f4a8394b">FILEERRORS</a>,</div>
<div class="line"><a name="l00065"></a><span class="lineno"><a class="line" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#af0643ce73ebb07f6165776254ba520d1"> 65</a></span>&#160; <a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#af0643ce73ebb07f6165776254ba520d1">PARTITIONS</a>,</div>
<div class="line"><a name="l00066"></a><span class="lineno"><a class="line" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a98152dabbffc26c9bbb90aa55e348b22"> 66</a></span>&#160; <a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a98152dabbffc26c9bbb90aa55e348b22">SETUP</a>,</div>
<div class="line"><a name="l00067"></a><span class="lineno"><a class="line" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#abc504a968bbe5b9b5833bafdf0560b3b"> 67</a></span>&#160; <a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#abc504a968bbe5b9b5833bafdf0560b3b">ERRORS</a>,</div>
<div class="line"><a name="l00068"></a><span class="lineno"><a class="line" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#aeea37292184bec2d2a95b47e1975cf36"> 68</a></span>&#160; <a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#aeea37292184bec2d2a95b47e1975cf36">SCANRANGELOCATIONS</a>,</div>
<div class="line"><a name="l00069"></a><span class="lineno"><a class="line" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a6cacaaf0604748f6149bf900ed9600bd"> 69</a></span>&#160; <a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a6cacaaf0604748f6149bf900ed9600bd">LINEAGE</a>;</div>
<div class="line"><a name="l00070"></a><span class="lineno"> 70</span>&#160;</div>
<div class="line"><a name="l00071"></a><span class="lineno"> 71</span>&#160; <span class="comment">// Return header line for this section</span></div>
<div class="line"><a name="l00072"></a><span class="lineno"><a class="line" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#aa5b44b7e223257ad5442be57c879f3ff"> 72</a></span>&#160; <span class="keyword">public</span> String <a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#aa5b44b7e223257ad5442be57c879f3ff">getHeader</a>() {</div>
<div class="line"><a name="l00073"></a><span class="lineno"> 73</span>&#160; <span class="keywordflow">return</span> <span class="stringliteral">&quot;---- &quot;</span> + this.toString();</div>
<div class="line"><a name="l00074"></a><span class="lineno"> 74</span>&#160; }</div>
<div class="line"><a name="l00075"></a><span class="lineno"> 75</span>&#160; }</div>
<div class="line"><a name="l00076"></a><span class="lineno"> 76</span>&#160;</div>
<div class="line"><a name="l00081"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html"> 81</a></span>&#160; <span class="keyword">public</span> <span class="keyword">static</span> <span class="keyword">class </span><a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html">TestCase</a> {</div>
<div class="line"><a name="l00082"></a><span class="lineno"> 82</span>&#160;</div>
<div class="line"><a name="l00083"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#ac5d52585e4ca778e14af53559cde867b"> 83</a></span>&#160; <span class="keyword">private</span> <span class="keyword">final</span> EnumMap&lt;Section, ArrayList&lt;String&gt;&gt; <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#ac5d52585e4ca778e14af53559cde867b">expectedResultSections</a> =</div>
<div class="line"><a name="l00084"></a><span class="lineno"> 84</span>&#160; Maps.newEnumMap(Section.class);</div>
<div class="line"><a name="l00085"></a><span class="lineno"> 85</span>&#160;</div>
<div class="line"><a name="l00086"></a><span class="lineno"> 86</span>&#160; <span class="comment">// Line number in the test case file where this case started</span></div>
<div class="line"><a name="l00087"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a373b3b44befa23aba43dcfab8a6ef49a"> 87</a></span>&#160; <span class="keyword">private</span> <span class="keyword">final</span> <span class="keywordtype">int</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a373b3b44befa23aba43dcfab8a6ef49a">startLineNum</a>;</div>
<div class="line"><a name="l00088"></a><span class="lineno"> 88</span>&#160;</div>
<div class="line"><a name="l00089"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a77660b95ff8930e06404daf2ebddcf84"> 89</a></span>&#160; <span class="keyword">public</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a77660b95ff8930e06404daf2ebddcf84">TestCase</a>(<span class="keywordtype">int</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#aea875dca2fdb7cdb620879d2b1debc1e">lineNum</a>) {</div>
<div class="line"><a name="l00090"></a><span class="lineno"> 90</span>&#160; <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a373b3b44befa23aba43dcfab8a6ef49a">startLineNum</a> = <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#aea875dca2fdb7cdb620879d2b1debc1e">lineNum</a>;</div>
<div class="line"><a name="l00091"></a><span class="lineno"> 91</span>&#160; }</div>
<div class="line"><a name="l00092"></a><span class="lineno"> 92</span>&#160;</div>
<div class="line"><a name="l00093"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a4d64bcb01b4b7b0884d1bce22bc29586"> 93</a></span>&#160; <span class="keyword">public</span> <span class="keywordtype">int</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a4d64bcb01b4b7b0884d1bce22bc29586">getStartingLineNum</a>() {</div>
<div class="line"><a name="l00094"></a><span class="lineno"> 94</span>&#160; <span class="keywordflow">return</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a373b3b44befa23aba43dcfab8a6ef49a">startLineNum</a>;</div>
<div class="line"><a name="l00095"></a><span class="lineno"> 95</span>&#160; }</div>
<div class="line"><a name="l00096"></a><span class="lineno"> 96</span>&#160;</div>
<div class="line"><a name="l00097"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a65c9e9086d4408a3ec39b93d080d59a5"> 97</a></span>&#160; <span class="keyword">protected</span> <span class="keywordtype">void</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a65c9e9086d4408a3ec39b93d080d59a5">addSection</a>(<a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html">Section</a> section, ArrayList&lt;String&gt; contents) {</div>
<div class="line"><a name="l00098"></a><span class="lineno"> 98</span>&#160; expectedResultSections.put(section, contents);</div>
<div class="line"><a name="l00099"></a><span class="lineno"> 99</span>&#160; }</div>
<div class="line"><a name="l00100"></a><span class="lineno"> 100</span>&#160;</div>
<div class="line"><a name="l00105"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#ad99141f500fe30152aabe233d079c8e2"> 105</a></span>&#160; <span class="keyword">public</span> ArrayList&lt;String&gt; <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#ad99141f500fe30152aabe233d079c8e2">getSectionContents</a>(<a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html">Section</a> section) {</div>
<div class="line"><a name="l00106"></a><span class="lineno"> 106</span>&#160; <span class="keywordflow">return</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#ad99141f500fe30152aabe233d079c8e2">getSectionContents</a>(section, <span class="keyword">false</span>);</div>
<div class="line"><a name="l00107"></a><span class="lineno"> 107</span>&#160; }</div>
<div class="line"><a name="l00108"></a><span class="lineno"> 108</span>&#160;</div>
<div class="line"><a name="l00109"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#ada2a696516d8b95ebd97f9cdfada5502"> 109</a></span>&#160; <span class="keyword">public</span> ArrayList&lt;String&gt; <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#ada2a696516d8b95ebd97f9cdfada5502">getSectionContents</a>(<a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html">Section</a> section, <span class="keywordtype">boolean</span> withComments) {</div>
<div class="line"><a name="l00110"></a><span class="lineno"> 110</span>&#160; <span class="keywordflow">return</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#ad99141f500fe30152aabe233d079c8e2">getSectionContents</a>(section, withComments, null);</div>
<div class="line"><a name="l00111"></a><span class="lineno"> 111</span>&#160; }</div>
<div class="line"><a name="l00112"></a><span class="lineno"> 112</span>&#160;</div>
<div class="line"><a name="l00125"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a6a8285a0eef8ebdc6d66eabe0b69f201"> 125</a></span>&#160; <span class="keyword">public</span> ArrayList&lt;String&gt; <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a6a8285a0eef8ebdc6d66eabe0b69f201">getSectionContents</a>(<a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html">Section</a> section, <span class="keywordtype">boolean</span> withComments,</div>
<div class="line"><a name="l00126"></a><span class="lineno"> 126</span>&#160; String dbSuffix) {</div>
<div class="line"><a name="l00127"></a><span class="lineno"> 127</span>&#160; ArrayList&lt;String&gt; ret = expectedResultSections.get(section);</div>
<div class="line"><a name="l00128"></a><span class="lineno"> 128</span>&#160; <span class="keywordflow">if</span> (ret == null) {</div>
<div class="line"><a name="l00129"></a><span class="lineno"> 129</span>&#160; <span class="keywordflow">return</span> Lists.newArrayList();</div>
<div class="line"><a name="l00130"></a><span class="lineno"> 130</span>&#160; } <span class="keywordflow">else</span> <span class="keywordflow">if</span> (withComments &amp;&amp; dbSuffix == null) {</div>
<div class="line"><a name="l00131"></a><span class="lineno"> 131</span>&#160; <span class="keywordflow">return</span> ret;</div>
<div class="line"><a name="l00132"></a><span class="lineno"> 132</span>&#160; }</div>
<div class="line"><a name="l00133"></a><span class="lineno"> 133</span>&#160;</div>
<div class="line"><a name="l00134"></a><span class="lineno"> 134</span>&#160; ArrayList&lt;String&gt; retList = Lists.newArrayList();</div>
<div class="line"><a name="l00135"></a><span class="lineno"> 135</span>&#160; <span class="keywordflow">for</span> (String s : ret) {</div>
<div class="line"><a name="l00136"></a><span class="lineno"> 136</span>&#160; <span class="keywordflow">if</span> (!(s.startsWith(<span class="stringliteral">&quot;#&quot;</span>) || s.startsWith(<span class="stringliteral">&quot;//&quot;</span>))) {</div>
<div class="line"><a name="l00137"></a><span class="lineno"> 137</span>&#160; <span class="keywordflow">if</span> (dbSuffix != null) {</div>
<div class="line"><a name="l00138"></a><span class="lineno"> 138</span>&#160; retList.add(s.replaceAll(<span class="stringliteral">&quot;\\$DATABASE&quot;</span>, dbSuffix));</div>
<div class="line"><a name="l00139"></a><span class="lineno"> 139</span>&#160; } <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00140"></a><span class="lineno"> 140</span>&#160; retList.add(s);</div>
<div class="line"><a name="l00141"></a><span class="lineno"> 141</span>&#160; }</div>
<div class="line"><a name="l00142"></a><span class="lineno"> 142</span>&#160; } <span class="keywordflow">else</span> <span class="keywordflow">if</span> (withComments) {</div>
<div class="line"><a name="l00143"></a><span class="lineno"> 143</span>&#160; retList.add(s);</div>
<div class="line"><a name="l00144"></a><span class="lineno"> 144</span>&#160; }</div>
<div class="line"><a name="l00145"></a><span class="lineno"> 145</span>&#160; }</div>
<div class="line"><a name="l00146"></a><span class="lineno"> 146</span>&#160;</div>
<div class="line"><a name="l00147"></a><span class="lineno"> 147</span>&#160; <span class="keywordflow">return</span> retList;</div>
<div class="line"><a name="l00148"></a><span class="lineno"> 148</span>&#160; }</div>
<div class="line"><a name="l00149"></a><span class="lineno"> 149</span>&#160;</div>
<div class="line"><a name="l00150"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a53e1a70c9c693d8ea87acf4dc4345e0f"> 150</a></span>&#160; <span class="keyword">public</span> String <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a53e1a70c9c693d8ea87acf4dc4345e0f">getSectionAsString</a>(<a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html">Section</a> section, <span class="keywordtype">boolean</span> withComments,</div>
<div class="line"><a name="l00151"></a><span class="lineno"> 151</span>&#160; String delimiter) {</div>
<div class="line"><a name="l00152"></a><span class="lineno"> 152</span>&#160; <span class="keywordflow">return</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a53e1a70c9c693d8ea87acf4dc4345e0f">getSectionAsString</a>(section, withComments, delimiter, null);</div>
<div class="line"><a name="l00153"></a><span class="lineno"> 153</span>&#160; }</div>
<div class="line"><a name="l00154"></a><span class="lineno"> 154</span>&#160;</div>
<div class="line"><a name="l00159"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a713c57194b3908dafdb762e31e7a81f1"> 159</a></span>&#160; <span class="keyword">public</span> String <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a713c57194b3908dafdb762e31e7a81f1">getSectionAsString</a>(<a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html">Section</a> section, <span class="keywordtype">boolean</span> withComments,</div>
<div class="line"><a name="l00160"></a><span class="lineno"> 160</span>&#160; String delimiter, String dbSuffix) {</div>
<div class="line"><a name="l00161"></a><span class="lineno"> 161</span>&#160; List&lt;String&gt; sectionList = <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#ad99141f500fe30152aabe233d079c8e2">getSectionContents</a>(section, withComments, dbSuffix);</div>
<div class="line"><a name="l00162"></a><span class="lineno"> 162</span>&#160; <span class="keywordflow">if</span> (sectionList == null) {</div>
<div class="line"><a name="l00163"></a><span class="lineno"> 163</span>&#160; <span class="keywordflow">return</span> null;</div>
<div class="line"><a name="l00164"></a><span class="lineno"> 164</span>&#160; }</div>
<div class="line"><a name="l00165"></a><span class="lineno"> 165</span>&#160;</div>
<div class="line"><a name="l00166"></a><span class="lineno"> 166</span>&#160; <span class="keywordflow">return</span> Joiner.on(delimiter).join(sectionList);</div>
<div class="line"><a name="l00167"></a><span class="lineno"> 167</span>&#160; }</div>
<div class="line"><a name="l00168"></a><span class="lineno"> 168</span>&#160;</div>
<div class="line"><a name="l00172"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#aa8a7dc090d5020f51919a228b185478e"> 172</a></span>&#160; <span class="keyword">public</span> String <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#aa8a7dc090d5020f51919a228b185478e">getQuery</a>() {</div>
<div class="line"><a name="l00173"></a><span class="lineno"> 173</span>&#160; <span class="keywordflow">return</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a53e1a70c9c693d8ea87acf4dc4345e0f">getSectionAsString</a>(<a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html">Section</a>.<a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a462d7d404b0713d1d521c582d62ef0ba">QUERY</a>, <span class="keyword">false</span>, <span class="stringliteral">&quot;\n&quot;</span>);</div>
<div class="line"><a name="l00174"></a><span class="lineno"> 174</span>&#160; }</div>
<div class="line"><a name="l00175"></a><span class="lineno"> 175</span>&#160;</div>
<div class="line"><a name="l00179"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#ab82078412764355378233e3d04511498"> 179</a></span>&#160; <span class="keyword">public</span> <span class="keywordtype">boolean</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#ab82078412764355378233e3d04511498">isValid</a>() {</div>
<div class="line"><a name="l00180"></a><span class="lineno"> 180</span>&#160; <span class="keywordflow">return</span> !<a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#aa8a7dc090d5020f51919a228b185478e">getQuery</a>().isEmpty() &amp;&amp; (!<a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#ad99141f500fe30152aabe233d079c8e2">getSectionContents</a>(<a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html">Section</a>.<a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a52b2fe668d828145d7d81331bc3f01c8">PLAN</a>).isEmpty() ||</div>
<div class="line"><a name="l00181"></a><span class="lineno"> 181</span>&#160; !<a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#ad99141f500fe30152aabe233d079c8e2">getSectionContents</a>(<a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html">Section</a>.<a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a06182a858208bd23a9433699c153928b">DISTRIBUTEDPLAN</a>).isEmpty() ||</div>
<div class="line"><a name="l00182"></a><span class="lineno"> 182</span>&#160; !<a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#ad99141f500fe30152aabe233d079c8e2">getSectionContents</a>(<a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html">Section</a>.<a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a6cacaaf0604748f6149bf900ed9600bd">LINEAGE</a>).isEmpty());</div>
<div class="line"><a name="l00183"></a><span class="lineno"> 183</span>&#160; }</div>
<div class="line"><a name="l00184"></a><span class="lineno"> 184</span>&#160; }</div>
<div class="line"><a name="l00185"></a><span class="lineno"> 185</span>&#160;</div>
<div class="line"><a name="l00186"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#adfd46b838f2f9fd42a0b0eef97e964b8"> 186</a></span>&#160; <span class="keyword">private</span> <span class="keyword">final</span> List&lt;TestCase&gt; <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#adfd46b838f2f9fd42a0b0eef97e964b8">testCases</a> = Lists.newArrayList();</div>
<div class="line"><a name="l00187"></a><span class="lineno"> 187</span>&#160;</div>
<div class="line"><a name="l00188"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#aea875dca2fdb7cdb620879d2b1debc1e"> 188</a></span>&#160; <span class="keyword">private</span> <span class="keywordtype">int</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#aea875dca2fdb7cdb620879d2b1debc1e">lineNum</a> = 0;</div>
<div class="line"><a name="l00189"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a5835d5816a8d5ed89c3df0b99aa2a376"> 189</a></span>&#160; <span class="keyword">private</span> <span class="keyword">final</span> String <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a5835d5816a8d5ed89c3df0b99aa2a376">fileName</a>;</div>
<div class="line"><a name="l00190"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#af6a6bf7a155af0b4c1e830e74bd11111"> 190</a></span>&#160; <span class="keyword">private</span> BufferedReader <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#af6a6bf7a155af0b4c1e830e74bd11111">reader</a>;</div>
<div class="line"><a name="l00191"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a1f0ebab61210b9cbd4fb0034123357af"> 191</a></span>&#160; <span class="keyword">private</span> Scanner <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a1f0ebab61210b9cbd4fb0034123357af">scanner</a>;</div>
<div class="line"><a name="l00192"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#aee09309a9d3a58c1a989fb614d029042"> 192</a></span>&#160; <span class="keyword">private</span> <span class="keywordtype">boolean</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a304e8c38e6de1b43233a47ba5831d05f">hasSetupSection</a> = <span class="keyword">false</span>;</div>
<div class="line"><a name="l00193"></a><span class="lineno"> 193</span>&#160;</div>
<div class="line"><a name="l00198"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a4c5f0519f06e6fe299fc7049311b8d37"> 198</a></span>&#160; <span class="keyword">static</span> <span class="keyword">private</span> <span class="keyword">final</span> ArrayList&lt;Section&gt; <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a4c5f0519f06e6fe299fc7049311b8d37">defaultSectionOrder</a> =</div>
<div class="line"><a name="l00199"></a><span class="lineno"> 199</span>&#160; Lists.newArrayList(<a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a462d7d404b0713d1d521c582d62ef0ba">Section.QUERY</a>, <a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a6bf929527a84a0d1ac6cd49af8f7f9ce">Section.TYPES</a>, <a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#ae5f0ef405c4045be59e5068b9437b496">Section.RESULTS</a>);</div>
<div class="line"><a name="l00200"></a><span class="lineno"> 200</span>&#160;</div>
<div class="line"><a name="l00201"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a06672e632d395275afdb4e16956b889a"> 201</a></span>&#160; <span class="keyword">public</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a06672e632d395275afdb4e16956b889a">TestFileParser</a>(String <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a5835d5816a8d5ed89c3df0b99aa2a376">fileName</a>) {</div>
<div class="line"><a name="l00202"></a><span class="lineno"> 202</span>&#160; this.fileName = <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a5835d5816a8d5ed89c3df0b99aa2a376">fileName</a>;</div>
<div class="line"><a name="l00203"></a><span class="lineno"> 203</span>&#160; }</div>
<div class="line"><a name="l00204"></a><span class="lineno"> 204</span>&#160;</div>
<div class="line"><a name="l00205"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#aa6a870ac3f8a0ddff0a310a53a1410d7"> 205</a></span>&#160; <span class="keyword">public</span> List&lt;TestCase&gt; <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#aa6a870ac3f8a0ddff0a310a53a1410d7">getTestCases</a>() {</div>
<div class="line"><a name="l00206"></a><span class="lineno"> 206</span>&#160; <span class="keywordflow">return</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#adfd46b838f2f9fd42a0b0eef97e964b8">testCases</a>;</div>
<div class="line"><a name="l00207"></a><span class="lineno"> 207</span>&#160; }</div>
<div class="line"><a name="l00208"></a><span class="lineno"> 208</span>&#160;</div>
<div class="line"><a name="l00209"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a20d15ee210293cd2865754e835dcdff4"> 209</a></span>&#160; <span class="keyword">public</span> String <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a20d15ee210293cd2865754e835dcdff4">getTestFileName</a>() {</div>
<div class="line"><a name="l00210"></a><span class="lineno"> 210</span>&#160; <span class="keywordflow">return</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a5835d5816a8d5ed89c3df0b99aa2a376">fileName</a>;</div>
<div class="line"><a name="l00211"></a><span class="lineno"> 211</span>&#160; }</div>
<div class="line"><a name="l00212"></a><span class="lineno"> 212</span>&#160;</div>
<div class="line"><a name="l00213"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a304e8c38e6de1b43233a47ba5831d05f"> 213</a></span>&#160; <span class="keyword">public</span> <span class="keywordtype">boolean</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a304e8c38e6de1b43233a47ba5831d05f">hasSetupSection</a>() {</div>
<div class="line"><a name="l00214"></a><span class="lineno"> 214</span>&#160; <span class="keywordflow">return</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a304e8c38e6de1b43233a47ba5831d05f">hasSetupSection</a>;</div>
<div class="line"><a name="l00215"></a><span class="lineno"> 215</span>&#160; }</div>
<div class="line"><a name="l00216"></a><span class="lineno"> 216</span>&#160;</div>
<div class="line"><a name="l00220"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#afad99420566a5fc57e962b9a9ca50124"> 220</a></span>&#160; <span class="keyword">private</span> <span class="keywordtype">void</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#afad99420566a5fc57e962b9a9ca50124">open</a>(String table) {</div>
<div class="line"><a name="l00221"></a><span class="lineno"> 221</span>&#160; <span class="keywordflow">try</span> {</div>
<div class="line"><a name="l00222"></a><span class="lineno"> 222</span>&#160; String testFileBaseDir =</div>
<div class="line"><a name="l00223"></a><span class="lineno"> 223</span>&#160; <span class="keyword">new</span> File(System.getenv(<span class="stringliteral">&quot;IMPALA_HOME&quot;</span>), <span class="stringliteral">&quot;testdata/workloads&quot;</span>).getPath();</div>
<div class="line"><a name="l00224"></a><span class="lineno"> 224</span>&#160; String fullPath = <span class="keyword">new</span> File(testFileBaseDir, <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a5835d5816a8d5ed89c3df0b99aa2a376">fileName</a>).getPath();</div>
<div class="line"><a name="l00225"></a><span class="lineno"> 225</span>&#160; <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#af6a6bf7a155af0b4c1e830e74bd11111">reader</a> = <span class="keyword">new</span> BufferedReader(<span class="keyword">new</span> FileReader(fullPath));</div>
<div class="line"><a name="l00226"></a><span class="lineno"> 226</span>&#160; <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a1f0ebab61210b9cbd4fb0034123357af">scanner</a> = <span class="keyword">new</span> Scanner(reader);</div>
<div class="line"><a name="l00227"></a><span class="lineno"> 227</span>&#160; } <span class="keywordflow">catch</span> (Exception e) {</div>
<div class="line"><a name="l00228"></a><span class="lineno"> 228</span>&#160; fail(e.getMessage());</div>
<div class="line"><a name="l00229"></a><span class="lineno"> 229</span>&#160; }</div>
<div class="line"><a name="l00230"></a><span class="lineno"> 230</span>&#160; }</div>
<div class="line"><a name="l00231"></a><span class="lineno"> 231</span>&#160;</div>
<div class="line"><a name="l00235"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a421aba184fc1ed5cdaa3d965d94c0c4f"> 235</a></span>&#160; <span class="keyword">private</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html">TestCase</a> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a421aba184fc1ed5cdaa3d965d94c0c4f">parseOneTestCase</a>() {</div>
<div class="line"><a name="l00236"></a><span class="lineno"> 236</span>&#160; <a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html">Section</a> currentSection = <a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a462d7d404b0713d1d521c582d62ef0ba">Section.QUERY</a>;</div>
<div class="line"><a name="l00237"></a><span class="lineno"> 237</span>&#160; ArrayList&lt;String&gt; sectionContents = Lists.newArrayList();</div>
<div class="line"><a name="l00238"></a><span class="lineno"> 238</span>&#160; <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html">TestCase</a> currentTestCase = <span class="keyword">new</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html">TestCase</a>(<a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#aea875dca2fdb7cdb620879d2b1debc1e">lineNum</a>);</div>
<div class="line"><a name="l00239"></a><span class="lineno"> 239</span>&#160; <span class="keywordtype">int</span> sectionCount = 0;</div>
<div class="line"><a name="l00240"></a><span class="lineno"> 240</span>&#160;</div>
<div class="line"><a name="l00241"></a><span class="lineno"> 241</span>&#160; <span class="keywordflow">while</span> (<a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a1f0ebab61210b9cbd4fb0034123357af">scanner</a>.hasNextLine()) {</div>
<div class="line"><a name="l00242"></a><span class="lineno"> 242</span>&#160; String line = scanner.nextLine();</div>
<div class="line"><a name="l00243"></a><span class="lineno"> 243</span>&#160; ++<a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#aea875dca2fdb7cdb620879d2b1debc1e">lineNum</a>;</div>
<div class="line"><a name="l00244"></a><span class="lineno"> 244</span>&#160; <span class="keywordflow">if</span> (line.startsWith(<span class="stringliteral">&quot;====&quot;</span>) &amp;&amp; sectionCount &gt; 0) {</div>
<div class="line"><a name="l00245"></a><span class="lineno"> 245</span>&#160; currentTestCase.addSection(currentSection, sectionContents);</div>
<div class="line"><a name="l00246"></a><span class="lineno"> 246</span>&#160; <span class="keywordflow">if</span>(!currentTestCase.isValid()) {</div>
<div class="line"><a name="l00247"></a><span class="lineno"> 247</span>&#160; <span class="keywordflow">throw</span> <span class="keyword">new</span> IllegalStateException(<span class="stringliteral">&quot;Invalid test case&quot;</span> +</div>
<div class="line"><a name="l00248"></a><span class="lineno"> 248</span>&#160; <span class="stringliteral">&quot; at line &quot;</span> + currentTestCase.startLineNum + <span class="stringliteral">&quot; detected.&quot;</span>);</div>
<div class="line"><a name="l00249"></a><span class="lineno"> 249</span>&#160; }</div>
<div class="line"><a name="l00250"></a><span class="lineno"> 250</span>&#160; <span class="keywordflow">return</span> currentTestCase; <span class="comment">// done with this test case</span></div>
<div class="line"><a name="l00251"></a><span class="lineno"> 251</span>&#160; }</div>
<div class="line"><a name="l00252"></a><span class="lineno"> 252</span>&#160; <span class="keywordflow">if</span> (line.startsWith(<span class="stringliteral">&quot;----&quot;</span>)) {</div>
<div class="line"><a name="l00253"></a><span class="lineno"> 253</span>&#160; sectionCount++;</div>
<div class="line"><a name="l00254"></a><span class="lineno"> 254</span>&#160; <span class="comment">// New section</span></div>
<div class="line"><a name="l00255"></a><span class="lineno"> 255</span>&#160; currentTestCase.addSection(currentSection, sectionContents);</div>
<div class="line"><a name="l00256"></a><span class="lineno"> 256</span>&#160; <span class="keywordtype">boolean</span> found = <span class="keyword">false</span>;</div>
<div class="line"><a name="l00257"></a><span class="lineno"> 257</span>&#160; line = line.trim().toLowerCase();</div>
<div class="line"><a name="l00258"></a><span class="lineno"> 258</span>&#160;</div>
<div class="line"><a name="l00259"></a><span class="lineno"> 259</span>&#160; <span class="comment">// Check for section header - a missing header probably means an old test file.</span></div>
<div class="line"><a name="l00260"></a><span class="lineno"> 260</span>&#160; <span class="keywordflow">if</span> (!line.endsWith(<span class="stringliteral">&quot;----&quot;</span>)) {</div>
<div class="line"><a name="l00261"></a><span class="lineno"> 261</span>&#160; <span class="keywordflow">for</span> (<a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html">Section</a> s : <a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html">Section</a>.values()) {</div>
<div class="line"><a name="l00262"></a><span class="lineno"> 262</span>&#160; <span class="keywordflow">if</span> (line.matches(<span class="stringliteral">&quot;----\\s+&quot;</span> + s.toString().toLowerCase() + <span class="stringliteral">&quot;\\b.*&quot;</span>)) {</div>
<div class="line"><a name="l00263"></a><span class="lineno"> 263</span>&#160; currentSection = s;</div>
<div class="line"><a name="l00264"></a><span class="lineno"> 264</span>&#160; <span class="keywordflow">if</span> (s == <a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html">Section</a>.<a class="code" href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a98152dabbffc26c9bbb90aa55e348b22">SETUP</a>) {</div>
<div class="line"><a name="l00265"></a><span class="lineno"> 265</span>&#160; <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a304e8c38e6de1b43233a47ba5831d05f">hasSetupSection</a> = <span class="keyword">true</span>;</div>
<div class="line"><a name="l00266"></a><span class="lineno"> 266</span>&#160; }</div>
<div class="line"><a name="l00267"></a><span class="lineno"> 267</span>&#160; found = <span class="keyword">true</span>;</div>
<div class="line"><a name="l00268"></a><span class="lineno"> 268</span>&#160; <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00269"></a><span class="lineno"> 269</span>&#160; }</div>
<div class="line"><a name="l00270"></a><span class="lineno"> 270</span>&#160; }</div>
<div class="line"><a name="l00271"></a><span class="lineno"> 271</span>&#160; <span class="keywordflow">if</span> (!found) {</div>
<div class="line"><a name="l00272"></a><span class="lineno"> 272</span>&#160; <span class="keywordflow">throw</span> <span class="keyword">new</span> IllegalStateException(<span class="stringliteral">&quot;Unknown section name: &quot;</span> + line);</div>
<div class="line"><a name="l00273"></a><span class="lineno"> 273</span>&#160; }</div>
<div class="line"><a name="l00274"></a><span class="lineno"> 274</span>&#160; } <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00275"></a><span class="lineno"> 275</span>&#160; <span class="comment">// Backwards compatibility only - TODO remove once all test files have section</span></div>
<div class="line"><a name="l00276"></a><span class="lineno"> 276</span>&#160; <span class="comment">// headers.</span></div>
<div class="line"><a name="l00277"></a><span class="lineno"> 277</span>&#160; <span class="keywordflow">if</span> (sectionCount &gt;= <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a4c5f0519f06e6fe299fc7049311b8d37">defaultSectionOrder</a>.size()) {</div>
<div class="line"><a name="l00278"></a><span class="lineno"> 278</span>&#160; <span class="keywordflow">throw</span> <span class="keyword">new</span> IllegalStateException(<span class="stringliteral">&quot;Unexpected number of untitled sections: &quot;</span></div>
<div class="line"><a name="l00279"></a><span class="lineno"> 279</span>&#160; + sectionCount);</div>
<div class="line"><a name="l00280"></a><span class="lineno"> 280</span>&#160; }</div>
<div class="line"><a name="l00281"></a><span class="lineno"> 281</span>&#160; currentSection = defaultSectionOrder.get(sectionCount);</div>
<div class="line"><a name="l00282"></a><span class="lineno"> 282</span>&#160; LOG.warn(<span class="stringliteral">&quot;No section header found. Guessing: &quot;</span> + currentSection);</div>
<div class="line"><a name="l00283"></a><span class="lineno"> 283</span>&#160; }</div>
<div class="line"><a name="l00284"></a><span class="lineno"> 284</span>&#160;</div>
<div class="line"><a name="l00285"></a><span class="lineno"> 285</span>&#160; sectionContents = Lists.newArrayList();</div>
<div class="line"><a name="l00286"></a><span class="lineno"> 286</span>&#160; } <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00287"></a><span class="lineno"> 287</span>&#160; sectionContents.add(line);</div>
<div class="line"><a name="l00288"></a><span class="lineno"> 288</span>&#160; }</div>
<div class="line"><a name="l00289"></a><span class="lineno"> 289</span>&#160; }</div>
<div class="line"><a name="l00290"></a><span class="lineno"> 290</span>&#160;</div>
<div class="line"><a name="l00291"></a><span class="lineno"> 291</span>&#160; <span class="keywordflow">if</span>(!currentTestCase.isValid()) {</div>
<div class="line"><a name="l00292"></a><span class="lineno"> 292</span>&#160; <span class="keywordflow">throw</span> <span class="keyword">new</span> IllegalStateException(<span class="stringliteral">&quot;Invalid test case&quot;</span> +</div>
<div class="line"><a name="l00293"></a><span class="lineno"> 293</span>&#160; <span class="stringliteral">&quot; at line &quot;</span> + currentTestCase.startLineNum + <span class="stringliteral">&quot; detected.&quot;</span>);</div>
<div class="line"><a name="l00294"></a><span class="lineno"> 294</span>&#160; }</div>
<div class="line"><a name="l00295"></a><span class="lineno"> 295</span>&#160;</div>
<div class="line"><a name="l00296"></a><span class="lineno"> 296</span>&#160; <span class="keywordflow">return</span> currentTestCase;</div>
<div class="line"><a name="l00297"></a><span class="lineno"> 297</span>&#160; }</div>
<div class="line"><a name="l00298"></a><span class="lineno"> 298</span>&#160;</div>
<div class="line"><a name="l00302"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#af95d793a2bbc5c1847cd960d0d9ccb21"> 302</a></span>&#160; <span class="keyword">public</span> <span class="keywordtype">void</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#af95d793a2bbc5c1847cd960d0d9ccb21">parseFile</a>() {</div>
<div class="line"><a name="l00303"></a><span class="lineno"> 303</span>&#160; <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#af95d793a2bbc5c1847cd960d0d9ccb21">parseFile</a>(null);</div>
<div class="line"><a name="l00304"></a><span class="lineno"> 304</span>&#160; }</div>
<div class="line"><a name="l00305"></a><span class="lineno"> 305</span>&#160;</div>
<div class="line"><a name="l00306"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#aca94458929dfce55cc114e323b8ffcaa"> 306</a></span>&#160; <span class="keyword">public</span> <span class="keywordtype">void</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#aca94458929dfce55cc114e323b8ffcaa">parseFile</a>(String table) {</div>
<div class="line"><a name="l00307"></a><span class="lineno"> 307</span>&#160; <span class="keywordflow">try</span> {</div>
<div class="line"><a name="l00308"></a><span class="lineno"> 308</span>&#160; <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#afad99420566a5fc57e962b9a9ca50124">open</a>(table);</div>
<div class="line"><a name="l00309"></a><span class="lineno"> 309</span>&#160; testCases.clear();</div>
<div class="line"><a name="l00310"></a><span class="lineno"> 310</span>&#160; <span class="keywordflow">while</span> (<a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a1f0ebab61210b9cbd4fb0034123357af">scanner</a>.hasNextLine()) {</div>
<div class="line"><a name="l00311"></a><span class="lineno"> 311</span>&#160; testCases.add(<a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a421aba184fc1ed5cdaa3d965d94c0c4f">parseOneTestCase</a>());</div>
<div class="line"><a name="l00312"></a><span class="lineno"> 312</span>&#160; }</div>
<div class="line"><a name="l00313"></a><span class="lineno"> 313</span>&#160; } <span class="keywordflow">finally</span> {</div>
<div class="line"><a name="l00314"></a><span class="lineno"> 314</span>&#160; <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#aae1d02532c09097bf6eecf3962d271e4">close</a>();</div>
<div class="line"><a name="l00315"></a><span class="lineno"> 315</span>&#160; }</div>
<div class="line"><a name="l00316"></a><span class="lineno"> 316</span>&#160; }</div>
<div class="line"><a name="l00317"></a><span class="lineno"> 317</span>&#160;</div>
<div class="line"><a name="l00318"></a><span class="lineno"><a class="line" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#aae1d02532c09097bf6eecf3962d271e4"> 318</a></span>&#160; <span class="keyword">private</span> <span class="keywordtype">void</span> <a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#aae1d02532c09097bf6eecf3962d271e4">close</a>() {</div>
<div class="line"><a name="l00319"></a><span class="lineno"> 319</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#af6a6bf7a155af0b4c1e830e74bd11111">reader</a> != null) {</div>
<div class="line"><a name="l00320"></a><span class="lineno"> 320</span>&#160; <span class="keywordflow">try</span> {</div>
<div class="line"><a name="l00321"></a><span class="lineno"> 321</span>&#160; reader.close();</div>
<div class="line"><a name="l00322"></a><span class="lineno"> 322</span>&#160; } <span class="keywordflow">catch</span> (IOException e) {</div>
<div class="line"><a name="l00323"></a><span class="lineno"> 323</span>&#160; fail(e.getMessage());</div>
<div class="line"><a name="l00324"></a><span class="lineno"> 324</span>&#160; }</div>
<div class="line"><a name="l00325"></a><span class="lineno"> 325</span>&#160; }</div>
<div class="line"><a name="l00326"></a><span class="lineno"> 326</span>&#160;</div>
<div class="line"><a name="l00327"></a><span class="lineno"> 327</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a1f0ebab61210b9cbd4fb0034123357af">scanner</a> != null) {</div>
<div class="line"><a name="l00328"></a><span class="lineno"> 328</span>&#160; scanner.close();</div>
<div class="line"><a name="l00329"></a><span class="lineno"> 329</span>&#160; }</div>
<div class="line"><a name="l00330"></a><span class="lineno"> 330</span>&#160; }</div>
<div class="line"><a name="l00331"></a><span class="lineno"> 331</span>&#160;}</div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_html_a304e8c38e6de1b43233a47ba5831d05f"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a304e8c38e6de1b43233a47ba5831d05f">com.cloudera.impala.testutil.TestFileParser.hasSetupSection</a></div><div class="ttdeci">boolean hasSetupSection()</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00213">TestFileParser.java:213</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase_html_ad99141f500fe30152aabe233d079c8e2"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#ad99141f500fe30152aabe233d079c8e2">com.cloudera.impala.testutil.TestFileParser.TestCase.getSectionContents</a></div><div class="ttdeci">ArrayList&lt; String &gt; getSectionContents(Section section)</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00105">TestFileParser.java:105</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_html_aae1d02532c09097bf6eecf3962d271e4"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#aae1d02532c09097bf6eecf3962d271e4">com.cloudera.impala.testutil.TestFileParser.close</a></div><div class="ttdeci">void close()</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00318">TestFileParser.java:318</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_html_afad99420566a5fc57e962b9a9ca50124"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#afad99420566a5fc57e962b9a9ca50124">com.cloudera.impala.testutil.TestFileParser.open</a></div><div class="ttdeci">void open(String table)</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00220">TestFileParser.java:220</a></div></div>
<div class="ttc" id="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section_html_af0643ce73ebb07f6165776254ba520d1"><div class="ttname"><a href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#af0643ce73ebb07f6165776254ba520d1">com.cloudera.impala.testutil.TestFileParser.Section.PARTITIONS</a></div><div class="ttdeci">PARTITIONS</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00065">TestFileParser.java:65</a></div></div>
<div class="ttc" id="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section_html_a193ad5d5e45787ec673ec66feb0c5f5b"><div class="ttname"><a href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a193ad5d5e45787ec673ec66feb0c5f5b">com.cloudera.impala.testutil.TestFileParser.Section.COLLABELS</a></div><div class="ttdeci">COLLABELS</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00060">TestFileParser.java:60</a></div></div>
<div class="ttc" id="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section_html_a52b2fe668d828145d7d81331bc3f01c8"><div class="ttname"><a href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a52b2fe668d828145d7d81331bc3f01c8">com.cloudera.impala.testutil.TestFileParser.Section.PLAN</a></div><div class="ttdeci">PLAN</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00062">TestFileParser.java:62</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase_html_a713c57194b3908dafdb762e31e7a81f1"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a713c57194b3908dafdb762e31e7a81f1">com.cloudera.impala.testutil.TestFileParser.TestCase.getSectionAsString</a></div><div class="ttdeci">String getSectionAsString(Section section, boolean withComments, String delimiter, String dbSuffix)</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00159">TestFileParser.java:159</a></div></div>
<div class="ttc" id="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section_html_abc504a968bbe5b9b5833bafdf0560b3b"><div class="ttname"><a href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#abc504a968bbe5b9b5833bafdf0560b3b">com.cloudera.impala.testutil.TestFileParser.Section.ERRORS</a></div><div class="ttdeci">ERRORS</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00067">TestFileParser.java:67</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_html_a1f0ebab61210b9cbd4fb0034123357af"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a1f0ebab61210b9cbd4fb0034123357af">com.cloudera.impala.testutil.TestFileParser.scanner</a></div><div class="ttdeci">Scanner scanner</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00191">TestFileParser.java:191</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase_html_ada2a696516d8b95ebd97f9cdfada5502"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#ada2a696516d8b95ebd97f9cdfada5502">com.cloudera.impala.testutil.TestFileParser.TestCase.getSectionContents</a></div><div class="ttdeci">ArrayList&lt; String &gt; getSectionContents(Section section, boolean withComments)</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00109">TestFileParser.java:109</a></div></div>
<div class="ttc" id="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section_html_a462d7d404b0713d1d521c582d62ef0ba"><div class="ttname"><a href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a462d7d404b0713d1d521c582d62ef0ba">com.cloudera.impala.testutil.TestFileParser.Section.QUERY</a></div><div class="ttdeci">QUERY</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00058">TestFileParser.java:58</a></div></div>
<div class="ttc" id="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section_html_a98152dabbffc26c9bbb90aa55e348b22"><div class="ttname"><a href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a98152dabbffc26c9bbb90aa55e348b22">com.cloudera.impala.testutil.TestFileParser.Section.SETUP</a></div><div class="ttdeci">SETUP</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00066">TestFileParser.java:66</a></div></div>
<div class="ttc" id="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section_html_ae5f0ef405c4045be59e5068b9437b496"><div class="ttname"><a href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#ae5f0ef405c4045be59e5068b9437b496">com.cloudera.impala.testutil.TestFileParser.Section.RESULTS</a></div><div class="ttdeci">RESULTS</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00061">TestFileParser.java:61</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase_html_a77660b95ff8930e06404daf2ebddcf84"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a77660b95ff8930e06404daf2ebddcf84">com.cloudera.impala.testutil.TestFileParser.TestCase.TestCase</a></div><div class="ttdeci">TestCase(int lineNum)</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00089">TestFileParser.java:89</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_html_a4c5f0519f06e6fe299fc7049311b8d37"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a4c5f0519f06e6fe299fc7049311b8d37">com.cloudera.impala.testutil.TestFileParser.defaultSectionOrder</a></div><div class="ttdeci">static final ArrayList&lt; Section &gt; defaultSectionOrder</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00198">TestFileParser.java:198</a></div></div>
<div class="ttc" id="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section_html_a6bf929527a84a0d1ac6cd49af8f7f9ce"><div class="ttname"><a href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a6bf929527a84a0d1ac6cd49af8f7f9ce">com.cloudera.impala.testutil.TestFileParser.Section.TYPES</a></div><div class="ttdeci">TYPES</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00059">TestFileParser.java:59</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_html_aea875dca2fdb7cdb620879d2b1debc1e"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#aea875dca2fdb7cdb620879d2b1debc1e">com.cloudera.impala.testutil.TestFileParser.lineNum</a></div><div class="ttdeci">int lineNum</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00188">TestFileParser.java:188</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase_html_a53e1a70c9c693d8ea87acf4dc4345e0f"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a53e1a70c9c693d8ea87acf4dc4345e0f">com.cloudera.impala.testutil.TestFileParser.TestCase.getSectionAsString</a></div><div class="ttdeci">String getSectionAsString(Section section, boolean withComments, String delimiter)</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00150">TestFileParser.java:150</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_html_adfd46b838f2f9fd42a0b0eef97e964b8"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#adfd46b838f2f9fd42a0b0eef97e964b8">com.cloudera.impala.testutil.TestFileParser.testCases</a></div><div class="ttdeci">final List&lt; TestCase &gt; testCases</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00186">TestFileParser.java:186</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_html_aca94458929dfce55cc114e323b8ffcaa"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#aca94458929dfce55cc114e323b8ffcaa">com.cloudera.impala.testutil.TestFileParser.parseFile</a></div><div class="ttdeci">void parseFile(String table)</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00306">TestFileParser.java:306</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_html_a20d15ee210293cd2865754e835dcdff4"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a20d15ee210293cd2865754e835dcdff4">com.cloudera.impala.testutil.TestFileParser.getTestFileName</a></div><div class="ttdeci">String getTestFileName()</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00209">TestFileParser.java:209</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase_html_ac5d52585e4ca778e14af53559cde867b"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#ac5d52585e4ca778e14af53559cde867b">com.cloudera.impala.testutil.TestFileParser.TestCase.expectedResultSections</a></div><div class="ttdeci">final EnumMap&lt; Section, ArrayList&lt; String &gt; &gt; expectedResultSections</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00083">TestFileParser.java:83</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_html_a06672e632d395275afdb4e16956b889a"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a06672e632d395275afdb4e16956b889a">com.cloudera.impala.testutil.TestFileParser.TestFileParser</a></div><div class="ttdeci">TestFileParser(String fileName)</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00201">TestFileParser.java:201</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase_html_a65c9e9086d4408a3ec39b93d080d59a5"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a65c9e9086d4408a3ec39b93d080d59a5">com.cloudera.impala.testutil.TestFileParser.TestCase.addSection</a></div><div class="ttdeci">void addSection(Section section, ArrayList&lt; String &gt; contents)</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00097">TestFileParser.java:97</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_html_af6a6bf7a155af0b4c1e830e74bd11111"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#af6a6bf7a155af0b4c1e830e74bd11111">com.cloudera.impala.testutil.TestFileParser.reader</a></div><div class="ttdeci">BufferedReader reader</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00190">TestFileParser.java:190</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase_html_ab82078412764355378233e3d04511498"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#ab82078412764355378233e3d04511498">com.cloudera.impala.testutil.TestFileParser.TestCase.isValid</a></div><div class="ttdeci">boolean isValid()</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00179">TestFileParser.java:179</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_html"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html">com.cloudera.impala.testutil.TestFileParser</a></div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00051">TestFileParser.java:51</a></div></div>
<div class="ttc" id="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section_html_a8568e931e029b23b759a6270f4a8394b"><div class="ttname"><a href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a8568e931e029b23b759a6270f4a8394b">com.cloudera.impala.testutil.TestFileParser.Section.FILEERRORS</a></div><div class="ttdeci">FILEERRORS</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00064">TestFileParser.java:64</a></div></div>
<div class="ttc" id="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section_html_aeea37292184bec2d2a95b47e1975cf36"><div class="ttname"><a href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#aeea37292184bec2d2a95b47e1975cf36">com.cloudera.impala.testutil.TestFileParser.Section.SCANRANGELOCATIONS</a></div><div class="ttdeci">SCANRANGELOCATIONS</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00068">TestFileParser.java:68</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_html_a421aba184fc1ed5cdaa3d965d94c0c4f"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a421aba184fc1ed5cdaa3d965d94c0c4f">com.cloudera.impala.testutil.TestFileParser.parseOneTestCase</a></div><div class="ttdeci">TestCase parseOneTestCase()</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00235">TestFileParser.java:235</a></div></div>
<div class="ttc" id="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section_html_a6cacaaf0604748f6149bf900ed9600bd"><div class="ttname"><a href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a6cacaaf0604748f6149bf900ed9600bd">com.cloudera.impala.testutil.TestFileParser.Section.LINEAGE</a></div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00069">TestFileParser.java:69</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase_html"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html">com.cloudera.impala.testutil.TestFileParser.TestCase</a></div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00081">TestFileParser.java:81</a></div></div>
<div class="ttc" id="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section_html_aa5b44b7e223257ad5442be57c879f3ff"><div class="ttname"><a href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#aa5b44b7e223257ad5442be57c879f3ff">com.cloudera.impala.testutil.TestFileParser.Section.getHeader</a></div><div class="ttdeci">String getHeader()</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00072">TestFileParser.java:72</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase_html_a373b3b44befa23aba43dcfab8a6ef49a"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a373b3b44befa23aba43dcfab8a6ef49a">com.cloudera.impala.testutil.TestFileParser.TestCase.startLineNum</a></div><div class="ttdeci">final int startLineNum</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00087">TestFileParser.java:87</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase_html_aa8a7dc090d5020f51919a228b185478e"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#aa8a7dc090d5020f51919a228b185478e">com.cloudera.impala.testutil.TestFileParser.TestCase.getQuery</a></div><div class="ttdeci">String getQuery()</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00172">TestFileParser.java:172</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_html_a789f5fbc89b3122f3c40ba0f63a81289"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a789f5fbc89b3122f3c40ba0f63a81289">com.cloudera.impala.testutil.TestFileParser.LOG</a></div><div class="ttdeci">static final Logger LOG</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00052">TestFileParser.java:52</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_html_af95d793a2bbc5c1847cd960d0d9ccb21"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#af95d793a2bbc5c1847cd960d0d9ccb21">com.cloudera.impala.testutil.TestFileParser.parseFile</a></div><div class="ttdeci">void parseFile()</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00302">TestFileParser.java:302</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase_html_a4d64bcb01b4b7b0884d1bce22bc29586"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a4d64bcb01b4b7b0884d1bce22bc29586">com.cloudera.impala.testutil.TestFileParser.TestCase.getStartingLineNum</a></div><div class="ttdeci">int getStartingLineNum()</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00093">TestFileParser.java:93</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_html_aa6a870ac3f8a0ddff0a310a53a1410d7"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#aa6a870ac3f8a0ddff0a310a53a1410d7">com.cloudera.impala.testutil.TestFileParser.getTestCases</a></div><div class="ttdeci">List&lt; TestCase &gt; getTestCases()</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00205">TestFileParser.java:205</a></div></div>
<div class="ttc" id="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section_html_a06182a858208bd23a9433699c153928b"><div class="ttname"><a href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html#a06182a858208bd23a9433699c153928b">com.cloudera.impala.testutil.TestFileParser.Section.DISTRIBUTEDPLAN</a></div><div class="ttdeci">DISTRIBUTEDPLAN</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00063">TestFileParser.java:63</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_html_a5835d5816a8d5ed89c3df0b99aa2a376"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser.html#a5835d5816a8d5ed89c3df0b99aa2a376">com.cloudera.impala.testutil.TestFileParser.fileName</a></div><div class="ttdeci">final String fileName</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00189">TestFileParser.java:189</a></div></div>
<div class="ttc" id="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section_html"><div class="ttname"><a href="enumcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1Section.html">com.cloudera.impala.testutil.TestFileParser.Section</a></div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00057">TestFileParser.java:57</a></div></div>
<div class="ttc" id="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase_html_a6a8285a0eef8ebdc6d66eabe0b69f201"><div class="ttname"><a href="classcom_1_1cloudera_1_1impala_1_1testutil_1_1TestFileParser_1_1TestCase.html#a6a8285a0eef8ebdc6d66eabe0b69f201">com.cloudera.impala.testutil.TestFileParser.TestCase.getSectionContents</a></div><div class="ttdeci">ArrayList&lt; String &gt; getSectionContents(Section section, boolean withComments, String dbSuffix)</div><div class="ttdef"><b>Definition:</b> <a href="TestFileParser_8java_source.html#l00125">TestFileParser.java:125</a></div></div>
</div><!-- fragment --></div><!-- contents -->
</div><!-- doc-content -->
<!-- start footer part -->
<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
<ul>
<li class="navelem"><a class="el" href="dir_ca2797c59c2e868cd2eca72571423f6a.html">fe</a></li><li class="navelem"><a class="el" href="dir_9456c03c9c6e5a96e843b28fc5c6395b.html">src</a></li><li class="navelem"><a class="el" href="dir_5e883f6dc74bff61c96421c8f6a7e178.html">test</a></li><li class="navelem"><a class="el" href="dir_90203b64d536a3b270171a34c42a21ea.html">java</a></li><li class="navelem"><a class="el" href="dir_11616761b8bb98abd72e3e6bfe811524.html">com</a></li><li class="navelem"><a class="el" href="dir_b7afc6fa9388eeabd689520334a456b3.html">cloudera</a></li><li class="navelem"><a class="el" href="dir_85b47c81f280e02ede8246bf72165fa2.html">impala</a></li><li class="navelem"><a class="el" href="dir_5169f189d7f3e0aed981b4f55bf339a2.html">testutil</a></li><li class="navelem"><a class="el" href="TestFileParser_8java.html">TestFileParser.java</a></li>
<li class="footer">Generated on Thu May 7 2015 16:10:39 for Impala by
<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.6 </li>
</ul>
</div>
</body>
</html>