blob: 42d5ececf7ba5c92b05787febd3b45018125faab [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.pig.test;
import java.io.ByteArrayInputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.PrintStream;
import java.util.Map;
import java.util.HashMap;
import java.util.Properties;
import org.junit.Test;
import junit.framework.TestCase;
import org.apache.pig.PigServer;
import org.apache.pig.impl.PigContext;
import org.apache.pig.impl.logicalLayer.* ;
import org.apache.pig.impl.logicalLayer.parser.* ;
import org.apache.pig.impl.eval.* ;
import org.apache.pig.impl.eval.cond.* ;
public class TestPigScriptParser extends TestCase {
@Test
public void testParserWithEscapeCharacters() throws Exception {
// All the needed variables
Map<String, LogicalPlan> aliases = new HashMap<String, LogicalPlan>() ;
Map<OperatorKey, LogicalOperator> opTable = new HashMap<OperatorKey, LogicalOperator>() ;
PigContext pigContext = new PigContext(PigServer.ExecType.LOCAL, new Properties()) ;
String tempFile = this.prepareTempFile() ;
// Start the real parsing job
{
// Initial statement
String query = String.format("A = LOAD '%s' ;", Util.encodeEscape(tempFile)) ;
ByteArrayInputStream in = new ByteArrayInputStream(query.getBytes());
QueryParser parser = new QueryParser(in, pigContext, "scope", aliases, opTable) ;
LogicalPlan lp = parser.Parse() ;
aliases.put(lp.getAlias(), lp) ;
}
{
// Normal condition
String query = "B1 = filter A by $0 eq 'This is a test string' ;" ;
checkParsedConstContent(aliases, opTable, pigContext,
query, "This is a test string") ;
}
{
// single-quote condition
String query = "B2 = filter A by $0 eq 'This is a test \\'string' ;" ;
checkParsedConstContent(aliases, opTable, pigContext,
query, "This is a test 'string") ;
}
{
// newline condition
String query = "B3 = filter A by $0 eq 'This is a test \\nstring' ;" ;
checkParsedConstContent(aliases, opTable, pigContext,
query, "This is a test \nstring") ;
}
{
// Unicode
String query = "B4 = filter A by $0 eq 'This is a test \\uD30C\\uC774string' ;" ;
checkParsedConstContent(aliases, opTable, pigContext,
query, "This is a test \uD30C\uC774string") ;
}
}
private void checkParsedConstContent(Map<String, LogicalPlan> aliases,
Map<OperatorKey, LogicalOperator> opTable,
PigContext pigContext,
String query,
String expectedContent)
throws Exception {
// Run the parser
ByteArrayInputStream in = new ByteArrayInputStream(query.getBytes());
QueryParser parser = new QueryParser(in, pigContext, "scope", aliases, opTable) ;
LogicalPlan lp = parser.Parse() ;
aliases.put(lp.getAlias(), lp) ;
// Digging down the tree
LOEval eval = (LOEval)opTable.get(lp.getRoot()) ;
CompCond compCond = ((CompCond)(((FilterSpec) eval.getSpec()).cond)) ;
// Here is the actual check logic
if (compCond.left instanceof ConstSpec) {
ConstSpec constSpec = (ConstSpec) compCond.left ;
assertTrue("Must be equal",
constSpec.constant.equals(expectedContent)) ;
}
// If not left, it must be right.
else {
ConstSpec constSpec = (ConstSpec) compCond.right ;
assertTrue("Must be equal",
constSpec.constant.equals(expectedContent)) ;
}
}
private String prepareTempFile() throws IOException {
File inputFile = File.createTempFile("test", "txt");
inputFile.deleteOnExit() ;
PrintStream ps = new PrintStream(new FileOutputStream(inputFile));
ps.println("hohoho") ;
ps.close();
return inputFile.getPath() ;
}
}