1*1212f9a0SAndroid Build Coastguard Worker /* 2*1212f9a0SAndroid Build Coastguard Worker * Licensed to the Apache Software Foundation (ASF) under one 3*1212f9a0SAndroid Build Coastguard Worker * or more contributor license agreements. See the NOTICE file 4*1212f9a0SAndroid Build Coastguard Worker * distributed with this work for additional information 5*1212f9a0SAndroid Build Coastguard Worker * regarding copyright ownership. The ASF licenses this file 6*1212f9a0SAndroid Build Coastguard Worker * to you under the Apache License, Version 2.0 (the "License"); 7*1212f9a0SAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 8*1212f9a0SAndroid Build Coastguard Worker * You may obtain a copy of the License at 9*1212f9a0SAndroid Build Coastguard Worker * 10*1212f9a0SAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 11*1212f9a0SAndroid Build Coastguard Worker * 12*1212f9a0SAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 13*1212f9a0SAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 14*1212f9a0SAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 15*1212f9a0SAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 16*1212f9a0SAndroid Build Coastguard Worker * limitations under the License. 17*1212f9a0SAndroid Build Coastguard Worker */ 18*1212f9a0SAndroid Build Coastguard Worker // Common Qetest / Xalan testing imports 19*1212f9a0SAndroid Build Coastguard Worker import org.apache.qetest.Datalet; 20*1212f9a0SAndroid Build Coastguard Worker import org.apache.qetest.Logger; 21*1212f9a0SAndroid Build Coastguard Worker import org.apache.qetest.TestletImpl; 22*1212f9a0SAndroid Build Coastguard Worker 23*1212f9a0SAndroid Build Coastguard Worker // REPLACE_imports needed for reproducing the bug 24*1212f9a0SAndroid Build Coastguard Worker import org.apache.qetest.*; 25*1212f9a0SAndroid Build Coastguard Worker import org.apache.qetest.trax.*; 26*1212f9a0SAndroid Build Coastguard Worker import org.apache.qetest.xsl.*; 27*1212f9a0SAndroid Build Coastguard Worker 28*1212f9a0SAndroid Build Coastguard Worker // Import all relevant TRAX packages 29*1212f9a0SAndroid Build Coastguard Worker import javax.xml.transform.*; 30*1212f9a0SAndroid Build Coastguard Worker import javax.xml.transform.dom.*; 31*1212f9a0SAndroid Build Coastguard Worker import javax.xml.transform.sax.*; 32*1212f9a0SAndroid Build Coastguard Worker import javax.xml.transform.stream.*; 33*1212f9a0SAndroid Build Coastguard Worker import javax.xml.parsers.DocumentBuilder; 34*1212f9a0SAndroid Build Coastguard Worker import javax.xml.parsers.DocumentBuilderFactory; 35*1212f9a0SAndroid Build Coastguard Worker import javax.xml.parsers.SAXParserFactory; 36*1212f9a0SAndroid Build Coastguard Worker 37*1212f9a0SAndroid Build Coastguard Worker // Needed SAX, DOM, JAXP classes 38*1212f9a0SAndroid Build Coastguard Worker import org.xml.sax.InputSource; 39*1212f9a0SAndroid Build Coastguard Worker import org.xml.sax.XMLReader; 40*1212f9a0SAndroid Build Coastguard Worker import org.w3c.dom.Node; 41*1212f9a0SAndroid Build Coastguard Worker 42*1212f9a0SAndroid Build Coastguard Worker // java classes 43*1212f9a0SAndroid Build Coastguard Worker import java.io.File; 44*1212f9a0SAndroid Build Coastguard Worker import java.io.FilenameFilter; 45*1212f9a0SAndroid Build Coastguard Worker import java.util.Properties; 46*1212f9a0SAndroid Build Coastguard Worker 47*1212f9a0SAndroid Build Coastguard Worker 48*1212f9a0SAndroid Build Coastguard Worker /** 49*1212f9a0SAndroid Build Coastguard Worker * Testlet for reproducing Bugzilla reported bugs. 50*1212f9a0SAndroid Build Coastguard Worker * 51*1212f9a0SAndroid Build Coastguard Worker * @author [email protected] 52*1212f9a0SAndroid Build Coastguard Worker * @author [email protected] 53*1212f9a0SAndroid Build Coastguard Worker */ 54*1212f9a0SAndroid Build Coastguard Worker public class Bugzilla1266 extends TestletImpl 55*1212f9a0SAndroid Build Coastguard Worker { 56*1212f9a0SAndroid Build Coastguard Worker // Initialize our classname for TestletImpl's main() method - must be updated! 57*1212f9a0SAndroid Build Coastguard Worker static { thisClassName = "Bugzilla1266"; } 58*1212f9a0SAndroid Build Coastguard Worker 59*1212f9a0SAndroid Build Coastguard Worker /** 60*1212f9a0SAndroid Build Coastguard Worker * Write Minimal code to reproduce your Bugzilla bug report. 61*1212f9a0SAndroid Build Coastguard Worker * Many Bugzilla tests won't bother with a datalet; they'll 62*1212f9a0SAndroid Build Coastguard Worker * just have the data to reproduce the bug encoded by default. 63*1212f9a0SAndroid Build Coastguard Worker * @param d (optional) Datalet to use as data point for the test. 64*1212f9a0SAndroid Build Coastguard Worker */ execute(Datalet d)65*1212f9a0SAndroid Build Coastguard Worker public void execute(Datalet d) 66*1212f9a0SAndroid Build Coastguard Worker { 67*1212f9a0SAndroid Build Coastguard Worker // Use logger.logMsg(...) instead of System.out.println(...) 68*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.STATUSMSG, "Reproducing Bugzilla#1266"); 69*1212f9a0SAndroid Build Coastguard Worker LoggingErrorListener loggingErrorListener = new LoggingErrorListener(logger); 70*1212f9a0SAndroid Build Coastguard Worker loggingErrorListener.setThrowWhen(LoggingErrorListener.THROW_NEVER); 71*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.STATUSMSG, "loggingErrorListener originally setup:" + loggingErrorListener.getQuickCounters()); 72*1212f9a0SAndroid Build Coastguard Worker 73*1212f9a0SAndroid Build Coastguard Worker TransformerFactory factory = null; 74*1212f9a0SAndroid Build Coastguard Worker Templates templates = null; 75*1212f9a0SAndroid Build Coastguard Worker Transformer transformer = null; 76*1212f9a0SAndroid Build Coastguard Worker try 77*1212f9a0SAndroid Build Coastguard Worker { 78*1212f9a0SAndroid Build Coastguard Worker factory = TransformerFactory.newInstance(); 79*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.STATUSMSG, "About to factory.newTemplates(" + QetestUtils.filenameToURL("identity.xsl") + ")"); 80*1212f9a0SAndroid Build Coastguard Worker templates = factory.newTemplates(new StreamSource(QetestUtils.filenameToURL("identity.xsl"))); 81*1212f9a0SAndroid Build Coastguard Worker transformer = templates.newTransformer(); 82*1212f9a0SAndroid Build Coastguard Worker 83*1212f9a0SAndroid Build Coastguard Worker // Set the errorListener and validate it 84*1212f9a0SAndroid Build Coastguard Worker transformer.setErrorListener(loggingErrorListener); 85*1212f9a0SAndroid Build Coastguard Worker if (transformer.getErrorListener() == loggingErrorListener) 86*1212f9a0SAndroid Build Coastguard Worker logger.checkPass("set/getErrorListener on transformer"); 87*1212f9a0SAndroid Build Coastguard Worker else 88*1212f9a0SAndroid Build Coastguard Worker logger.checkFail("set/getErrorListener on transformer"); 89*1212f9a0SAndroid Build Coastguard Worker 90*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.STATUSMSG, "Reproduce Bugzilla1266 - warning due to bad output props not propagated"); 91*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.STATUSMSG, "transformer.setOutputProperty(encoding, illegal-encoding-value)"); 92*1212f9a0SAndroid Build Coastguard Worker transformer.setOutputProperty("encoding", "illegal-encoding-value"); 93*1212f9a0SAndroid Build Coastguard Worker 94*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.STATUSMSG, "about to transform(...)"); 95*1212f9a0SAndroid Build Coastguard Worker transformer.transform(new StreamSource(QetestUtils.filenameToURL("identity.xml")), 96*1212f9a0SAndroid Build Coastguard Worker new StreamResult("Bugzilla1266.out")); 97*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.STATUSMSG, "after transform(...)"); 98*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.STATUSMSG, "loggingErrorListener after transform:" + loggingErrorListener.getQuickCounters()); 99*1212f9a0SAndroid Build Coastguard Worker 100*1212f9a0SAndroid Build Coastguard Worker // Validate that one warning (about illegal-encoding-value) should have been reported 101*1212f9a0SAndroid Build Coastguard Worker int[] errCtr = loggingErrorListener.getCounters(); 102*1212f9a0SAndroid Build Coastguard Worker if (errCtr[LoggingErrorListener.TYPE_WARNING] > 0) 103*1212f9a0SAndroid Build Coastguard Worker logger.checkPass("At least one Warning listned to for illegal-encoding-value"); 104*1212f9a0SAndroid Build Coastguard Worker else 105*1212f9a0SAndroid Build Coastguard Worker logger.checkFail("At least one Warning listned to for illegal-encoding-value"); 106*1212f9a0SAndroid Build Coastguard Worker 107*1212f9a0SAndroid Build Coastguard Worker // Validate the actual output file as well: in this case, 108*1212f9a0SAndroid Build Coastguard Worker // the stylesheet should still work 109*1212f9a0SAndroid Build Coastguard Worker CheckService fileChecker = new XHTFileCheckService(); 110*1212f9a0SAndroid Build Coastguard Worker fileChecker.check(logger, 111*1212f9a0SAndroid Build Coastguard Worker new File("Bugzilla1266.out"), 112*1212f9a0SAndroid Build Coastguard Worker new File("identity.gold"), 113*1212f9a0SAndroid Build Coastguard Worker "transform of good xsl w/bad output props into: " + "Bugzilla1266.out"); 114*1212f9a0SAndroid Build Coastguard Worker 115*1212f9a0SAndroid Build Coastguard Worker } 116*1212f9a0SAndroid Build Coastguard Worker catch (Throwable t) 117*1212f9a0SAndroid Build Coastguard Worker { 118*1212f9a0SAndroid Build Coastguard Worker logger.checkFail("Bugzilla1266 unexpectedly threw: " + t.toString()); 119*1212f9a0SAndroid Build Coastguard Worker logger.logThrowable(Logger.ERRORMSG, t, "Bugzilla1266 unexpectedly threw"); 120*1212f9a0SAndroid Build Coastguard Worker } 121*1212f9a0SAndroid Build Coastguard Worker 122*1212f9a0SAndroid Build Coastguard Worker } 123*1212f9a0SAndroid Build Coastguard Worker 124*1212f9a0SAndroid Build Coastguard Worker /** 125*1212f9a0SAndroid Build Coastguard Worker * <a href="http://nagoya.apache.org/bugzilla/show_bug.cgi?id=1266"> 126*1212f9a0SAndroid Build Coastguard Worker * Link to Bugzilla report</a> 127*1212f9a0SAndroid Build Coastguard Worker * @return Warning Event not being fired from Transformer when using invalid Encoding String. 128*1212f9a0SAndroid Build Coastguard Worker */ getDescription()129*1212f9a0SAndroid Build Coastguard Worker public String getDescription() 130*1212f9a0SAndroid Build Coastguard Worker { 131*1212f9a0SAndroid Build Coastguard Worker return "Warning Event not being fired from Transformer when using invalid Encoding String"; 132*1212f9a0SAndroid Build Coastguard Worker } 133*1212f9a0SAndroid Build Coastguard Worker 134*1212f9a0SAndroid Build Coastguard Worker } // end of class Bugzilla1266 135*1212f9a0SAndroid Build Coastguard Worker 136