All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.xmlbeans.impl.tool.XSTCTester Maven / Gradle / Ivy

The newest version!
/*   Copyright 2004 The Apache Software Foundation
 *
 *   Licensed 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.
 */

package org.apache.xmlbeans.impl.tool;

import org.apache.xmlbeans.SystemProperties;
import org.apache.xmlbeans.impl.xb.ltgfmt.TestsDocument;
import org.apache.xmlbeans.impl.xb.ltgfmt.FileDesc;
import org.apache.xmlbeans.XmlOptions;
import org.apache.xmlbeans.XmlException;
import org.apache.xmlbeans.XmlError;
import org.apache.xmlbeans.XmlCalendar;

import java.io.File;
import java.io.PrintWriter;
import java.io.FileWriter;
import java.io.IOException;
import java.util.Collection;
import java.util.ArrayList;
import java.util.Set;
import java.util.HashSet;
import java.util.Collections;
import java.util.Iterator;
import java.util.Date;
import java.util.regex.Pattern;
import java.net.URI;

public class XSTCTester
{
    public static void printUsage()
    {
        System.out.println("Usage: xstc [-showpass] [-errcode] foo_LTGfmt.xml ...");
    }

    public static void main(String[] args) throws IOException
    {
        Set flags = new HashSet();
        flags.add("h");
        flags.add("help");
        flags.add("usage");
        flags.add("version");
        flags.add("showpass");
        flags.add("errcode");

        long start = System.currentTimeMillis();
        
        CommandLine cl = new CommandLine(args, flags, Collections.EMPTY_SET);
        if (cl.getOpt("h") != null || cl.getOpt("help") != null || cl.getOpt("usage") != null)
        {
            printUsage();
            System.exit(0);
            return;
        }

        if (cl.getOpt("version") != null)
        {
            CommandLine.printVersion();
            System.exit(0);
            return;
        }

        String[] badopts = cl.getBadOpts();
        if (badopts.length > 0)
        {
            for (int i = 0; i < badopts.length; i++)
                System.out.println("Unrecognized option: " + badopts[i]);
            printUsage();
            System.exit(0);
            return;
        }

        if (cl.args().length == 0) {
            printUsage();
            return;
        }

        boolean showpass = (cl.getOpt("showpass") != null);
        boolean errcode = (cl.getOpt("errcode") != null);

        File[] allFiles = cl.getFiles();
        Collection ltgFiles = new ArrayList();
        Harness harness = new XMLBeanXSTCHarness();
        
        for (int i = 0; i < allFiles.length; i++)
        {
            if (allFiles[i].getName().indexOf("LTG") >= 0)
                ltgFiles.add(allFiles[i]);
        }
        
        File resultsFile = new File("out.html");
        PrintWriter writer = new PrintWriter(new FileWriter(resultsFile));
        writer.println("");
        writer.println("");
        writer.println("");

        writer.println("");

        writer.println("

XML Schema Test Collection Results

"); writer.println("

Run on " + (new XmlCalendar(new Date())) + "

"); writer.println("

Values in schema or instance valid columns are results from compiling or validating respectively."); writer.println("Red or orange background mean the test failed.

"); writer.println(""); writer.println(""); int failures = 0; int cases = 0; for (Iterator i = ltgFiles.iterator(); i.hasNext(); ) { File ltgFile = (File)i.next(); System.out.println("Processing test cases in " + ltgFile); Collection ltgErrors = new ArrayList(); TestCase[] testCases = parseLTGFile(ltgFile, ltgErrors); Collection results = new ArrayList(); if (testCases != null) for (int j = 0; j < testCases.length; j++) { TestCaseResult result = new TestCaseResult(); result.testCase = testCases[j]; harness.runTestCase(result); cases += 1; if (!result.succeeded(errcode)) failures += 1; else if (!showpass) continue; results.add(result); } writer.println(""); if (!ltgErrors.isEmpty()) { writer.println(""); } else { if (results.size() == 0) writer.println(""); } if (results == null) continue; for (Iterator j = results.iterator(); j.hasNext() ;) { summarizeResultAsHTMLTableRows((TestCaseResult)j.next(), writer, errcode); } } writer.println(""); writer.println("
idDescriptionsch vins v
" + ltgFile + "
Errors within the LTG file:"); writer.println(""); for (Iterator j = ltgErrors.iterator(); j.hasNext(); ) writer.println(j.next()); writer.println(""); writer.println("
Nothing to report
Summary: " + failures + " failures out of " + cases + " cases run.
"); writer.close(); long finish = System.currentTimeMillis(); System.out.println("Time run tests: " + ((double)(finish - start) / 1000.0) + " seconds" ); // Launch results System.out.println("Results output to " + resultsFile); if (SystemProperties.getProperty("os.name").toLowerCase().indexOf("windows") >= 0) Runtime.getRuntime().exec("cmd /c start iexplore \"" + resultsFile.getAbsolutePath() + "\""); else Runtime.getRuntime().exec("mozilla file://" + resultsFile.getAbsolutePath()); } public static class TestCase { private File ltgFile; private String id; private String origin; private String description; private File schemaFile; private File instanceFile; private File resourceFile; private boolean svExpected; private boolean ivExpected; private boolean rvExpected; private String errorCode; public File getLtgFile() { return ltgFile; } public String getId() { return id; } public String getOrigin() { return origin; } public String getDescription() { return description; } public File getSchemaFile() { return schemaFile; } public File getInstanceFile() { return instanceFile; } public File getResourceFile() { return resourceFile; } public boolean isSvExpected() { return svExpected; } public boolean isIvExpected() { return ivExpected; } public boolean isRvExpected() { return rvExpected; } public String getErrorCode() { return errorCode; } } public static class TestCaseResult { private TestCase testCase; private boolean svActual; private Collection svMessages = new ArrayList(); private boolean ivActual; private Collection ivMessages = new ArrayList(); private boolean crash; public TestCase getTestCase() { return testCase; } public boolean isSvActual() { return svActual; } public void setSvActual(boolean svActual) { this.svActual = svActual; } public boolean isIvActual() { return ivActual; } public void setIvActual(boolean ivActual) { this.ivActual = ivActual; } public Collection getSvMessages() { return Collections.unmodifiableCollection(svMessages); } public void addSvMessages(Collection svMessages) { this.svMessages.addAll(svMessages); } public Collection getIvMessages() { return Collections.unmodifiableCollection(ivMessages); } public void addIvMessages(Collection ivMessages) { this.ivMessages.addAll(ivMessages); } public void setCrash(boolean crash) { this.crash = crash; } public boolean isCrash() { return crash; } public boolean succeeded(boolean errcode) { boolean success = !crash && (isIvActual() == testCase.isIvExpected()) && (isSvActual() == testCase.isSvExpected()); if (errcode && testCase.getErrorCode() != null) success &= errorReported(testCase.getErrorCode(), svMessages) || errorReported(testCase.getErrorCode(), ivMessages); return success; } } public static interface Harness { public void runTestCase(TestCaseResult result); } public static String makeHTMLLink(File file, boolean value) { if (file == null) return " "; URI uri = file.getAbsoluteFile().toURI(); return "" + Boolean.toString(value) + ""; } private static final Pattern leadingSpace = Pattern.compile("^\\s+", Pattern.MULTILINE); public static String makeHTMLDescription(TestCase testCase) { StringBuffer sb = new StringBuffer(); sb.append(""); sb.append(leadingSpace.matcher(testCase.getDescription()).replaceAll("")); sb.append(""); return sb.toString(); } public static void summarizeResultAsHTMLTableRows(TestCaseResult result, PrintWriter out, boolean errcode) { TestCase testCase = result.getTestCase(); boolean errorRow = errcode && testCase.getErrorCode() != null; boolean messagesRow = !result.getIvMessages().isEmpty() || !result.getSvMessages().isEmpty(); boolean sRight = testCase.getSchemaFile() == null || testCase.isSvExpected() == result.isSvActual(); boolean iRight = testCase.getInstanceFile() == null || testCase.isIvExpected() == result.isIvActual(); boolean codeRight = true; if (errorRow) codeRight = (errorReported(testCase.getErrorCode(), result.svMessages) || errorReported(testCase.getErrorCode(), result.ivMessages)); out.println(result.isCrash() ? "" : ""); int idRowSpan = 1 + (errorRow ? 1 : 0) + (messagesRow ? 1 : 0); out.println("" + testCase.getId() + ""); out.println("" + makeHTMLDescription(testCase) + ""); String sLinks; if (testCase.getResourceFile() == null) sLinks = makeHTMLLink(testCase.getSchemaFile(), result.isSvActual()); else sLinks = makeHTMLLink(testCase.getSchemaFile(), result.isSvActual()) + "
" + makeHTMLLink(testCase.getResourceFile(), result.isSvActual()); out.println((sRight ? "" : result.isSvActual() ? "" : "") + sLinks + ""); out.println((iRight ? "" : result.isIvActual() ? "" : "") + makeHTMLLink(testCase.getInstanceFile(), result.isIvActual()) + ""); out.println(""); if (errorRow) { out.println(""); out.println((codeRight ? "" : "") + "expected error: " + testCase.getErrorCode() + ""); out.println(""); } if (messagesRow) { if (!result.succeeded(errcode)) out.println(""); else out.println("<tr><td colspan=4><xmp>"); for (Iterator j = result.getSvMessages().iterator(); j.hasNext(); ) out.println(j.next()); for (Iterator j = result.getIvMessages().iterator(); j.hasNext(); ) out.println(j.next()); out.println(""); } } public static TestCase[] parseLTGFile(File ltgFile, Collection outerErrors) { Collection errors = new ArrayList(); try { XmlOptions ltgOptions = new XmlOptions(); ltgOptions.setLoadSubstituteNamespaces(Collections.singletonMap("", "http://www.bea.com/2003/05/xmlbean/ltgfmt")); ltgOptions.setErrorListener(errors); ltgOptions.setLoadLineNumbers(); TestsDocument doc = TestsDocument.Factory.parse(ltgFile, ltgOptions); if (!doc.validate(ltgOptions)) throw new Exception("Document " + ltgFile + " not valid."); org.apache.xmlbeans.impl.xb.ltgfmt.TestCase[] testCases = doc.getTests().getTestArray(); Collection result = new ArrayList(); for (int i = 0; i < testCases.length; i++) { TestCase newCase = new TestCase(); newCase.ltgFile = ltgFile; newCase.id = testCases[i].getId(); newCase.origin = testCases[i].getOrigin(); newCase.description = testCases[i].getDescription(); FileDesc[] filedescs = testCases[i].getFiles().getFileArray(); testCases[i].getOrigin(); for (int j = 0; j < filedescs.length; j++) { String dir = filedescs[j].getFolder(); String filename = filedescs[j].getFileName(); File theFile = new File(ltgFile.getParentFile(), dir + "/" + filename); if (!theFile.exists() || !theFile.isFile() || !theFile.canRead()) { outerErrors.add(XmlError.forObject("Can't read file " + theFile, filedescs[j]).toString()); continue; } switch (filedescs[j].getRole().intValue()) { case FileDesc.Role.INT_INSTANCE: if (newCase.instanceFile != null) outerErrors.add(XmlError.forObject("More than one instance file speicifed - ignoring all but last", filedescs[j]).toString()); newCase.instanceFile = theFile; newCase.ivExpected = filedescs[j].getValidity(); break; case FileDesc.Role.INT_SCHEMA: if (newCase.schemaFile != null) outerErrors.add(XmlError.forObject("More than one schema file speicifed - ignoring all but last", filedescs[j]).toString()); newCase.schemaFile = theFile; newCase.svExpected = filedescs[j].getValidity(); break; case FileDesc.Role.INT_RESOURCE: if (newCase.resourceFile != null) outerErrors.add(XmlError.forObject("More than one resource file speicifed - ignoring all but last", filedescs[j]).toString()); newCase.resourceFile = theFile; newCase.rvExpected = filedescs[j].getValidity(); break; default: throw new XmlException(XmlError.forObject("Unexpected file role", filedescs[j])); } if (filedescs[j].getCode() != null) newCase.errorCode = filedescs[j].getCode().getID(); } result.add(newCase); } return (TestCase[])result.toArray(new TestCase[result.size()]); } catch (Exception e) { if (errors.isEmpty()) outerErrors.add(e.getMessage()); else for (Iterator i = errors.iterator(); i.hasNext(); ) outerErrors.add(i.next().toString()); return null; } } public static boolean errorReported(String errorCode, Collection set) { if (errorCode == null || set == null || set.size() == 0) return false; for (Iterator i = set.iterator(); i.hasNext(); ) { if (errorCode.equals(((XmlError)i.next()).getErrorCode())) return true; } return false; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy