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.CheckService; 25*1212f9a0SAndroid Build Coastguard Worker import org.apache.qetest.xsl.XHTFileCheckService; 26*1212f9a0SAndroid Build Coastguard Worker 27*1212f9a0SAndroid Build Coastguard Worker import javax.xml.transform.*; 28*1212f9a0SAndroid Build Coastguard Worker import javax.xml.transform.stream.*; 29*1212f9a0SAndroid Build Coastguard Worker import java.io.File; 30*1212f9a0SAndroid Build Coastguard Worker 31*1212f9a0SAndroid Build Coastguard Worker /** 32*1212f9a0SAndroid Build Coastguard Worker * Testlet for reproducing Bugzilla reported bugs. 33*1212f9a0SAndroid Build Coastguard Worker * @author [email protected] 34*1212f9a0SAndroid Build Coastguard Worker * @author [email protected] 35*1212f9a0SAndroid Build Coastguard Worker */ 36*1212f9a0SAndroid Build Coastguard Worker public class Bugzilla5609 extends TestletImpl 37*1212f9a0SAndroid Build Coastguard Worker { 38*1212f9a0SAndroid Build Coastguard Worker // Initialize our classname for TestletImpl's main() method - must be updated! 39*1212f9a0SAndroid Build Coastguard Worker static { thisClassName = "Bugzilla5609"; } 40*1212f9a0SAndroid Build Coastguard Worker 41*1212f9a0SAndroid Build Coastguard Worker /** 42*1212f9a0SAndroid Build Coastguard Worker * Write Minimal code to reproduce your Bugzilla bug report. 43*1212f9a0SAndroid Build Coastguard Worker * Many Bugzilla tests won't bother with a datalet; they'll 44*1212f9a0SAndroid Build Coastguard Worker * just have the data to reproduce the bug encoded by default. 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#5609: Global Variable Initialization across Multiple Transformations"); 51*1212f9a0SAndroid Build Coastguard Worker CheckService fileChecker = new XHTFileCheckService(); 52*1212f9a0SAndroid Build Coastguard Worker try 53*1212f9a0SAndroid Build Coastguard Worker { 54*1212f9a0SAndroid Build Coastguard Worker // Reproduce bug as-is: re-using transformer with global variable decl uses wrong value 55*1212f9a0SAndroid Build Coastguard Worker TransformerFactory factory = TransformerFactory.newInstance(); 56*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.STATUSMSG, "About to newTransformer(Bugzilla5609.xsl)"); 57*1212f9a0SAndroid Build Coastguard Worker Transformer transformer = factory.newTransformer(new StreamSource(new File("Bugzilla5609.xsl"))); 58*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.STATUSMSG, "About to transform#1 Bugzilla5609.xml into .out"); 59*1212f9a0SAndroid Build Coastguard Worker transformer.transform(new StreamSource(new File("Bugzilla5609.xml")), 60*1212f9a0SAndroid Build Coastguard Worker new StreamResult(new File("Bugzilla5609.out"))); 61*1212f9a0SAndroid Build Coastguard Worker fileChecker.check(logger, 62*1212f9a0SAndroid Build Coastguard Worker new File("Bugzilla5609.out"), 63*1212f9a0SAndroid Build Coastguard Worker new File("Bugzilla5609.gold"), 64*1212f9a0SAndroid Build Coastguard Worker "transform#1 into Bugzilla5609.out"); 65*1212f9a0SAndroid Build Coastguard Worker 66*1212f9a0SAndroid Build Coastguard Worker 67*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.STATUSMSG, "About to transform#2 ParamBugzilla5609a.xml into .out"); 68*1212f9a0SAndroid Build Coastguard Worker transformer.transform(new StreamSource(new File("Bugzilla5609a.xml")), 69*1212f9a0SAndroid Build Coastguard Worker new StreamResult(new File("Bugzilla5609a.out"))); 70*1212f9a0SAndroid Build Coastguard Worker fileChecker.check(logger, 71*1212f9a0SAndroid Build Coastguard Worker new File("Bugzilla5609a.out"), 72*1212f9a0SAndroid Build Coastguard Worker new File("Bugzilla5609a.gold"), 73*1212f9a0SAndroid Build Coastguard Worker "transform#2 into Bugzilla5609a.out; but is wrong var num is used"); 74*1212f9a0SAndroid Build Coastguard Worker 75*1212f9a0SAndroid Build Coastguard Worker } 76*1212f9a0SAndroid Build Coastguard Worker catch (Throwable t) 77*1212f9a0SAndroid Build Coastguard Worker { 78*1212f9a0SAndroid Build Coastguard Worker logger.logThrowable(Logger.WARNINGMSG, t, "Bugzilla#5609 threw"); 79*1212f9a0SAndroid Build Coastguard Worker logger.checkErr("Bugzilla#5609 threw " + t.toString()); 80*1212f9a0SAndroid Build Coastguard Worker } 81*1212f9a0SAndroid Build Coastguard Worker 82*1212f9a0SAndroid Build Coastguard Worker try 83*1212f9a0SAndroid Build Coastguard Worker { 84*1212f9a0SAndroid Build Coastguard Worker // Reproduce bug when getting single transformer from templates 85*1212f9a0SAndroid Build Coastguard Worker TransformerFactory factory = TransformerFactory.newInstance(); 86*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.STATUSMSG, "About to newTemplates(Bugzilla5609.xsl)"); 87*1212f9a0SAndroid Build Coastguard Worker Templates templates = factory.newTemplates(new StreamSource(new File("Bugzilla5609.xsl"))); 88*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.STATUSMSG, "About to Templates.newTransformer()"); 89*1212f9a0SAndroid Build Coastguard Worker Transformer transformer = templates.newTransformer(); 90*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.STATUSMSG, "About to transform#1 Bugzilla5609.xml into .out"); 91*1212f9a0SAndroid Build Coastguard Worker transformer.transform(new StreamSource(new File("Bugzilla5609.xml")), 92*1212f9a0SAndroid Build Coastguard Worker new StreamResult(new File("Bugzilla5609.out"))); 93*1212f9a0SAndroid Build Coastguard Worker fileChecker.check(logger, 94*1212f9a0SAndroid Build Coastguard Worker new File("Bugzilla5609.out"), 95*1212f9a0SAndroid Build Coastguard Worker new File("Bugzilla5609.gold"), 96*1212f9a0SAndroid Build Coastguard Worker "transform#1 into Bugzilla5609.out"); 97*1212f9a0SAndroid Build Coastguard Worker 98*1212f9a0SAndroid Build Coastguard Worker 99*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.STATUSMSG, "About to transform#2 Bugzilla5609a.xml into .out"); 100*1212f9a0SAndroid Build Coastguard Worker transformer.transform(new StreamSource(new File("Bugzilla5609a.xml")), 101*1212f9a0SAndroid Build Coastguard Worker new StreamResult(new File("Bugzilla5609a.out"))); 102*1212f9a0SAndroid Build Coastguard Worker fileChecker.check(logger, 103*1212f9a0SAndroid Build Coastguard Worker new File("Bugzilla5609a.out"), 104*1212f9a0SAndroid Build Coastguard Worker new File("Bugzilla5609a.gold"), 105*1212f9a0SAndroid Build Coastguard Worker "transform#2 into Bugzilla5609a.out; but is wrong var num is used"); 106*1212f9a0SAndroid Build Coastguard Worker 107*1212f9a0SAndroid Build Coastguard Worker } 108*1212f9a0SAndroid Build Coastguard Worker catch (Throwable t) 109*1212f9a0SAndroid Build Coastguard Worker { 110*1212f9a0SAndroid Build Coastguard Worker logger.logThrowable(Logger.WARNINGMSG, t, "Bugzilla#5609 threw"); 111*1212f9a0SAndroid Build Coastguard Worker logger.checkErr("Bugzilla#5609 threw " + t.toString()); 112*1212f9a0SAndroid Build Coastguard Worker } 113*1212f9a0SAndroid Build Coastguard Worker } 114*1212f9a0SAndroid Build Coastguard Worker 115*1212f9a0SAndroid Build Coastguard Worker /** 116*1212f9a0SAndroid Build Coastguard Worker * <a href="http://nagoya.apache.org/bugzilla/show_bug.cgi?id=5609"> 117*1212f9a0SAndroid Build Coastguard Worker * Link to Bugzilla report</a> 118*1212f9a0SAndroid Build Coastguard Worker * @return Global Variable Initialization across Multiple Transformations. 119*1212f9a0SAndroid Build Coastguard Worker */ getDescription()120*1212f9a0SAndroid Build Coastguard Worker public String getDescription() 121*1212f9a0SAndroid Build Coastguard Worker { 122*1212f9a0SAndroid Build Coastguard Worker return "Global Variable Initialization across Multiple Transformations"; 123*1212f9a0SAndroid Build Coastguard Worker } 124*1212f9a0SAndroid Build Coastguard Worker 125*1212f9a0SAndroid Build Coastguard Worker } // end of class Bugzilla5609 126*1212f9a0SAndroid Build Coastguard Worker 127