| /* |
| * 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. |
| */ |
| /* |
| * $Id$ |
| */ |
| |
| /* |
| * |
| * TransformStateTest.java |
| * |
| */ |
| package org.apache.qetest.xalanj2; |
| |
| import java.io.File; |
| import java.util.Properties; |
| import java.util.Vector; |
| |
| import org.apache.qetest.FileBasedTest; |
| import org.apache.qetest.Logger; |
| |
| //------------------------------------------------------------------------- |
| |
| /** |
| * Basic functionality testing of TransformState interface. |
| * This is basically just a test driver class for an explicit |
| * list of TransformStateTestlet/Datalets. In the future we |
| * should enable better data-driven testing by being able to |
| * read in a list of TransformStateDatalets somehow. |
| * |
| * @author shane_curcuru@lotus.com |
| * @version $Id$ |
| */ |
| public class TransformStateTest extends FileBasedTest |
| { |
| |
| /** Subdirectory under test\tests\api for our xsl/xml files. */ |
| public static final String X2J_SUBDIR = "xalanj2"; |
| |
| |
| /** Just initialize test name, comment, numTestCases. */ |
| public TransformStateTest() |
| { |
| numTestCases = 1; // REPLACE_num |
| testName = "TransformStateTest"; |
| testComment = "Basic functionality testing of TransformState interface"; |
| } |
| |
| |
| /** |
| * Initialize this test - create output dir. |
| * |
| * @param p Properties to initialize from (if needed) |
| * @return false if we should abort the test; true otherwise |
| */ |
| public boolean doTestFileInit(Properties p) |
| { |
| // NOTE: 'reporter' variable is already initialized at this point |
| |
| // Used for all tests; just dump files in trax subdir |
| File outSubDir = new File(outputDir + File.separator + X2J_SUBDIR); |
| if (!outSubDir.mkdirs()) |
| reporter.logWarningMsg("Could not create output dir: " + outSubDir); |
| |
| return true; |
| } |
| |
| |
| /** |
| * Use a TransformStateTestlet to test some datalets. |
| * |
| * @return false if we should abort the test; true otherwise |
| */ |
| public boolean testCase1() |
| { |
| // Use a 'fake' testCase1 to initialize everything |
| reporter.testCaseInit("Use a TransformStateTestlet to test some datalets"); |
| reporter.logWarningMsg("Note: limited validation: only certain events checked."); |
| |
| // First arg is list of files; currently unused |
| // Note: several method signatures are copied from |
| // StylesheetTestletDriver for future growth |
| Vector datalets = buildDatalets(null, |
| new File(inputDir + File.separator + X2J_SUBDIR), |
| new File(outputDir + File.separator + X2J_SUBDIR), |
| new File(goldDir + File.separator + X2J_SUBDIR)); |
| |
| // Validate datalets |
| if ((null == datalets) || (0 == datalets.size())) |
| { |
| // No datalets to test, report it as an error |
| reporter.checkErr("Testlet or datalets are null/blank, nothing to test!"); |
| return true; |
| } |
| else |
| { |
| reporter.checkPass("Found " + datalets.size() + " datalets to test..."); |
| } |
| |
| // Now just go through the list and process each set |
| int numDatalets = 0; |
| numDatalets = datalets.size(); |
| reporter.logInfoMsg("processFileList-equivalent() with " + numDatalets |
| + " potential tests"); |
| // Close out our 'fake' initialization testCase1 |
| reporter.testCaseClose(); |
| // Iterate over every datalet and test it |
| for (int ctr = 0; ctr < numDatalets; ctr++) |
| { |
| try |
| { |
| reporter.testCaseInit("Testing datalet(" + ctr + ") validation size=" |
| + ((TransformStateDatalet)datalets.elementAt(ctr)).validate99.size()); |
| // Create a Testlet to execute a test with this |
| // next datalet - the Testlet will log all info |
| // about the test, including calling check*() |
| getTestlet().execute((TransformStateDatalet)datalets.elementAt(ctr)); |
| } |
| catch (Throwable t) |
| { |
| // Log any exceptions as fails and keep going |
| //@todo improve the below to output more useful info |
| reporter.checkFail("Datalet num " + ctr + " threw: " + t.toString()); |
| reporter.logThrowable(Logger.ERRORMSG, t, "Datalet threw"); |
| } |
| reporter.testCaseClose(); |
| } // of while... |
| |
| return true; |
| } |
| |
| |
| /** |
| * Transform a vector of individual test names into a Vector |
| * of filled-in datalets to be tested |
| * |
| * This currently is hard-coded to return a static Vector |
| * of Datalets that are simply constructed here. |
| * In the future we should add a way to read them in from disk. |
| * |
| * @param files Vector of local path\filenames to be tested |
| * This is currently ignored |
| * @param testLocation File denoting directory where all |
| * .xml/.xsl tests are found |
| * @param outLocation File denoting directory where all |
| * output files should be put |
| * @param goldLocation File denoting directory where all |
| * gold files are found |
| * @return Vector of StylesheetDatalets that are fully filled in, |
| * i.e. outputName, goldName, etc are filled in respectively |
| * to inputName |
| */ |
| public Vector buildDatalets(Vector files, File testLocation, |
| File outLocation, File goldLocation) |
| { |
| Vector v = new Vector(); |
| |
| /*********************************************** |
| // Comment out validation using ExpectedObjects since they hang 28-Jun-01 -sc |
| // A simple datalet for identity transform |
| TransformStateDatalet d = new TransformStateDatalet(); |
| String testFileName = "identity"; |
| d.inputName = testLocation.getPath() + File.separator + testFileName + ".xsl"; |
| d.xmlName = testLocation.getPath() + File.separator + testFileName + ".xml"; |
| d.outputName = outLocation.getPath() + File.separator + testFileName + ".out"; |
| d.goldName = goldLocation.getPath() + File.separator + testFileName + ".out"; |
| // Validation TransformStates for RootTemplate |
| ExpectedTransformState ets = new ExpectedTransformState(); |
| ets.setName("doc"); |
| ets.set("line", ExpectedObject.MUST_EQUAL, new Integer(6)); |
| ets.set("column", ExpectedObject.MUST_EQUAL, new Integer(8)); |
| ets.set("event", ExpectedObject.MUST_EQUAL, "startElement:"); |
| ets.set("current.match", ExpectedObject.MUST_EQUAL, "@*|node()"); |
| ets.set("matched.match", ExpectedObject.MUST_EQUAL, "@*|node()"); |
| // Add the expected object(s) to the datalet.. |
| d.expectedTransformStates.put(ets.getHashKey(), ets); |
| |
| ets = new ExpectedTransformState(); |
| ets.setName("copy"); |
| ets.set("line", ExpectedObject.MUST_EQUAL, new Integer(7)); |
| ets.set("column", ExpectedObject.MUST_EQUAL, new Integer(15)); |
| ets.set("event", ExpectedObject.MUST_EQUAL, "startElement:"); |
| ets.set("current.match", ExpectedObject.MUST_EQUAL, "@*|node()"); |
| // Add the expected object(s) to the datalet.. |
| d.expectedTransformStates.put(ets.getHashKey(), ets); |
| |
| // Comment out validation using ExpectedObjects since they hang 28-Jun-01 -sc |
| ***********************************************/ |
| // Simple single file with call-template, modes |
| TransformStateDatalet d = new TransformStateDatalet(); |
| String testFileName = "TransformState99a"; |
| d.inputName = testLocation.getPath() + File.separator + testFileName + ".xsl"; |
| d.xmlName = testLocation.getPath() + File.separator + testFileName + ".xml"; |
| d.outputName = outLocation.getPath() + File.separator + testFileName + ".out"; |
| d.goldName = goldLocation.getPath() + File.separator + testFileName + ".out"; |
| d.validate99.put("42.current.name", "apple"); |
| d.validate99.put("42.current.match", "pies-are-good"); |
| d.validate99.put("42.matched.name", "template-1-root"); |
| d.validate99.put("42.matched.match", "/"); |
| |
| // .. and Add the datalet to the vector |
| v.addElement(d); |
| |
| // Simple included file |
| d = new TransformStateDatalet(); |
| testFileName = "TransformState99b"; // and TransformState99binc.xsl |
| d.inputName = testLocation.getPath() + File.separator + testFileName + ".xsl"; |
| d.xmlName = testLocation.getPath() + File.separator + testFileName + ".xml"; |
| d.outputName = outLocation.getPath() + File.separator + testFileName + ".out"; |
| d.goldName = goldLocation.getPath() + File.separator + testFileName + ".out"; |
| // Note this should still be cross-checked for line numbers when using included files! |
| d.validate99.put("27.current.name", "apple"); |
| d.validate99.put("27.current.match", "pies-are-good"); |
| d.validate99.put("27.matched.name", "template-1-root"); |
| d.validate99.put("27.matched.match", "/"); |
| |
| // .. and Add the datalet to the vector |
| v.addElement(d); |
| |
| // Simple imported file |
| d = new TransformStateDatalet(); |
| testFileName = "TransformState99c"; // and TransformState99cimp.xsl |
| d.inputName = testLocation.getPath() + File.separator + testFileName + ".xsl"; |
| d.xmlName = testLocation.getPath() + File.separator + testFileName + ".xml"; |
| d.outputName = outLocation.getPath() + File.separator + testFileName + ".out"; |
| d.goldName = goldLocation.getPath() + File.separator + testFileName + ".out"; |
| // Note this should still be cross-checked for line numbers when using included files! |
| d.validate99.put("32.current.name", "apple"); |
| d.validate99.put("32.current.match", "pies-are-good"); |
| d.validate99.put("32.matched.name", "template-1-root"); |
| d.validate99.put("32.matched.match", "/"); |
| |
| // .. and Add the datalet to the vector |
| v.addElement(d); |
| |
| // All done: return full vector |
| return v; |
| } |
| |
| |
| /** |
| * Convenience method to get a Testlet to use. |
| * Hard-coded to return a TransformStateTestlet. |
| * |
| * @return Testlet for use in this test; null if error |
| */ |
| public TransformStateTestlet getTestlet() |
| { |
| try |
| { |
| // Create it and set our reporter into it |
| TransformStateTestlet t = new TransformStateTestlet(); |
| t.setLogger((Logger)reporter); |
| return t; |
| } |
| catch (Exception e) |
| { |
| // Ooops, problem, should get logged somehow |
| return null; |
| } |
| } |
| |
| |
| /** |
| * Convenience method to print out usage information - update if needed. |
| * @return String denoting usage of this test class |
| */ |
| public String usage() |
| { |
| return ("Common [optional] options supported by TransformStateTest:\n" |
| + "(Note: assumes inputDir=.\\tests\\api)\n" |
| + super.usage()); // Grab our parent classes usage as well |
| } |
| |
| |
| /** |
| * Main method to run test from the command line - can be left alone. |
| * @param args command line argument array |
| */ |
| public static void main(String[] args) |
| { |
| TransformStateTest app = new TransformStateTest(); |
| app.doMain(args); |
| } |
| } |