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

com.nedap.archie.rules.evaluation.AssertionResult Maven / Gradle / Ivy

Go to download

tools that operate on the archie reference models and archetype object model

There is a newer version: 3.12.0
Show newest version
package com.nedap.archie.rules.evaluation;

import com.nedap.archie.rules.Expression;

import java.util.ArrayList;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;

/**
 * Created by pieter.bos on 04/04/16.
 */
public class AssertionResult {

    private String tag;
    private Expression assertion;
    /**
     * The raw result: Did all the separate checks for this assertion pass?
     */
    private ValueList rawResult;
    /**
     * The result: did this assertion pass?
     */
    private boolean result;


    /**
     * Paths that must have a specific value. Will be set even if this path already has the specific value,
     * to let the UI know that this field can NOT manually be changed by the user right now
     */
    private Map> setPathValues = new LinkedHashMap<>();
    /**
     * Paths that must exist. Will be set even if it does exist, to let the UI know it should not be removed
     */
    private List pathsThatMustExist = new ArrayList<>();
    /**
     * Paths that must not exist. Will be set even if it does not exist, to let the UI know if should not be added.
     */
    private List pathsThatMustNotExist = new ArrayList<>();

    /**
     * Paths where a term code must now be constrained to a value set. Use for example to change a drop down list, to a subselection of
     * the original full list of values
     */
    private Map pathsConstrainedToValueSets = new LinkedHashMap<>();

    public String getTag() {
        return tag;
    }

    public void setTag(String tag) {
        this.tag = tag;
    }

    public Expression getAssertion() {
        return assertion;
    }

    public void setAssertion(Expression assertion) {
        this.assertion = assertion;
    }

    public ValueList getRawResult() {
        return rawResult;
    }

    public void setRawResult(ValueList rawResult) {
        this.rawResult = rawResult;
    }

    public boolean getResult() {
        return result;
    }

    public void setResult(boolean result) {
        this.result = result;
    }

    public Map> getSetPathValues() {
        return setPathValues;
    }

    public void setSetPathValues(Map> setPathValues) {
        this.setPathValues = setPathValues;
    }

    public List getPathsThatMustExist() {
        return pathsThatMustExist;
    }

    public void setPathsThatMustExist(List pathsThatMustExist) {
        this.pathsThatMustExist = pathsThatMustExist;
    }

    public List getPathsThatMustNotExist() {
        return pathsThatMustNotExist;
    }

    public Map getPathsConstrainedToValueSets() {
        return pathsConstrainedToValueSets;
    }

    public void setPathsConstrainedToValueSets(Map pathsConstrainedToValueSets) {
        this.pathsConstrainedToValueSets = pathsConstrainedToValueSets;
    }

    public void setPathsThatMustNotExist(List pathsThatMustNotExist) {
        this.pathsThatMustNotExist = pathsThatMustNotExist;
    }

    public String toString() {
        StringBuilder stringBuilder = new StringBuilder();
        stringBuilder.append("assertion");
        stringBuilder.append(" ");
        if(tag != null) {
            stringBuilder.append(tag);
        } else {
            stringBuilder.append(assertion);
        }
        if(result) {
            stringBuilder.append(" succeeded");
        } else {
            stringBuilder.append(" failed");
        }
        return stringBuilder.toString();
    }

    public void addPathThatMustExist(String path) {
        pathsThatMustExist.add(path);
    }

    public void addPathThatMustNotExist(String path) {
        pathsThatMustNotExist.add(path);
    }

    public void addPathsThatMustNotExist(List path) {
        pathsThatMustNotExist.addAll(path);
    }

    public void setSetPathValue(String path, ValueList values) {
        for(Value value: values.getValues()) {
            //TODO
            setPathValues.put(path, value);
        }

    }

    public void constrainPathToValueSet(String path, String valueSetId) {
        pathsConstrainedToValueSets.put(path, valueSetId);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy