How to use parseSqlAction method of com.consol.citrus.config.xml.SQLActionParser class

Best Citrus code snippet using com.consol.citrus.config.xml.SQLActionParser.parseSqlAction

Source:SQLActionParser.java Github

copy

Full Screen

...49 List<Element> extractElements = DomUtils.getChildElementsByTagName(element, "extract");50 Element scriptValidationElement = DomUtils.getChildElementByTagName(element, "validate-script");51 52 if (CollectionUtils.isEmpty(validateElements) && CollectionUtils.isEmpty(extractElements) && scriptValidationElement == null) {53 beanDefinition = parseSqlAction(element);54 beanDefinition.addPropertyValue("name", "sqlUpdate:" + dataSource);55 } else {56 beanDefinition = parseSqlQueryAction(element, scriptValidationElement, validateElements, extractElements);57 beanDefinition.addPropertyValue("name", "sqlQuery:" + dataSource);58 }59 60 beanDefinition.addPropertyReference("dataSource", dataSource);61 BeanDefinitionParserUtils.setPropertyReference(beanDefinition, element.getAttribute("transaction-manager"), "transactionManager");62 BeanDefinitionParserUtils.setPropertyValue(beanDefinition, element.getAttribute("transaction-timeout"), "transactionTimeout");63 BeanDefinitionParserUtils.setPropertyValue(beanDefinition, element.getAttribute("transaction-isolation-level"), "transactionIsolationLevel");64 DescriptionElementParser.doParse(element, beanDefinition);65 List<String> statements = new ArrayList<String>();66 List<?> stmtElements = DomUtils.getChildElementsByTagName(element, "statement");67 for (Iterator<?> iter = stmtElements.iterator(); iter.hasNext();) {68 Element stmt = (Element) iter.next();69 statements.add(DomUtils.getTextValue(stmt));70 }71 beanDefinition.addPropertyValue("statements", statements);72 Element sqlResourceElement = DomUtils.getChildElementByTagName(element, "resource");73 if (sqlResourceElement != null) {74 beanDefinition.addPropertyValue("sqlResourcePath", sqlResourceElement.getAttribute("file"));75 }76 return beanDefinition.getBeanDefinition();77 }78 79 /**80 * Parses SQL action just executing a set of statements.81 * @param element82 * @return83 */84 private BeanDefinitionBuilder parseSqlAction(Element element) {85 BeanDefinitionBuilder beanDefinition = BeanDefinitionBuilder.rootBeanDefinition(ExecuteSQLAction.class);86 87 String ignoreErrors = element.getAttribute("ignore-errors");88 if (ignoreErrors != null && ignoreErrors.equals("true")) {89 beanDefinition.addPropertyValue("ignoreErrors", true);90 }91 92 return beanDefinition;93 }94 /**95 * Parses SQL query action with result set validation elements.96 * @param element the root element.97 * @param scriptValidationElement the optional script validation element.98 * @param validateElements validation elements....

Full Screen

Full Screen

parseSqlAction

Using AI Code Generation

copy

Full Screen

1package com.consol.citrus.config.xml;2import java.util.Map;3import org.springframework.beans.factory.support.BeanDefinitionBuilder;4import org.springframework.util.xml.DomUtils;5import org.testng.Assert;6import org.testng.annotations.Test;7import org.w3c.dom.Element;8import com.consol.citrus.actions.ExecuteSQLQueryAction;9import com.consol.citrus.testng.AbstractActionParserTest;10public class SQLActionParserTest extends AbstractActionParserTest<ExecuteSQLQueryAction> {11 public void testSQLActionParser() {12 assertActionCount(2);13 assertActionClassAndName(ExecuteSQLQueryAction.class, "sql:foo");14 assertActionClassAndName(ExecuteSQLQueryAction.class, "sql:bar");15 ExecuteSQLQueryAction action = getNextTestActionFromTest();16 Assert.assertEquals(action.getDataSource(), beanDefinitionContext.getBeanDefinition("dataSource"));17 Assert.assertEquals(action.getSqlResourcePath(), "classpath:com/consol/citrus/sql/test.sql");18 Assert.assertEquals(action.getResultSet(), "rs");19 Assert.assertEquals(action.getVariableDefinitions().size(), 2L);20 Assert.assertEquals(action.getVariableDefinitions().get("id"), "${rs[0].id}");21 Assert.assertEquals(action.getVariableDefinitions().get("name"), "${rs[0].name}");22 action = getNextTestActionFromTest();23 Assert.assertEquals(action.getDataSource(), beanDefinitionContext.getBeanDefinition("dataSource"));24 Assert.assertEquals(action.getSqlResourcePath(), "classpath:com/consol/citrus/sql/test.sql");25 Assert.assertEquals(action.getResultSet(), "rs");26 Assert.assertEquals(action.getVariableDefinitions().size(), 2L);27 Assert.assertEquals(action.getVariableDefinitions().get("id"), "${rs[0].id}");28 Assert.assertEquals(action.getVariableDefinitions().get("name"), "${rs[0].name}");29 }30 protected String getActionType() {31 return "sql";32 }33 protected String getControlFilePath() {34 return "com/consol/citrus/config/xml/sql-action-ctrl.xml";35 }36 protected void createSpringApplicationContext() {37 super.createSpringApplicationContext();38 Map<String, String> sqlResources = getControlDocument().getSqlResources();39 for (Map.Entry<String, String> entry : sqlResources.entrySet()) {

Full Screen

Full Screen

parseSqlAction

Using AI Code Generation

copy

Full Screen

1public class SQLActionParserTest extends AbstractActionParserTest<SQLAction> {2 public void testSQLActionParser() {3 assertActionCount(4);4 assertActionClassAndName(SQLAction.class, "sql");5 SQLAction action = getNextTestActionFromTest();6 Assert.assertEquals(action.getDataSource(), beanDefinitionContext.getBeanDefinition("testDataSource"));7 Assert.assertEquals(action.getSqlResourcePath(), "classpath:com/consol/citrus/actions/test.sql");8 Assert.assertEquals(action.getSqlResource(), new ClassPathResource("com/consol/citrus/actions/test.sql"));9 Assert.assertEquals(action.getSql(), "INSERT INTO test_table (id, name) VALUES (1, 'Test')");10 Assert.assertEquals(action.getStatementType(), StatementType.PREPARED_STATEMENT);11 Assert.assertEquals(action.getParameters().size(), 2L);12 Assert.assertEquals(action.getParameters().get(0).toString(), "1");13 Assert.assertEquals(action.getParameters().get(1).toString(), "Test");14 Assert.assertEquals(action.getValidationCallback(), beanDefinitionContext.getBeanDefinition("validationCallback"));15 Assert.assertEquals(action.getValidationCallbackClass(), TestValidationCallback.class);16 Assert.assertEquals(action.getValidationCallbackInstance().getClass(), TestValidationCallback.class);17 Assert.assertTrue(action.isIgnoreErrors());18 action = getNextTestActionFromTest();19 Assert.assertEquals(action.getDataSource(), beanDefinitionContext.getBeanDefinition("testDataSource"));20 Assert.assertEquals(action.getSqlResourcePath(), "classpath:com/consol/citrus/actions/test.sql");21 Assert.assertEquals(action.getSqlResource(), new ClassPathResource("com/consol/citrus/actions/test.sql"));22 Assert.assertEquals(action.getSql(), "INSERT INTO test_table (id, name) VALUES (1, 'Test')");23 Assert.assertEquals(action.getStatementType(), StatementType.PREPARED_STATEMENT);24 Assert.assertEquals(action.getParameters().size(), 2L);25 Assert.assertEquals(action.getParameters().get(0).toString(), "1");26 Assert.assertEquals(action.getParameters().get(1).toString(), "Test");27 Assert.assertEquals(action.getValidationCallback(), beanDefinitionContext.getBeanDefinition("validationCallback"));28 Assert.assertEquals(action.getValidationCallbackClass(), TestValidationCallback.class);29 Assert.assertEquals(action.getValidationCallbackInstance().getClass(), TestValidationCallback.class);30 Assert.assertFalse(action.isIgnoreErrors());31 action = getNextTestActionFromTest();

Full Screen

Full Screen

parseSqlAction

Using AI Code Generation

copy

Full Screen

1public class SQLActionParserTest {2 public void testParseSqlAction() {3 SQLActionParser parser = new SQLActionParser();4 Element sqlElement = new DOMElement("sql");5 sqlElement.addAttribute("query", "select * from employee");6 sqlElement.addAttribute("statement", "select * from employee");7 sqlElement.addAttribute("statement-resource", "classpath:sql/select.sql");8 sqlElement.addAttribute("datasource", "jdbc/myDataSource");9 sqlElement.addAttribute("timeout", "10000");10 sqlElement.addAttribute("transactional", "true");11 sqlElement.addAttribute("ignore-errors", "true");12 sqlElement.addAttribute("result", "myResult");13 sqlElement.addAttribute("auto-commit", "true");14 sqlElement.addAttribute("fetch-size", "100");15 sqlElement.addAttribute("max-rows", "100");16 sqlElement.addAttribute("query-timeout", "10000");17 sqlElement.addAttribute("fetch-direction", "FETCH_FORWARD");18 sqlElement.addAttribute("escape-processing", "false");19 sqlElement.addAttribute("poolable", "true");20 sqlElement.addAttribute("query-timeout", "10000");21 sqlElement.addAttribute("fetch-direction", "FETCH_FORWARD");22 sqlElement.addAttribute("escape-processing", "false");23 sqlElement.addAttribute("poolable", "true");24 sqlElement.addAttribute("result-map", "resultMap");25 sqlElement.addAttribute("result-set", "resultSet");26 sqlElement.addAttribute("result-set-index", "0");27 sqlElement.addAttribute("result-set-type", "TYPE_FORWARD_ONLY");28 sqlElement.addAttribute("result-set-concurrency", "CONCUR_READ_ONLY");29 sqlElement.addAttribute("result-set-holdability", "HOLD_CURSORS_OVER_COMMIT");30 sqlElement.addAttribute("result-set-cursor-name", "myCursor");31 sqlElement.addAttribute("result-set-rows", "10");32 sqlElement.addAttribute("result-set-start-row", "10");33 sqlElement.addAttribute("result-set-max-rows", "10");34 sqlElement.addAttribute("result-set-max-field-size", "10");35 sqlElement.addAttribute("result-set-fetch-size", "10");36 sqlElement.addAttribute("result-set-fetch-direction", "FETCH_FORWARD");37 sqlElement.addAttribute("result-set-escape-processing", "false");

Full Screen

Full Screen

Automation Testing Tutorials

Learn to execute automation testing from scratch with LambdaTest Learning Hub. Right from setting up the prerequisites to run your first automation test, to following best practices and diving deeper into advanced test scenarios. LambdaTest Learning Hubs compile a list of step-by-step guides to help you be proficient with different test automation frameworks i.e. Selenium, Cypress, TestNG etc.

LambdaTest Learning Hubs:

YouTube

You could also refer to video tutorials over LambdaTest YouTube channel to get step by step demonstration from industry experts.

Run Citrus automation tests on LambdaTest cloud grid

Perform automation testing on 3000+ real desktop and mobile devices online.

Try LambdaTest Now !!

Get 100 minutes of automation test minutes FREE!!

Next-Gen App & Browser Testing Cloud

Was this article helpful?

Helpful

NotHelpful