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 import javax.xml.transform.*; 24*1212f9a0SAndroid Build Coastguard Worker import javax.xml.transform.dom.*; 25*1212f9a0SAndroid Build Coastguard Worker import javax.xml.transform.stream.*; 26*1212f9a0SAndroid Build Coastguard Worker import org.apache.xalan.stree.DocumentImpl; 27*1212f9a0SAndroid Build Coastguard Worker import org.apache.xalan.extensions.ExpressionContext; 28*1212f9a0SAndroid Build Coastguard Worker import org.xml.sax.InputSource; 29*1212f9a0SAndroid Build Coastguard Worker import org.w3c.dom.Document; 30*1212f9a0SAndroid Build Coastguard Worker import org.w3c.dom.Element; 31*1212f9a0SAndroid Build Coastguard Worker import org.w3c.dom.Node; 32*1212f9a0SAndroid Build Coastguard Worker import java.io.File; 33*1212f9a0SAndroid Build Coastguard Worker 34*1212f9a0SAndroid Build Coastguard Worker /** 35*1212f9a0SAndroid Build Coastguard Worker * Testlet for reproducing Bugzilla reported bugs. 36*1212f9a0SAndroid Build Coastguard Worker * @author [email protected] (Vladimir Rylsky) 37*1212f9a0SAndroid Build Coastguard Worker * @author [email protected] 38*1212f9a0SAndroid Build Coastguard Worker */ 39*1212f9a0SAndroid Build Coastguard Worker public class Bugzilla1288 extends TestletImpl 40*1212f9a0SAndroid Build Coastguard Worker { 41*1212f9a0SAndroid Build Coastguard Worker // Initialize our classname for TestletImpl's main() method - must be updated! 42*1212f9a0SAndroid Build Coastguard Worker static { thisClassName = "Bugzilla1288"; } 43*1212f9a0SAndroid Build Coastguard Worker 44*1212f9a0SAndroid Build Coastguard Worker /** 45*1212f9a0SAndroid Build Coastguard Worker * @param d (optional) Datalet to use as data point for the test. 46*1212f9a0SAndroid Build Coastguard Worker */ execute(Datalet d)47*1212f9a0SAndroid Build Coastguard Worker public void execute(Datalet d) 48*1212f9a0SAndroid Build Coastguard Worker { 49*1212f9a0SAndroid Build Coastguard Worker // Use logger.logMsg(...) instead of System.out.println(...) 50*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.STATUSMSG, "Reproducing Bugzilla#1288 TreeWalker.traverse goes to infinite loop (with extension)"); 51*1212f9a0SAndroid Build Coastguard Worker // Just transform the stylesheet: 52*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.CRITICALMSG, "WARNING! THIS TEST MAY HANG! (i.e. don't run in automation)"); 53*1212f9a0SAndroid Build Coastguard Worker try 54*1212f9a0SAndroid Build Coastguard Worker { 55*1212f9a0SAndroid Build Coastguard Worker TransformerFactory transformerFactory = TransformerFactory.newInstance(); 56*1212f9a0SAndroid Build Coastguard Worker Source transformerSource = new StreamSource(new File("Bugzilla1288.xsl")); 57*1212f9a0SAndroid Build Coastguard Worker Transformer transformer = transformerFactory.newTransformer(transformerSource); 58*1212f9a0SAndroid Build Coastguard Worker Source input = new StreamSource(new File("identity.xml")); 59*1212f9a0SAndroid Build Coastguard Worker Result output = new StreamResult(new File("Bugzilla1288.out")); 60*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.STATUSMSG, "About to transform error.xml into Bugzilla1288.out"); 61*1212f9a0SAndroid Build Coastguard Worker transformer.transform(input, output); 62*1212f9a0SAndroid Build Coastguard Worker logger.checkPass("Transform completed and returned (crash test)"); 63*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.STATUSMSG, "To-do: validate output!"); 64*1212f9a0SAndroid Build Coastguard Worker } 65*1212f9a0SAndroid Build Coastguard Worker catch (Exception e) 66*1212f9a0SAndroid Build Coastguard Worker { 67*1212f9a0SAndroid Build Coastguard Worker logger.checkFail("Transform threw: " + e.toString()); 68*1212f9a0SAndroid Build Coastguard Worker logger.logThrowable(Logger.ERRORMSG, e, "Transform threw"); 69*1212f9a0SAndroid Build Coastguard Worker } 70*1212f9a0SAndroid Build Coastguard Worker logger.checkAmbiguous("Bug occours now: system hangs"); 71*1212f9a0SAndroid Build Coastguard Worker } 72*1212f9a0SAndroid Build Coastguard Worker 73*1212f9a0SAndroid Build Coastguard Worker /** 74*1212f9a0SAndroid Build Coastguard Worker * <a href="http://nagoya.apache.org/bugzilla/show_bug.cgi?id=1288"> 75*1212f9a0SAndroid Build Coastguard Worker * Link to Bugzilla report</a> 76*1212f9a0SAndroid Build Coastguard Worker * @return TreeWalker.traverse goes to infinite loop (with extension). 77*1212f9a0SAndroid Build Coastguard Worker */ getDescription()78*1212f9a0SAndroid Build Coastguard Worker public String getDescription() 79*1212f9a0SAndroid Build Coastguard Worker { 80*1212f9a0SAndroid Build Coastguard Worker return "TreeWalker.traverse goes to infinite loop (with extension)"; 81*1212f9a0SAndroid Build Coastguard Worker } 82*1212f9a0SAndroid Build Coastguard Worker 83*1212f9a0SAndroid Build Coastguard Worker /* Extension function used in stylesheet */ run(ExpressionContext processor, Node context)84*1212f9a0SAndroid Build Coastguard Worker public Node run(ExpressionContext processor, Node context) 85*1212f9a0SAndroid Build Coastguard Worker { 86*1212f9a0SAndroid Build Coastguard Worker Document x_doc = null; 87*1212f9a0SAndroid Build Coastguard Worker Element n_tool; 88*1212f9a0SAndroid Build Coastguard Worker 89*1212f9a0SAndroid Build Coastguard Worker // Note must call public constructor! -sc 90*1212f9a0SAndroid Build Coastguard Worker x_doc = new DocumentImpl(1024); 91*1212f9a0SAndroid Build Coastguard Worker 92*1212f9a0SAndroid Build Coastguard Worker n_tool = (Element)x_doc.appendChild(x_doc.createElement("TOOL_NAME")); 93*1212f9a0SAndroid Build Coastguard Worker n_tool.setAttribute("date", "date-string-here" /* new Date().toString() */); 94*1212f9a0SAndroid Build Coastguard Worker 95*1212f9a0SAndroid Build Coastguard Worker Node n_result = n_tool.appendChild(x_doc.createElement("result")); 96*1212f9a0SAndroid Build Coastguard Worker 97*1212f9a0SAndroid Build Coastguard Worker if (context != null) 98*1212f9a0SAndroid Build Coastguard Worker { 99*1212f9a0SAndroid Build Coastguard Worker try 100*1212f9a0SAndroid Build Coastguard Worker { 101*1212f9a0SAndroid Build Coastguard Worker Transformer copier = TransformerFactory.newInstance().newTransformer(); 102*1212f9a0SAndroid Build Coastguard Worker copier.transform(new DOMSource(n_tool), new DOMResult(context)); 103*1212f9a0SAndroid Build Coastguard Worker } 104*1212f9a0SAndroid Build Coastguard Worker catch (TransformerException ex) 105*1212f9a0SAndroid Build Coastguard Worker { 106*1212f9a0SAndroid Build Coastguard Worker ex.printStackTrace(); 107*1212f9a0SAndroid Build Coastguard Worker } 108*1212f9a0SAndroid Build Coastguard Worker } 109*1212f9a0SAndroid Build Coastguard Worker 110*1212f9a0SAndroid Build Coastguard Worker return n_tool; 111*1212f9a0SAndroid Build Coastguard Worker } 112*1212f9a0SAndroid Build Coastguard Worker } // end of class Bugzilla1288 113