ConnectExpressionsVisitorTest.java
/*-
* #%L
* JSQLParser library
* %%
* Copyright (C) 2004 - 2019 JSQLParser
* %%
* Dual licensed under GNU LGPL 2.1 or Apache License 2.0
* #L%
*/
package net.sf.jsqlparser.util;
import net.sf.jsqlparser.JSQLParserException;
import net.sf.jsqlparser.expression.BinaryExpression;
import net.sf.jsqlparser.expression.operators.arithmetic.Addition;
import net.sf.jsqlparser.expression.operators.arithmetic.Concat;
import net.sf.jsqlparser.parser.CCJSqlParserManager;
import net.sf.jsqlparser.statement.select.Select;
import org.junit.jupiter.api.Test;
import java.io.StringReader;
import static org.junit.jupiter.api.Assertions.assertEquals;
public class ConnectExpressionsVisitorTest {
private final CCJSqlParserManager parserManager = new CCJSqlParserManager();
@Test
public void testVisit_PlainSelect_concat() throws JSQLParserException {
String sql = "select a,b,c from test";
Select select = (Select) parserManager.parse(new StringReader(sql));
ConnectExpressionsVisitor<Void> instance = new ConnectExpressionsVisitor<>() {
@Override
protected BinaryExpression createBinaryExpression() {
return new Concat();
}
};
select.accept(instance, null);
assertEquals("SELECT a || b || c AS expr FROM test", select.toString());
}
@Test
public void testVisit_PlainSelect_addition() throws JSQLParserException {
String sql = "select a,b,c from test";
Select select = (Select) parserManager.parse(new StringReader(sql));
ConnectExpressionsVisitor<Void> instance = new ConnectExpressionsVisitor<>("testexpr") {
@Override
protected BinaryExpression createBinaryExpression() {
return new Addition();
}
};
select.accept(instance, null);
assertEquals("SELECT a + b + c AS testexpr FROM test", select.toString());
}
}