org.citrusframework.sql.xml.Sql Maven / Gradle / Ivy
/*
* Copyright the original author or authors.
*
* 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 org.citrusframework.sql.xml;
import java.nio.charset.Charset;
import java.nio.charset.StandardCharsets;
import java.util.ArrayList;
import java.util.List;
import jakarta.xml.bind.annotation.XmlAccessType;
import jakarta.xml.bind.annotation.XmlAccessorType;
import jakarta.xml.bind.annotation.XmlAttribute;
import jakarta.xml.bind.annotation.XmlElement;
import jakarta.xml.bind.annotation.XmlRootElement;
import jakarta.xml.bind.annotation.XmlType;
import jakarta.xml.bind.annotation.XmlValue;
import org.citrusframework.TestActionBuilder;
import org.citrusframework.actions.AbstractDatabaseConnectingTestAction;
import org.citrusframework.actions.ExecuteSQLAction;
import org.citrusframework.actions.ExecuteSQLQueryAction;
import org.citrusframework.spi.ReferenceResolver;
import org.citrusframework.spi.ReferenceResolverAware;
import org.citrusframework.util.StringUtils;
import org.springframework.transaction.PlatformTransactionManager;
@XmlRootElement(name = "sql")
public class Sql implements TestActionBuilder, ReferenceResolverAware {
private AbstractDatabaseConnectingTestAction.Builder, ?> builder = new ExecuteSQLAction.Builder();
private String transactionManager;
private ReferenceResolver referenceResolver;
@XmlElement(name = "validate")
protected List validates;
@XmlElement(name = "extract")
protected List extracts;
@XmlElement
public Sql setDescription(String value) {
builder.description(value);
return this;
}
@XmlAttribute(name = "datasource")
public Sql setDataSource(String dataSource) {
builder.dataSource(dataSource);
builder.name(String.format("sql:%s", dataSource));
return this;
}
@XmlElement(required = true)
public Sql setStatements(Statements statements) {
statements.getStatements().forEach(builder::statement);
if (statements.file != null) {
builder.sqlResource(statements.file);
}
return this;
}
@XmlElement
public Sql setTransaction(Transaction transaction) {
if (transaction.manager != null) {
transactionManager = transaction.manager;
}
if (transaction.isolationLevel != null) {
builder.transactionIsolationLevel(transaction.isolationLevel);
}
if (transaction.timeout != null) {
builder.transactionTimeout(transaction.timeout);
}
return this;
}
@XmlAttribute(name = "ignore-errors")
public Sql setIgnoreErrors(boolean value) {
if (builder instanceof ExecuteSQLAction.Builder) {
((ExecuteSQLAction.Builder) builder).ignoreErrors(value);
}
return this;
}
public List getValidates() {
if (validates == null) {
validates = new ArrayList<>();
}
return this.validates;
}
public List getExtracts() {
if (extracts == null) {
extracts = new ArrayList<>();
}
return this.extracts;
}
@Override
public AbstractDatabaseConnectingTestAction build() {
if (referenceResolver != null) {
builder.withReferenceResolver(referenceResolver);
if (transactionManager != null) {
builder.transactionManager(referenceResolver.resolve(transactionManager, PlatformTransactionManager.class));
}
}
for (Validate validate : getValidates()) {
if (validate.column != null) {
if (validate.value != null) {
asSqlQueryBuilder().validate(validate.column, validate.value);
}
if (validate.getValues() != null) {
asSqlQueryBuilder().validate(validate.column, validate.getValues().getValues().toArray(String[]::new));
}
}
Validate.Script script = validate.script;
// check for nested validate script child node
if (script != null) {
String type = script.getType();
String filePath = script.getFile();
if (StringUtils.hasText(filePath)) {
if (script.getCharset() != null) {
asSqlQueryBuilder().validateScriptResource(filePath, type, Charset.forName(script.getCharset()));
} else {
asSqlQueryBuilder().validateScriptResource(filePath, type, StandardCharsets.UTF_8);
}
} else if (script.getValue() != null) {
asSqlQueryBuilder().validateScript(script.getValue().trim(), type);
}
}
}
for (Extract extract : getExtracts()) {
asSqlQueryBuilder().extract(extract.column, extract.variable);
}
return builder.build();
}
@Override
public void setReferenceResolver(ReferenceResolver referenceResolver) {
this.referenceResolver = referenceResolver;
}
/**
* Converts sql action builder to query action builder.
* @return
*/
private ExecuteSQLQueryAction.Builder asSqlQueryBuilder() {
if (builder instanceof ExecuteSQLQueryAction.Builder) {
return (ExecuteSQLQueryAction.Builder) builder;
}
ExecuteSQLQueryAction.Builder sqlQueryBuilder = new ExecuteSQLQueryAction.Builder();
AbstractDatabaseConnectingTestAction base = builder.build();
sqlQueryBuilder.description(base.getDescription());
sqlQueryBuilder.dataSource(base.getDataSource());
sqlQueryBuilder.jdbcTemplate(base.getJdbcTemplate());
sqlQueryBuilder.sqlResource(base.getSqlResourcePath());
sqlQueryBuilder.statements(base.getStatements());
sqlQueryBuilder.transactionManager(base.getTransactionManager());
sqlQueryBuilder.transactionTimeout(base.getTransactionTimeout());
sqlQueryBuilder.transactionIsolationLevel(base.getTransactionIsolationLevel());
sqlQueryBuilder.actor(base.getActor());
builder = sqlQueryBuilder;
return sqlQueryBuilder;
}
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "", propOrder = {
"statements"
})
public static class Statements {
@XmlElement(name = "statement")
private List statements;
@XmlAttribute(name = "file")
protected String file;
public String getFile() {
return file;
}
public void setFile(String value) {
this.file = value;
}
public List getStatements() {
if (statements == null) {
statements = new ArrayList<>();
}
return statements;
}
}
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "")
public static class Transaction {
@XmlAttribute(name = "manager")
protected String manager;
@XmlAttribute(name = "timeout")
protected String timeout;
@XmlAttribute(name = "isolation-level")
protected String isolationLevel;
public String getManager() {
return manager;
}
public void setManager(String manager) {
this.manager = manager;
}
public String getTimeout() {
return timeout;
}
public void setTimeout(String timeout) {
this.timeout = timeout;
}
public String getIsolationLevel() {
return isolationLevel;
}
public void setIsolationLevel(String isolationLevel) {
this.isolationLevel = isolationLevel;
}
}
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "")
public static class Extract {
@XmlAttribute(name = "column", required = true)
protected String column;
@XmlAttribute(name = "variable", required = true)
protected String variable;
public String getColumn() {
return column;
}
public void setColumn(String value) {
this.column = value;
}
public String getVariable() {
return variable;
}
public void setVariable(String value) {
this.variable = value;
}
}
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "", propOrder = {
"values",
"script"
})
public static class Validate {
@XmlElement
protected Values values;
@XmlAttribute(name = "column")
protected String column;
@XmlAttribute(name = "value")
protected String value;
@XmlElement
protected Script script;
public Values getValues() {
return values;
}
public void setValues(Values value) {
this.values = value;
}
public String getColumn() {
return column;
}
public void setColumn(String value) {
this.column = value;
}
public String getValue() {
return value;
}
public void setValue(String value) {
this.value = value;
}
public Script getScript() {
return script;
}
public void setScript(Script script) {
this.script = script;
}
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "", propOrder = {
"values"
})
public static class Values {
@XmlElement(name = "value", required = true)
protected List values;
public List getValues() {
if (values == null) {
values = new ArrayList<>();
}
return this.values;
}
}
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "", propOrder = {
"value"
})
public static class Script {
@XmlValue
protected String value;
@XmlAttribute(name = "type", required = true)
protected String type;
@XmlAttribute(name = "file")
protected String file;
@XmlAttribute(name = "charset")
protected String charset;
public String getValue() {
return value;
}
public void setValue(String value) {
this.value = value;
}
public String getType() {
return type;
}
public void setType(String value) {
this.type = value;
}
public String getFile() {
return file;
}
public void setFile(String value) {
this.file = value;
}
public void setCharset(String charset) {
this.charset = charset;
}
public String getCharset() {
return charset;
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy