/* * JBoss, Home of Professional Open Source. * See the COPYRIGHT.txt file distributed with this work for information * regarding copyright ownership. Some portions may be licensed * to Red Hat, Inc. under one or more contributor license agreements. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA * 02110-1301 USA. */ package org.teiid.core.types; import java.io.StringReader; import java.util.StringTokenizer; import javax.xml.transform.stream.StreamSource; import org.teiid.core.types.StandardXMLTranslator; import junit.framework.TestCase; /** * XML StreamSource Translator. */ public class TestXMLStreamSourceTranslator extends TestCase { private static final String sourceXML = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>" + //$NON-NLS-1$ "<Books:bookCollection xmlns:Books=\"http://www.metamatrix.com/XMLSchema/DataSets/Books\">\r\n" + //$NON-NLS-1$ " <book isbn=\"0-7356-0877-6\">\r\n" + //$NON-NLS-1$ " <title>After the Gold Rush</title>\r\n" + //$NON-NLS-1$ " <subtitle>Creating a True Profession of Software Engineering</subtitle>\r\n" + //$NON-NLS-1$ " <edition>1</edition>\r\n" + //$NON-NLS-1$ " <authors>\r\n" + //$NON-NLS-1$ " <author>McConnell</author>\r\n" + //$NON-NLS-1$ " </authors>\r\n" + //$NON-NLS-1$ " <publishingInformation>\r\n" + //$NON-NLS-1$ " <publisher>Microsoft Press</publisher>\r\n" + //$NON-NLS-1$ " <publishDate>1999</publishDate>\r\n" + //$NON-NLS-1$ " </publishingInformation>\r\n" + //$NON-NLS-1$ " </book>\r\n" + //$NON-NLS-1$ " <book isbn=\"1-55615-484-4\">\r\n" + //$NON-NLS-1$ " <title>Code Complete</title>\r\n" + //$NON-NLS-1$ " <subtitle>A Practical Handbook of Software Construction</subtitle>\r\n" + //$NON-NLS-1$ " <edition>1</edition>\r\n" + //$NON-NLS-1$ " <authors>\r\n" + //$NON-NLS-1$ " <author>McConnell</author>\r\n" + //$NON-NLS-1$ " </authors>\r\n" + //$NON-NLS-1$ " <publishingInformation>\r\n" + //$NON-NLS-1$ " <publisher>Microsoft Press</publisher>\r\n" + //$NON-NLS-1$ " <publishDate>1993</publishDate>\r\n" + //$NON-NLS-1$ " </publishingInformation>\r\n" + //$NON-NLS-1$ " </book>\r\n" + //$NON-NLS-1$ " <book isbn=\"1-556-15900-5\">\r\n" + //$NON-NLS-1$ " <title>Rapid Development</title>\r\n" + //$NON-NLS-1$ " <subtitle>Taming Wild Software Schedules</subtitle>\r\n" + //$NON-NLS-1$ " <edition>1</edition>\r\n" + //$NON-NLS-1$ " <authors>\r\n" + //$NON-NLS-1$ " <author>McConnell</author>\r\n" + //$NON-NLS-1$ " </authors>\r\n" + //$NON-NLS-1$ " <publishingInformation>\r\n" + //$NON-NLS-1$ " <publisher>Microsoft Press</publisher>\r\n" + //$NON-NLS-1$ " <publishDate>1996</publishDate>\r\n" + //$NON-NLS-1$ " </publishingInformation>\r\n" + //$NON-NLS-1$ " </book>\r\n" + //$NON-NLS-1$ "</Books:bookCollection>"; //$NON-NLS-1$ public void testStreamSourceWithStream() throws Exception { StandardXMLTranslator translator = new StandardXMLTranslator(new StreamSource(new StringReader(sourceXML))); compareDocuments(sourceXML, translator.getString()); } private void compareDocuments(String expectedDoc, String actualDoc) { StringTokenizer tokens1 = new StringTokenizer(expectedDoc, "\r\n"); //$NON-NLS-1$ StringTokenizer tokens2 = new StringTokenizer(actualDoc, "\n");//$NON-NLS-1$ while(tokens1.hasMoreTokens()){ String token1 = tokens1.nextToken().trim(); if(!tokens2.hasMoreTokens()){ fail("XML doc mismatch: expected=" + token1 + "\nactual=none");//$NON-NLS-1$ //$NON-NLS-2$ } String token2 = tokens2.nextToken().trim(); assertEquals("XML doc mismatch: ", token1, token2); //$NON-NLS-1$ } if(tokens2.hasMoreTokens()){ fail("XML doc mismatch: expected=none\nactual=" + tokens2.nextToken().trim());//$NON-NLS-1$ } } }