io.prestosql.verifier.Query Maven / Gradle / Ivy
/*
* Licensed 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 io.prestosql.verifier;
import com.google.common.collect.ImmutableMap;
import java.util.List;
import java.util.Map;
import static com.google.common.collect.ImmutableList.toImmutableList;
public class Query
{
private final String catalog;
private final String schema;
private final List preQueries;
private final String query;
private final List postQueries;
private final String username;
private final String password;
private final Map sessionProperties;
public Query(
String catalog,
String schema,
List preQueries,
String query,
List postQueries,
String username,
String password,
Map sessionProperties)
{
this.catalog = catalog;
this.schema = schema;
this.preQueries = preQueries.stream().map(Query::clean).collect(toImmutableList());
this.query = clean(query);
this.postQueries = postQueries.stream().map(Query::clean).collect(toImmutableList());
this.username = username;
this.password = password;
this.sessionProperties = ImmutableMap.copyOf(sessionProperties);
}
public String getCatalog()
{
return catalog;
}
public String getSchema()
{
return schema;
}
public List getPreQueries()
{
return preQueries;
}
public String getQuery()
{
return query;
}
public List getPostQueries()
{
return postQueries;
}
public String getUsername()
{
return username;
}
public String getPassword()
{
return password;
}
public Map getSessionProperties()
{
return sessionProperties;
}
private static String clean(String sql)
{
sql = sql.replaceAll("\t", " ");
sql = sql.replaceAll("\n+", "\n");
sql = sql.trim();
while (sql.endsWith(";")) {
sql = sql.substring(0, sql.length() - 1).trim();
}
return sql;
}
}