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 java.io.File; 28*1212f9a0SAndroid Build Coastguard Worker import java.util.Calendar; 29*1212f9a0SAndroid Build Coastguard Worker import java.util.Date; 30*1212f9a0SAndroid Build Coastguard Worker import java.util.Hashtable; 31*1212f9a0SAndroid Build Coastguard Worker 32*1212f9a0SAndroid Build Coastguard Worker /** 33*1212f9a0SAndroid Build Coastguard Worker * Extension for testing xml-xalan/samples/extensions. 34*1212f9a0SAndroid Build Coastguard Worker */ 35*1212f9a0SAndroid Build Coastguard Worker public class javaSample3 extends TestableExtension 36*1212f9a0SAndroid Build Coastguard Worker { 37*1212f9a0SAndroid Build Coastguard Worker 38*1212f9a0SAndroid Build Coastguard Worker /** Extension method called from stylesheet. */ getDate(String year, String month, String day)39*1212f9a0SAndroid Build Coastguard Worker public static Date getDate(String year, String month, String day) 40*1212f9a0SAndroid Build Coastguard Worker { 41*1212f9a0SAndroid Build Coastguard Worker // Bump up counter for later validation in postCheck 42*1212f9a0SAndroid Build Coastguard Worker counter++; 43*1212f9a0SAndroid Build Coastguard Worker Calendar c = Calendar.getInstance(); 44*1212f9a0SAndroid Build Coastguard Worker // Convert each argument to int. 45*1212f9a0SAndroid Build Coastguard Worker c.set(Integer.parseInt(year),Integer.parseInt(month),Integer.parseInt(day)); 46*1212f9a0SAndroid Build Coastguard Worker return c.getTime(); 47*1212f9a0SAndroid Build Coastguard Worker } 48*1212f9a0SAndroid Build Coastguard Worker 49*1212f9a0SAndroid Build Coastguard Worker 50*1212f9a0SAndroid Build Coastguard Worker //// Implementations of TestableExtension 51*1212f9a0SAndroid Build Coastguard Worker /** Simple counter of number of times called. */ 52*1212f9a0SAndroid Build Coastguard Worker private static int counter = 0; 53*1212f9a0SAndroid Build Coastguard Worker 54*1212f9a0SAndroid Build Coastguard Worker 55*1212f9a0SAndroid Build Coastguard Worker /** 56*1212f9a0SAndroid Build Coastguard Worker * Perform and log any pre-transformation info. 57*1212f9a0SAndroid Build Coastguard Worker * @return true if OK; false if any fatal error occoured 58*1212f9a0SAndroid Build Coastguard Worker * @param datalet Datalet of current stylesheet test 59*1212f9a0SAndroid Build Coastguard Worker */ preCheck(Logger logger, StylesheetDatalet datalet)60*1212f9a0SAndroid Build Coastguard Worker public static boolean preCheck(Logger logger, StylesheetDatalet datalet) 61*1212f9a0SAndroid Build Coastguard Worker { 62*1212f9a0SAndroid Build Coastguard Worker logger.logMsg(Logger.INFOMSG, "javaSample3.preCheck; counter=" + counter); 63*1212f9a0SAndroid Build Coastguard Worker return true; 64*1212f9a0SAndroid Build Coastguard Worker } 65*1212f9a0SAndroid Build Coastguard Worker 66*1212f9a0SAndroid Build Coastguard Worker 67*1212f9a0SAndroid Build Coastguard Worker /** 68*1212f9a0SAndroid Build Coastguard Worker * Perform and log any post-transformation info. 69*1212f9a0SAndroid Build Coastguard Worker * 70*1212f9a0SAndroid Build Coastguard Worker * The extension should validate that it's extension was 71*1212f9a0SAndroid Build Coastguard Worker * properly called; we also validate output file. 72*1212f9a0SAndroid Build Coastguard Worker * 73*1212f9a0SAndroid Build Coastguard Worker * @param logger Logger to dump any info to 74*1212f9a0SAndroid Build Coastguard Worker * @param datalet Datalet of current stylesheet test 75*1212f9a0SAndroid Build Coastguard Worker */ postCheck(Logger logger, StylesheetDatalet datalet)76*1212f9a0SAndroid Build Coastguard Worker public static void postCheck(Logger logger, StylesheetDatalet datalet) 77*1212f9a0SAndroid Build Coastguard Worker { 78*1212f9a0SAndroid Build Coastguard Worker // Verify that we've been called at least once 79*1212f9a0SAndroid Build Coastguard Worker if (counter > 0) 80*1212f9a0SAndroid Build Coastguard Worker logger.checkPass("javaSample3 has been called " + counter + " times"); 81*1212f9a0SAndroid Build Coastguard Worker else 82*1212f9a0SAndroid Build Coastguard Worker logger.checkFail("javaSample3 has not been called"); 83*1212f9a0SAndroid Build Coastguard Worker 84*1212f9a0SAndroid Build Coastguard Worker // We also validate the output file the normal way 85*1212f9a0SAndroid Build Coastguard Worker CheckService fileChecker = (CheckService)datalet.options.get("fileCheckerImpl"); 86*1212f9a0SAndroid Build Coastguard Worker // Supply default value 87*1212f9a0SAndroid Build Coastguard Worker if (null == fileChecker) 88*1212f9a0SAndroid Build Coastguard Worker fileChecker = new XHTFileCheckService(); 89*1212f9a0SAndroid Build Coastguard Worker if (Logger.PASS_RESULT 90*1212f9a0SAndroid Build Coastguard Worker != fileChecker.check(logger, 91*1212f9a0SAndroid Build Coastguard Worker new File(datalet.outputName), 92*1212f9a0SAndroid Build Coastguard Worker new File(datalet.goldName), 93*1212f9a0SAndroid Build Coastguard Worker "Extension test of " + datalet.getDescription()) 94*1212f9a0SAndroid Build Coastguard Worker ) 95*1212f9a0SAndroid Build Coastguard Worker { 96*1212f9a0SAndroid Build Coastguard Worker // Log a custom element with all the file refs first 97*1212f9a0SAndroid Build Coastguard Worker // Closely related to viewResults.xsl select='fileref" 98*1212f9a0SAndroid Build Coastguard Worker //@todo check that these links are valid when base 99*1212f9a0SAndroid Build Coastguard Worker // paths are either relative or absolute! 100*1212f9a0SAndroid Build Coastguard Worker Hashtable attrs = new Hashtable(); 101*1212f9a0SAndroid Build Coastguard Worker attrs.put("idref", (new File(datalet.inputName)).getName()); 102*1212f9a0SAndroid Build Coastguard Worker attrs.put("inputName", datalet.inputName); 103*1212f9a0SAndroid Build Coastguard Worker attrs.put("xmlName", datalet.xmlName); 104*1212f9a0SAndroid Build Coastguard Worker attrs.put("outputName", datalet.outputName); 105*1212f9a0SAndroid Build Coastguard Worker attrs.put("goldName", datalet.goldName); 106*1212f9a0SAndroid Build Coastguard Worker logger.logElement(Logger.STATUSMSG, "fileref", attrs, "Extension test file references"); 107*1212f9a0SAndroid Build Coastguard Worker } 108*1212f9a0SAndroid Build Coastguard Worker } 109*1212f9a0SAndroid Build Coastguard Worker 110*1212f9a0SAndroid Build Coastguard Worker 111*1212f9a0SAndroid Build Coastguard Worker /** 112*1212f9a0SAndroid Build Coastguard Worker * Description of what this extension does. 113*1212f9a0SAndroid Build Coastguard Worker * @return String description of extension 114*1212f9a0SAndroid Build Coastguard Worker */ getDescription()115*1212f9a0SAndroid Build Coastguard Worker public static String getDescription() 116*1212f9a0SAndroid Build Coastguard Worker { 117*1212f9a0SAndroid Build Coastguard Worker return "getDate() returns date for ints"; 118*1212f9a0SAndroid Build Coastguard Worker } 119*1212f9a0SAndroid Build Coastguard Worker } 120*1212f9a0SAndroid Build Coastguard Worker 121