001/*
002 * Copyright (c) 2004-2012, Willem Cazander
003 * All rights reserved.
004 *
005 * Redistribution and use in source and binary forms, with or without modification, are permitted provided
006 * that the following conditions are met:
007 * 
008 * * Redistributions of source code must retain the above copyright notice, this list of conditions and the
009 *   following disclaimer.
010 * * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and
011 *   the following disclaimer in the documentation and/or other materials provided with the distribution.
012 * 
013 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
014 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
015 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
016 * THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
017 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
018 * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
019 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
020 * TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
021 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
022 */
023
024package org.x4o.xml.core;
025
026import java.io.File;
027import java.io.FileOutputStream;
028import java.io.IOException;
029
030import org.x4o.xml.core.config.X4OLanguagePropertyKeys;
031import org.x4o.xml.test.TestParser;
032
033import junit.framework.TestCase;
034
035/**
036 * X4ODebugWriterTest runs parser with debug output.
037 * 
038 * @author Willem Cazander
039 * @version 1.0 Aug 26, 2012
040 */
041public class X4ODebugWriterTest extends TestCase {
042        
043
044        private File createDebugFile() throws IOException {
045                File debugFile = File.createTempFile("test-debug", ".xml");
046                debugFile.deleteOnExit();
047                return debugFile;
048        }
049        
050        public void testDebugOutput() throws Exception {
051                File debugFile = createDebugFile();
052                TestParser parser = new TestParser();
053                parser.setProperty(X4OLanguagePropertyKeys.DEBUG_OUTPUT_STREAM, new FileOutputStream(debugFile));
054                parser.parseResource("tests/attributes/test-bean.xml");
055                
056                assertTrue("Debug file does not exists.",debugFile.exists());
057        }
058
059        public void testDebugOutputFull() throws Exception {
060                File debugFile = createDebugFile();
061                TestParser parser = new TestParser();
062                parser.setProperty(X4OLanguagePropertyKeys.DEBUG_OUTPUT_STREAM, new FileOutputStream(debugFile));
063                parser.setProperty(X4OLanguagePropertyKeys.DEBUG_OUTPUT_ELD_PARSER, true);
064                parser.parseResource("tests/attributes/test-bean.xml");
065                
066                assertTrue("Debug file does not exists.",debugFile.exists());
067        }
068}