| /* |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| // explicitly packageless |
| |
| import org.apache.qetest.CheckService; |
| import org.apache.qetest.Logger; |
| import org.apache.qetest.xsl.StylesheetDatalet; |
| import org.apache.qetest.xsl.TestableExtension; |
| import org.apache.qetest.xsl.XHTFileCheckService; |
| |
| import java.io.File; |
| import java.util.Hashtable; |
| |
| /** |
| * Extension for testing xml-xalan/samples/extensions. |
| */ |
| public class javaRedir1 extends TestableExtension |
| { |
| /** Note: no actual extension methods here; this class just does validation. */ |
| |
| //// Implementations of TestableExtension |
| /** Copied from javaRedir1.xml[/doc/foo/@file]. */ |
| public static final String REDIR_NAME = "javaRedir1a-from-build-extensions.out"; |
| |
| /** |
| * Perform and log any pre-transformation info. |
| * @return true if OK; false if any fatal error occoured |
| * @param datalet Datalet of current stylesheet test |
| */ |
| public static boolean preCheck(Logger logger, StylesheetDatalet datalet) |
| { |
| logger.logMsg(Logger.TRACEMSG, "javaRedir1.preCheck"); |
| return true; |
| } |
| |
| |
| /** |
| * Perform and log any post-transformation info. |
| * |
| * The extension should validate that it's extension was |
| * properly called; we also validate output file(s). |
| * |
| * @param logger Logger to dump any info to |
| * @param datalet Datalet of current stylesheet test |
| */ |
| public static void postCheck(Logger logger, StylesheetDatalet datalet) |
| { |
| logger.logMsg(Logger.TRACEMSG, "javaRedir1.postCheck"); |
| |
| // First, validate the normal output file the normal way |
| CheckService fileChecker = (CheckService)datalet.options.get("fileCheckerImpl"); |
| // Supply default value |
| if (null == fileChecker) |
| fileChecker = new XHTFileCheckService(); |
| if (Logger.PASS_RESULT |
| != fileChecker.check(logger, |
| new File(datalet.outputName), |
| new File(datalet.goldName), |
| "Extension test of " + datalet.getDescription()) |
| ) |
| { |
| // Log a custom element with all the file refs first |
| // Closely related to viewResults.xsl select='fileref" |
| //@todo check that these links are valid when base |
| // paths are either relative or absolute! |
| Hashtable attrs = new Hashtable(); |
| attrs.put("idref", (new File(datalet.inputName)).getName()); |
| attrs.put("inputName", datalet.inputName); |
| attrs.put("xmlName", datalet.xmlName); |
| attrs.put("outputName", datalet.outputName); |
| attrs.put("goldName", datalet.goldName); |
| logger.logElement(Logger.STATUSMSG, "fileref", attrs, "Extension test file references"); |
| } |
| // Now, also validate the redirected output! |
| // Calculate location of gold redir file |
| String goldRedir = (new File(datalet.goldName)).getParent() |
| + File.separator + REDIR_NAME; |
| |
| // Calculate location of actual redir file |
| String outRedir = (new File(datalet.outputName)).getParent() |
| + File.separator + REDIR_NAME; |
| |
| // Then check just with actual file name to the constructed |
| // gold name; don't bother with extra logging |
| fileChecker.check(logger, |
| new File(outRedir), |
| new File(goldRedir), |
| "Redir-Extension test of " + datalet.getDescription()); |
| } |
| |
| |
| /** |
| * Description of what this extension does. |
| * @return String description of extension |
| */ |
| public static String getDescription() |
| { |
| return "No extension methods - just validation"; |
| } |
| } |
| |