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

de.viadee.bpm.vPAV.processing.checker.XorConventionChecker Maven / Gradle / Ivy

Go to download

The tool checks Camunda projects for consistency and discovers errors in process-driven applications. Called as a Maven plugin or JUnit test, it discovers esp. inconsistencies of a given BPMN model in the classpath and the sourcecode of an underlying java project, such as a delegate reference to a non-existing java class or a non-existing Spring bean.

There is a newer version: 3.0.8
Show newest version
/**
 * BSD 3-Clause License
 *
 * Copyright © 2019, viadee Unternehmensberatung AG
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *
 * * Redistributions of source code must retain the above copyright notice, this
 *   list of conditions and the following disclaimer.
 *
 * * Redistributions in binary form must reproduce the above copyright notice,
 *   this list of conditions and the following disclaimer in the documentation
 *   and/or other materials provided with the distribution.
 *
 * * Neither the name of the copyright holder nor the names of its
 *   contributors may be used to endorse or promote products derived from
 *   this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */
package de.viadee.bpm.vPAV.processing.checker;

import de.viadee.bpm.vPAV.BpmnScanner;
import de.viadee.bpm.vPAV.Messages;
import de.viadee.bpm.vPAV.config.model.ElementConvention;
import de.viadee.bpm.vPAV.config.model.Rule;
import de.viadee.bpm.vPAV.config.model.Setting;
import de.viadee.bpm.vPAV.constants.BpmnConstants;
import de.viadee.bpm.vPAV.output.IssueWriter;
import de.viadee.bpm.vPAV.processing.CheckName;
import de.viadee.bpm.vPAV.processing.ProcessingException;
import de.viadee.bpm.vPAV.processing.code.flow.BpmnElement;
import de.viadee.bpm.vPAV.processing.model.data.CheckerIssue;
import de.viadee.bpm.vPAV.processing.model.data.CriticalityEnum;
import org.camunda.bpm.model.bpmn.impl.BpmnModelConstants;
import org.camunda.bpm.model.bpmn.instance.BaseElement;
import org.camunda.bpm.model.bpmn.instance.ExclusiveGateway;
import org.w3c.dom.Element;
import org.w3c.dom.Node;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Map;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class XorConventionChecker extends AbstractElementChecker {

	public XorConventionChecker(final Rule rule, final BpmnScanner bpmnScanner) {
		super(rule, bpmnScanner);
	}

	/**
	 * Check if XOR gateways and their outgoing edges adhere to naming conventions
	 *
	 * @return issues
	 */
	@Override
	public Collection check(final BpmnElement element) {

		final Collection issues = new ArrayList();
		final BaseElement bpmnElement = element.getBaseElement();
		final Map settings = rule.getSettings();

		if (bpmnElement instanceof ExclusiveGateway) {
			String xor_gateway = bpmnScanner.getXorGateWays(bpmnElement.getId());

			if (bpmnScanner.getOutgoing(xor_gateway) > 1) {

				// check default path
				if (settings != null && settings.containsKey(BpmnConstants.REQUIRED_DEFAULT)
						&& settings.get(BpmnConstants.REQUIRED_DEFAULT).getValue().equals("true") //$NON-NLS-1$
						&& bpmnElement.getAttributeValue(BpmnConstants.DEFAULT) == null) {
					issues.addAll(IssueWriter.createIssue(rule, CriticalityEnum.WARNING, element,
							String.format(Messages.getString("XorConventionChecker.1"), //$NON-NLS-1$
									CheckName.checkName(bpmnElement))));
				}

				final ArrayList elementConventions = (ArrayList) rule
						.getElementConventions();

				if (elementConventions == null) {
					throw new ProcessingException("xor naming convention checker must have one element convention!"); //$NON-NLS-1$
				}

				// TODO: dont use indices
				final String patternString = elementConventions.get(0).getPattern().trim();
				final String taskName = bpmnElement.getAttributeValue(BpmnModelConstants.BPMN_ATTRIBUTE_NAME);
				if (taskName != null && taskName.trim().length() > 0) {
					final Pattern pattern = Pattern.compile(patternString);
					final String taskNameClean = taskName.replaceAll("\n", "").replaceAll("\r", ""); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$
					Matcher matcher = pattern.matcher(taskNameClean);

					if (!matcher.matches()) {
						issues.addAll(
								IssueWriter.createIssue(rule, CriticalityEnum.WARNING, element,
										String.format(Messages.getString("XorConventionChecker.7"), //$NON-NLS-1$
												CheckName.checkName(bpmnElement)),
										elementConventions.get(0).getDescription()));
					}
				} else {
					issues.addAll(IssueWriter.createIssue(rule, CriticalityEnum.WARNING, element,
							Messages.getString("XorConventionChecker.8"))); //$NON-NLS-1$
				}

				// TODO: dont use indices
				final ArrayList edges = bpmnScanner.getOutgoingEdges(bpmnElement.getId());
				final String patternStringEdge = elementConventions.get(1).getPattern().trim();

				for (int i = 0; i < edges.size(); i++) {
					Element Task_Element = (Element) edges.get(i);
					final String edgeName = Task_Element.getAttribute(BpmnModelConstants.BPMN_ATTRIBUTE_NAME);
					if (edgeName != null && edgeName.trim().length() > 0) {
						final Pattern pattern = Pattern.compile(patternStringEdge);
						final String edgeNameClean = edgeName.replaceAll("\n", "").replaceAll("\r", ""); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$
						Matcher matcher = pattern.matcher(edgeNameClean);
						if (!matcher.matches()) {
							issues.addAll(IssueWriter.createIssue(rule, CriticalityEnum.WARNING, element,
									String.format(Messages.getString("XorConventionChecker.13"), //$NON-NLS-1$
											CheckName.checkName(bpmnElement)),
									elementConventions.get(1).getDescription()));
						}
					} else {
						issues.addAll(IssueWriter.createIssue(rule, CriticalityEnum.WARNING, element,
								Messages.getString("XorConventionChecker.14"))); //$NON-NLS-1$
					}
				}
			}
		}
		return issues;
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy