SelectXMLSerializeTest.java

/*-
 * #%L
 * JSQLParser library
 * %%
 * Copyright (C) 2004 - 2020 JSQLParser
 * %%
 * Dual licensed under GNU LGPL 2.1 or Apache License 2.0
 * #L%
 */
package net.sf.jsqlparser.statement.select;

import net.sf.jsqlparser.JSQLParserException;
import org.junit.jupiter.api.Test;

import static net.sf.jsqlparser.test.TestUtils.assertSqlCanBeParsedAndDeparsed;

/**
 *
 * @author tobens
 */
public class SelectXMLSerializeTest {

    @Test
    public void testXmlAgg1() throws JSQLParserException {
        assertSqlCanBeParsedAndDeparsed(
                "SELECT xmlserialize(xmlagg(xmltext(COMMENT_LINE) ORDER BY COMMENT_SEQUENCE) AS varchar (1024)) FROM mytable GROUP BY COMMENT_NUMBER");
    }

    @Test
    public void testXmlAgg2() throws JSQLParserException {
        assertSqlCanBeParsedAndDeparsed(
                "SELECT xmlserialize(xmlagg(xmltext(COMMENT_LINE) ORDER BY COMMENT_SEQUENCE, COMMENT_LINE) AS varchar (1024)) FROM mytable GROUP BY COMMENT_NUMBER");
    }

    @Test
    public void testXmlAgg3() throws JSQLParserException {
        assertSqlCanBeParsedAndDeparsed(
                "SELECT xmlserialize(xmlagg(xmltext(COMMENT_LINE) ORDER BY COMMENT_SEQUENCE) AS varchar (1024))");
    }

    @Test
    public void testXmlAgg4() throws JSQLParserException {
        assertSqlCanBeParsedAndDeparsed(
                "SELECT xmlserialize(xmlagg(xmltext(COMMENT_LINE_PREFIX || COMMENT_LINE) ORDER BY COMMENT_SEQUENCE) AS varchar (1024))");
    }

    @Test
    public void testXmlAgg5() throws JSQLParserException {
        assertSqlCanBeParsedAndDeparsed(
                "SELECT xmlserialize(xmlagg(xmltext(CONCAT(', ', TRIM(SOME_COLUMN))) ORDER BY MY_SEQUENCE) AS varchar (1024))",
                true);
    }

    @Test
    public void testXmlAgg6() throws JSQLParserException {
        assertSqlCanBeParsedAndDeparsed(
                "SELECT xmlserialize(xmlagg(xmltext(COMMENT_LINE)) AS varchar (1024))");
    }
}