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 19*1212f9a0SAndroid Build Coastguard Worker // explicitly packageless 20*1212f9a0SAndroid Build Coastguard Worker 21*1212f9a0SAndroid Build Coastguard Worker import org.apache.qetest.CheckService; 22*1212f9a0SAndroid Build Coastguard Worker import org.apache.qetest.Logger; 23*1212f9a0SAndroid Build Coastguard Worker import org.apache.qetest.xsl.StylesheetDatalet; 24*1212f9a0SAndroid Build Coastguard Worker import org.apache.qetest.xsl.TestableExtension; 25*1212f9a0SAndroid Build Coastguard Worker import org.apache.qetest.xsl.XHTFileCheckService; 26*1212f9a0SAndroid Build Coastguard Worker 27*1212f9a0SAndroid Build Coastguard Worker import org.w3c.dom.Node; 28*1212f9a0SAndroid Build Coastguard Worker import org.w3c.dom.NodeList; 29*1212f9a0SAndroid Build Coastguard Worker 30*1212f9a0SAndroid Build Coastguard Worker import java.io.File; 31*1212f9a0SAndroid Build Coastguard Worker import java.util.Hashtable; 32*1212f9a0SAndroid Build Coastguard Worker 33*1212f9a0SAndroid Build Coastguard Worker /** 34*1212f9a0SAndroid Build Coastguard Worker * Extension for testing xml-xalan/samples/extensions. 35*1212f9a0SAndroid Build Coastguard Worker */ 36*1212f9a0SAndroid Build Coastguard Worker public class javaBugzilla3722 extends TestableExtension 37*1212f9a0SAndroid Build Coastguard Worker { 38*1212f9a0SAndroid Build Coastguard Worker static Hashtable counters = new Hashtable (); 39*1212f9a0SAndroid Build Coastguard Worker 40*1212f9a0SAndroid Build Coastguard Worker static private Logger extnLogger = null; 41*1212f9a0SAndroid Build Coastguard Worker 42*1212f9a0SAndroid Build Coastguard Worker /** Extension method from Bugzilla3722. */ dumpConfig(NodeList conf)43*1212f9a0SAndroid Build Coastguard Worker public String dumpConfig(NodeList conf) 44*1212f9a0SAndroid Build Coastguard Worker { 45*1212f9a0SAndroid Build Coastguard Worker counter++; 46*1212f9a0SAndroid Build Coastguard Worker if (conf != null) 47*1212f9a0SAndroid Build Coastguard Worker { 48*1212f9a0SAndroid Build Coastguard Worker for (int i=0; i<conf.getLength(); i++) 49*1212f9a0SAndroid Build Coastguard Worker { 50*1212f9a0SAndroid Build Coastguard Worker Node node = conf.item(i); 51*1212f9a0SAndroid Build Coastguard Worker if (node!=null) 52*1212f9a0SAndroid Build Coastguard Worker { 53*1212f9a0SAndroid Build Coastguard Worker if (node.hasChildNodes()) 54*1212f9a0SAndroid Build Coastguard Worker { 55*1212f9a0SAndroid Build Coastguard Worker // getLogger().debug("<" + node.getNodeName() + ">"); 56*1212f9a0SAndroid Build Coastguard Worker try 57*1212f9a0SAndroid Build Coastguard Worker { 58*1212f9a0SAndroid Build Coastguard Worker // Below line throws DTMDOMException on CVS code 21-Sep-01 59*1212f9a0SAndroid Build Coastguard Worker NodeList subList = node.getChildNodes(); 60*1212f9a0SAndroid Build Coastguard Worker this.dumpConfig(subList); 61*1212f9a0SAndroid Build Coastguard Worker } 62*1212f9a0SAndroid Build Coastguard Worker catch (Exception e) 63*1212f9a0SAndroid Build Coastguard Worker { 64*1212f9a0SAndroid Build Coastguard Worker if (extnLogger == null) 65*1212f9a0SAndroid Build Coastguard Worker { 66*1212f9a0SAndroid Build Coastguard Worker e.printStackTrace(); 67*1212f9a0SAndroid Build Coastguard Worker throw new RuntimeException("FATAL ERROR: javaBugzilla3722 has no logger; " + e.toString()); 68*1212f9a0SAndroid Build Coastguard Worker } 69*1212f9a0SAndroid Build Coastguard Worker else 70*1212f9a0SAndroid Build Coastguard Worker { 71*1212f9a0SAndroid Build Coastguard Worker extnLogger.logThrowable(Logger.ERRORMSG, e, "dumpConfig threw:"); 72*1212f9a0SAndroid Build Coastguard Worker extnLogger.checkFail("dumpConfig threw unexpected exception"); 73*1212f9a0SAndroid Build Coastguard Worker } 74*1212f9a0SAndroid Build Coastguard Worker } 75*1212f9a0SAndroid Build Coastguard Worker } else 76*1212f9a0SAndroid Build Coastguard Worker { 77*1212f9a0SAndroid Build Coastguard Worker // Output info about the node for later debugging 78*1212f9a0SAndroid Build Coastguard Worker counters.put(node.getNodeName(), node.getNodeValue()); 79*1212f9a0SAndroid Build Coastguard Worker } 80*1212f9a0SAndroid Build Coastguard Worker } 81*1212f9a0SAndroid Build Coastguard Worker } 82*1212f9a0SAndroid Build Coastguard Worker } 83*1212f9a0SAndroid Build Coastguard Worker return "dumpConfig.count=" + counter; 84*1212f9a0SAndroid Build Coastguard Worker } 85*1212f9a0SAndroid Build Coastguard Worker 86*1212f9a0SAndroid Build Coastguard Worker //// Implementations of TestableExtension 87*1212f9a0SAndroid Build Coastguard Worker /** Plain counter of number of times called. */ 88*1212f9a0SAndroid Build Coastguard Worker private static int counter = 0; 89*1212f9a0SAndroid Build Coastguard Worker 90*1212f9a0SAndroid Build Coastguard Worker 91*1212f9a0SAndroid Build Coastguard Worker /** 92*1212f9a0SAndroid Build Coastguard Worker * Perform and log any pre-transformation info. 93*1212f9a0SAndroid Build Coastguard Worker * @return true if OK; false if any fatal error occoured 94*1212f9a0SAndroid Build Coastguard Worker * @param datalet Datalet of current stylesheet test 95*1212f9a0SAndroid Build Coastguard Worker */ preCheck(Logger logger, StylesheetDatalet datalet)96*1212f9a0SAndroid Build Coastguard Worker public static boolean preCheck(Logger logger, StylesheetDatalet datalet) 97*1212f9a0SAndroid Build Coastguard Worker { 98*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.INFOMSG, "javaBugzilla3722.preCheck; counter=" + counter); 99*1212f9a0SAndroid Build Coastguard Worker extnLogger = logger; 100*1212f9a0SAndroid Build Coastguard Worker return true; 101*1212f9a0SAndroid Build Coastguard Worker } 102*1212f9a0SAndroid Build Coastguard Worker 103*1212f9a0SAndroid Build Coastguard Worker 104*1212f9a0SAndroid Build Coastguard Worker /** 105*1212f9a0SAndroid Build Coastguard Worker * Perform and log any post-transformation info. 106*1212f9a0SAndroid Build Coastguard Worker * 107*1212f9a0SAndroid Build Coastguard Worker * The extension should validate that it's extension was 108*1212f9a0SAndroid Build Coastguard Worker * properly called; we also validate output file. 109*1212f9a0SAndroid Build Coastguard Worker * 110*1212f9a0SAndroid Build Coastguard Worker * @param logger Logger to dump any info to 111*1212f9a0SAndroid Build Coastguard Worker * @param datalet Datalet of current stylesheet test 112*1212f9a0SAndroid Build Coastguard Worker */ postCheck(Logger logger, StylesheetDatalet datalet)113*1212f9a0SAndroid Build Coastguard Worker public static void postCheck(Logger logger, StylesheetDatalet datalet) 114*1212f9a0SAndroid Build Coastguard Worker { 115*1212f9a0SAndroid Build Coastguard Worker // Dump out our hashtable for user analysis 116*1212f9a0SAndroid Build Coastguard Worker logger.logHashtable(Logger.STATUSMSG, counters, "javaBugzilla3722.postCheck() counters"); 117*1212f9a0SAndroid Build Coastguard Worker 118*1212f9a0SAndroid Build Coastguard Worker // Verify that we've been called at least once 119*1212f9a0SAndroid Build Coastguard Worker //@todo update to verify specific number of calls and hash entries 120*1212f9a0SAndroid Build Coastguard Worker if (counter > 0) 121*1212f9a0SAndroid Build Coastguard Worker logger.checkPass("javaBugzilla3722 has been called " + counter + " times"); 122*1212f9a0SAndroid Build Coastguard Worker else 123*1212f9a0SAndroid Build Coastguard Worker logger.checkFail("javaBugzilla3722 has not been called"); 124*1212f9a0SAndroid Build Coastguard Worker 125*1212f9a0SAndroid Build Coastguard Worker // We also validate the output file the normal way 126*1212f9a0SAndroid Build Coastguard Worker CheckService fileChecker = (CheckService)datalet.options.get("fileCheckerImpl"); 127*1212f9a0SAndroid Build Coastguard Worker // Supply default value 128*1212f9a0SAndroid Build Coastguard Worker if (null == fileChecker) 129*1212f9a0SAndroid Build Coastguard Worker fileChecker = new XHTFileCheckService(); 130*1212f9a0SAndroid Build Coastguard Worker fileChecker.check(logger, 131*1212f9a0SAndroid Build Coastguard Worker new File(datalet.outputName), 132*1212f9a0SAndroid Build Coastguard Worker new File(datalet.goldName), 133*1212f9a0SAndroid Build Coastguard Worker "Extension test of " + datalet.getDescription()); 134*1212f9a0SAndroid Build Coastguard Worker } 135*1212f9a0SAndroid Build Coastguard Worker 136*1212f9a0SAndroid Build Coastguard Worker 137*1212f9a0SAndroid Build Coastguard Worker /** 138*1212f9a0SAndroid Build Coastguard Worker * Description of what this extension does. 139*1212f9a0SAndroid Build Coastguard Worker * @return String description of extension 140*1212f9a0SAndroid Build Coastguard Worker */ getDescription()141*1212f9a0SAndroid Build Coastguard Worker public static String getDescription() 142*1212f9a0SAndroid Build Coastguard Worker { 143*1212f9a0SAndroid Build Coastguard Worker return "Reproduce Bugzilla # 3722"; 144*1212f9a0SAndroid Build Coastguard Worker } 145*1212f9a0SAndroid Build Coastguard Worker } 146