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

org.xmlunit.diff.DifferenceEngine Maven / Gradle / Ivy

There is a newer version: 2.10.0
Show newest version
/*
  This file is licensed 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.
*/
package org.xmlunit.diff;

import java.util.Map;
import javax.xml.transform.Source;
import org.w3c.dom.Attr;
import org.w3c.dom.Node;
import org.xmlunit.util.Predicate;

/**
 * XMLUnit's difference engine.
 */
public interface DifferenceEngine {
    /**
     * Registers a listener that is notified of each comparison.
     * @param l the listener to add
     */
    void addComparisonListener(ComparisonListener l);

    /**
     * Registers a listener that is notified of each comparison with
     * outcome {@link ComparisonResult#EQUAL}.
     * @param l the listener to add
     */
    void addMatchListener(ComparisonListener l);

    /**
     * Registers a listener that is notified of each comparison with
     * outcome other than {@link ComparisonResult#EQUAL}.
     * @param l the listener to add
     */
    void addDifferenceListener(ComparisonListener l);

    /**
     * Sets the strategy for selecting nodes to compare.
     * @param n the strategy to use
     */
    void setNodeMatcher(NodeMatcher n);

    /**
     * Sets the optional strategy that decides which attributes to
     * consider and which to ignore during comparison.
     *
     * 

Only attributes for which the predicate returns true are * part of the comparison. By default all attributes are * considered.

* *

The "special" namespace, namespace-location and * schema-instance-type attributes can not be ignored this way. * If you want to suppress comparison of them you'll need to * implement {@link DifferenceEvaluator}.

* * @param attributeFilter the strategy to use */ void setAttributeFilter(Predicate attributeFilter); /** * Sets the optional strategy that decides which nodes to * consider and which to ignore during comparison. * *

Only nodes for which the predicate returns true are part of * the comparison. By default nodes that are not document types * are considered.

* * @param nodeFilter the strategy to use */ void setNodeFilter(Predicate nodeFilter); /** * Evaluates the severity of a difference. * @param e the evaluator to use */ void setDifferenceEvaluator(DifferenceEvaluator e); /** * Determines whether the comparison should stop after given * difference has been found. * @param c the controller to use */ void setComparisonController(ComparisonController c); /** * Establish a namespace context that will be used in {@link * Comparison.Detail#getXPath Comparison.Detail#getXPath}. * *

Without a namespace context (or with an empty context) the * XPath expressions will only use local names for elements and * attributes.

* * @param prefix2Uri maps from prefix to namespace URI. */ void setNamespaceContext(Map prefix2Uri); /** * Compares two pieces of XML and invokes the registered listeners. * @param control the reference source of "good" XML * @param test the source under test to compare against {@code control} */ void compare(Source control, Source test); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy