package de.uniba.dsg.bpmnspector.schematron.commonExec; import api.ValidationException; import api.ValidationResult; import de.uniba.dsg.bpmnspector.schematron.TestCase; import org.junit.Test; /** * Test class for testing Constraint EXT.012 * * @author Matthias Geiger * @version 1.0 * */ public class Ext012 extends TestCase { private static final String ERR_MSG = "If natural-language expressions are used the process is not executable. A " + "FormalExpression has to be provided or the process must be marked as isExecutable='false'."; @Test public void testConstraintFailAdHocSubProcess() throws ValidationException { ValidationResult result = verifyInvalidResult(createFile("EXT012_failure_adHocSubProcess.bpmn"), 1); assertViolation(result.getViolations().get(0), ERR_MSG, "//bpmn:adHocSubProcess[bpmn:completionCondition and ancestor::bpmn:process[@isExecutable='true']][0]", 7); } @Test public void testConstraintSuccessAdHocSubProcess() throws ValidationException { verifyValidResult(createFile("EXT012_success_adHocSubProcess.bpmn")); } @Test public void testConstraintSuccessAdHocSubProcessNamespacePrefix() throws ValidationException { verifyValidResult(createFile("EXT012_success_adHocSubProcessNamespacePrefix.bpmn")); } @Test public void testConstraintFailAssignment() throws ValidationException { ValidationResult result = verifyInvalidResult(createFile("EXT012_failure_assignment.bpmn"), 1); assertViolation(result.getViolations().get(0), ERR_MSG, "//bpmn:assignment[ancestor::bpmn:process[@isExecutable='true']][0]", 21); } @Test public void testConstraintSuccessAssignment() throws ValidationException { verifyValidResult(createFile("EXT012_success_assignment.bpmn")); } @Test public void testConstraintFailComplexGateway() throws ValidationException { ValidationResult result = verifyInvalidResult(createFile("EXT012_failure_complexGateway.bpmn"), 1); assertViolation(result.getViolations().get(0), ERR_MSG, "//bpmn:complexGateway[bpmn:activationCondition and ancestor::bpmn:process[@isExecutable='true']][0]", 18); } @Test public void testConstraintSuccessComplexGateway() throws ValidationException { verifyValidResult(createFile("EXT012_success_complexGateway.bpmn")); } @Test public void testConstraintFailMultiInstanceLoopCharacteristicsInvalidCardinality() throws ValidationException { ValidationResult result = verifyInvalidResult(createFile("EXT012_failure_multiInstanceLoopCharacteristics_invalidCardinality.bpmn"), 1); assertViolation(result.getViolations().get(0), ERR_MSG, "//bpmn:multiInstanceLoopCharacteristics[bpmn:loopCardinality and ancestor::bpmn:process[@isExecutable='true']][0]", 10); } @Test public void testConstraintFailMultiInstanceLoopCharacteristicsInvalidCompletionCondition() throws ValidationException { ValidationResult result = verifyInvalidResult(createFile("EXT012_failure_multiInstanceLoopCharacteristics_invalidCompletionCondition.bpmn"), 1); assertViolation(result.getViolations().get(0), ERR_MSG, "//bpmn:multiInstanceLoopCharacteristics[bpmn:completionCondition and ancestor::bpmn:process[@isExecutable='true']][0]", 10); } @Test public void testConstraintSuccessMultiInstanceLoopCharacteristics() throws ValidationException { verifyValidResult(createFile("EXT012_success_multiInstanceLoopCharacteristics.bpmn")); } @Test public void testConstraintFailSequenceFlow() throws ValidationException { ValidationResult result = verifyInvalidResult(createFile("EXT012_failure_sequenceFlow.bpmn"), 1); assertViolation(result.getViolations().get(0), ERR_MSG, "//bpmn:sequenceFlow[bpmn:conditionExpression and ancestor::bpmn:process[@isExecutable='true']][0]", 16); } @Test public void testConstraintSuccessSequenceFlow() throws ValidationException { verifyValidResult(createFile("EXT012_success_sequenceFlow.bpmn")); } @Test public void testConstraintFailStandardLoopCharacteristics() throws ValidationException { ValidationResult result = verifyInvalidResult(createFile("EXT012_failure_standardLoopCharacteristics.bpmn"), 1); assertViolation(result.getViolations().get(0), ERR_MSG, "//bpmn:standardLoopCharacteristics[bpmn:loopCondition and ancestor::bpmn:process[@isExecutable='true']][0]", 10); } @Test public void testConstraintSuccessStandardLoopCharacteristics() throws ValidationException { verifyValidResult(createFile("EXT012_success_standardLoopCharacteristics.bpmn")); } @Test public void testConstraintFailTimerEventTimeCycle() throws ValidationException { ValidationResult result = verifyInvalidResult(createFile("EXT012_failure_timerEvent_timeCycle.bpmn"), 1); assertViolation(result.getViolations().get(0), ERR_MSG, "//bpmn:timerEventDefinition[(bpmn:timeDate or bpmn:timeDuration or bpmn:timeCycle) and ancestor::bpmn:process[@isExecutable='true']][0]", 10); } @Test public void testConstraintSuccessTimerEventTimeCycle() throws ValidationException { verifyValidResult(createFile("EXT012_success_timerEvent_timeCycle.bpmn")); } @Test public void testConstraintFailTimerEventTimeDate() throws ValidationException { ValidationResult result = verifyInvalidResult(createFile("EXT012_failure_timerEvent_timeDate.bpmn"), 1); assertViolation(result.getViolations().get(0), ERR_MSG, "//bpmn:timerEventDefinition[(bpmn:timeDate or bpmn:timeDuration or bpmn:timeCycle) and ancestor::bpmn:process[@isExecutable='true']][0]", 10); } @Test public void testConstraintSuccessTimerEventTimeDate() throws ValidationException { verifyValidResult(createFile("EXT012_success_timerEvent_timeDate.bpmn")); } @Test public void testConstraintFailTimerEventTimeDuration() throws ValidationException { ValidationResult result = verifyInvalidResult(createFile("EXT012_failure_timerEvent_timeDuration.bpmn"), 1); assertViolation(result.getViolations().get(0), ERR_MSG, "//bpmn:timerEventDefinition[(bpmn:timeDate or bpmn:timeDuration or bpmn:timeCycle) and ancestor::bpmn:process[@isExecutable='true']][0]", 10); } @Test public void testConstraintSuccessTimerEventTimeDuration() throws ValidationException { verifyValidResult(createFile("EXT012_success_timerEvent_timeDuration.bpmn")); } @Override protected String getExtNumber() { return "012"; } }