xref: /aosp_15_r20/external/apache-xml/test/tests/extensions/java/javaBugzilla3722.java (revision 1212f9a0ffdc28482b8821715d2222bf16dc14e2)
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